- [CHG] Gestió de interrupcions pasada a "mem" (futur "bus")
- [CHG] Reorganitzacions i neteja de codi - [NEW] Constants del espai io en la seua pròpia capçalera - [NEW] Comentaris en algunes parts menys obvies del codi - [CHG] Alguns defines passats a constexpr - [CHG] display::init() no feia més que cridar a display::reinit(). Concretats els dos en display::init() - [ONGOING] Passant la responsabilitat de tornar el foco a la finestra principal (que estaba en el mòdul debug) al gestor de finestres.
This commit is contained in:
+14
-9
@@ -52,13 +52,17 @@ namespace actions
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
// Control de paràmetres
|
||||
if (argc < 2) { printf("ABORTING: No rom specified.\n"); exit(1); }
|
||||
|
||||
// Velocitat de rellotge
|
||||
const uint32_t clock = 4194304;
|
||||
const uint32_t update_freq = clock >> 3;
|
||||
|
||||
// Inicia SDL
|
||||
SDL_Init(SDL_INIT_EVERYTHING);
|
||||
|
||||
// Carrega la rom
|
||||
FILE *f = fopen(argv[1], "rb");
|
||||
if (!f) { printf("ABORTING: Rom not found.\n"); exit(1); }
|
||||
fseek(f, 0, SEEK_END);
|
||||
@@ -68,8 +72,10 @@ int main(int argc, char *argv[])
|
||||
fread(buffer, filesize, 1, f);
|
||||
fclose(f);
|
||||
|
||||
// i mem inicialitza el mbc
|
||||
mem::init(buffer, filesize);
|
||||
|
||||
// Iniciem tots els sistemes
|
||||
sm83dis::loadSymbols();
|
||||
sm83::reset();
|
||||
|
||||
@@ -77,6 +83,7 @@ int main(int argc, char *argv[])
|
||||
display::init();
|
||||
debug::init();
|
||||
|
||||
// Iniciem el menú princpal (ací? perqué? No es de display.h?)
|
||||
ui::menu::init();
|
||||
ui::menu::setexitcallback(actions::exitMenu);
|
||||
|
||||
@@ -96,10 +103,6 @@ int main(int argc, char *argv[])
|
||||
ui::menu::addbooloption(menu, "STOP ON INVALID OP", sm83::getOption(SM83_OPTION_STOP_ON_INVALID), actions::decZoom);
|
||||
ui::menu::addoption(menu, "SHOW ANALYZER", actions::showAnalyzer);
|
||||
|
||||
//zx_ula::sound_init();
|
||||
|
||||
//debug::stop();
|
||||
|
||||
bool should_exit = false;
|
||||
SDL_Event e;
|
||||
|
||||
@@ -174,9 +177,7 @@ int main(int argc, char *argv[])
|
||||
}
|
||||
|
||||
if (!debug::debugging() && !debug::paused()) {
|
||||
bool fastload=false;
|
||||
|
||||
// En cada bucle fem 10 pasos de la CPU, sino s'ofega
|
||||
// En cada pas de bucle fem 10 pasos de la CPU, sino s'ofega
|
||||
for (int i=0;i<20;++i) {
|
||||
if (debug::isbreak(sm83::getPC(), 9)) {
|
||||
debug::stop();
|
||||
@@ -191,14 +192,18 @@ int main(int argc, char *argv[])
|
||||
}
|
||||
}
|
||||
|
||||
// Sincronització:
|
||||
// la frequència del rellotge diu quants t_states pot executar per segon.
|
||||
// update_freq es la freq del rellotge / 8. Per tant, el nombre de t_states que
|
||||
// pot executar cada 125 ms. Ací comprobem si ja havem executat eixe nombre
|
||||
// de t_states i, si ho havem fet, esperem fins que passen 125ms des de l'ultima
|
||||
// vegada que ho comprobarem.
|
||||
if (t_states>=update_freq)
|
||||
{
|
||||
while (SDL_GetTicks()<(time+125)) {}
|
||||
t_states -= update_freq;
|
||||
time = SDL_GetTicks();
|
||||
//z80analyze::refresh();
|
||||
}
|
||||
//z80analyze::refresh(true);
|
||||
|
||||
|
||||
} else if (!debug::debugging() && debug::paused()) {
|
||||
|
||||
Reference in New Issue
Block a user