Fixed a false positive with the FF-loop detection

This commit is contained in:
Lior Halphon 2016-09-30 18:24:01 +03:00
parent 5c5b1cd3ae
commit 17748b980a
1 changed files with 5 additions and 4 deletions

View File

@ -79,10 +79,6 @@ static void vblank(GB_gameboy_t *gb)
GB_log(gb, "A stack overflow has probably occurred.\n"); GB_log(gb, "A stack overflow has probably occurred.\n");
frames = test_length - 1; frames = test_length - 1;
} }
if (gb->pc == 0x38 && GB_read_memory(gb, 0x38) == 0xFF) {
GB_log(gb, "The game is probably stuck in an FF loop.\n");
frames = test_length - 1;
}
if (gb->halted && !gb->interrupt_enable) { if (gb->halted && !gb->interrupt_enable) {
GB_log(gb, "The game is deadlocked.\n"); GB_log(gb, "The game is deadlocked.\n");
frames = test_length - 1; frames = test_length - 1;
@ -313,6 +309,11 @@ int main(int argc, char **argv)
frames = 0; frames = 0;
while (running) { while (running) {
GB_run(&gb); GB_run(&gb);
/* This early crash test must not run in vblank because PC might not point to the next instruction. */
if (gb.pc == 0x38 && frames < test_length - 1 && GB_read_memory(&gb, 0x38) == 0xFF) {
GB_log(&gb, "The game is probably stuck in an FF loop.\n");
frames = test_length - 1;
}
} }
if (log_file) { if (log_file) {