diff --git a/Intel8080/src/Intel8080.cpp b/Intel8080/src/Intel8080.cpp index d0d4244..3c70265 100644 --- a/Intel8080/src/Intel8080.cpp +++ b/Intel8080/src/Intel8080.cpp @@ -451,7 +451,7 @@ void EightBit::Intel8080::execute(const int x, const int y, const int z, const i break; case 1: // 8-bit loading if (UNLIKELY(z == 6 && y == 6)) { // Exception (replaces LD (HL), (HL)) - halt(); + lowerHALT(); } else { R(y, R(z)); if (UNLIKELY((y == 6) || (z == 6))) // M operations diff --git a/LR35902/src/LR35902.cpp b/LR35902/src/LR35902.cpp index d6df6a1..1193a8c 100644 --- a/LR35902/src/LR35902.cpp +++ b/LR35902/src/LR35902.cpp @@ -315,8 +315,7 @@ int EightBit::GameBoy::LR35902::step() { const int index = EightBit::findFirstSet(masked); BUS().DATA() = 0x38 + (index << 3); } else { - if (halted()) - proceed(); + raiseHALT(); } } @@ -324,7 +323,7 @@ int EightBit::GameBoy::LR35902::step() { handleRESET(); } else if (UNLIKELY(lowered(INT()))) { handleINT(); - } else if (UNLIKELY(halted())) { + } else if (UNLIKELY(lowered(HALT()))) { Processor::execute(0); // NOP } else { Processor::execute(fetchByte()); @@ -589,7 +588,7 @@ void EightBit::GameBoy::LR35902::executeOther(const int x, const int y, const in break; case 1: // 8-bit loading if (UNLIKELY(z == 6 && y == 6)) { // Exception (replaces LD (HL), (HL)) - halt(); + lowerHALT(); } else { R(y, R(z)); if (UNLIKELY((y == 6) || (z == 6))) // M operations