uint32_t do_disasm = 0, old_level;
uint32_t last_irq = 8, last_last_irq = 8;
+uint8_t end_signal = 0;
+
char disasm_buf[4096];
#define KICKBASE 0xF80000
// printf("CPU emulation reset.\n");
}
-
if (mouse_hook_enabled && (mouse_extra != 0x00)) {
// mouse wheel events have occurred; unlike l/m/r buttons, these are queued as keypresses, so add to end of buffer
switch (mouse_extra) {
// dampen the scroll wheel until next while loop iteration
mouse_extra = 0x00;
}
+
+ if (end_signal)
+ goto stop_cpu_emulation;
+
goto cpu_loop;
-//stop_cpu_emulation:
+stop_cpu_emulation:
printf("[CPU] End of CPU thread\n");
}
//m68k_pulse_reset();
printf("CPU emulation reset.\n");
}
- // @todo work out how to signal the main process that we want to quit
- // if (c == 'q') {
- // printf("Quitting and exiting emulator.\n");
- // goto stop_cpu_emulation;
- // }
+ if (c == 'q') {
+ printf("Quitting and exiting emulator.\n");
+ end_signal = 1;
+ goto key_end;
+ }
if (c == 'd') {
realtime_disassembly ^= 1;
do_disasm = 1;
key_end:
printf("[KBD] Keyboard thread ending\n");
+ if (cfg->keyboard_grab) {
+ printf(ungrab_message);
+ release_device(keyboard_fd);
+ }
return (void*)NULL;
}
printf("Failed to open keyboard event source.\n");
}
+ if (cfg->mouse_autoconnect)
+ mouse_hook_enabled = 1;
+
+ if (cfg->keyboard_autoconnect)
+ kb_hook_enabled = 1;
+
InitGayle();
signal(SIGINT, sigint_handler);