From 57928602d5a0412969d6b283541b32945a7bf357 Mon Sep 17 00:00:00 2001 From: Adrian Conlon Date: Fri, 24 Aug 2018 10:49:13 +0100 Subject: [PATCH] Tidy instruction prefixing in the 6809, such that executed/ing instruction events fire correctly. Signed-off-by: Adrian Conlon --- MC6809/inc/mc6809.h | 6 ++-- MC6809/src/mc6809.cpp | 67 ++++++++++++++++++------------------------- 2 files changed, 31 insertions(+), 42 deletions(-) diff --git a/MC6809/inc/mc6809.h b/MC6809/inc/mc6809.h index 6c3763a..1175fb3 100644 --- a/MC6809/inc/mc6809.h +++ b/MC6809/inc/mc6809.h @@ -119,9 +119,9 @@ namespace EightBit { // Execution helpers - int executeUnprefixed(uint8_t opcode); - int execute10(uint8_t opcode); - int execute11(uint8_t opcode); + void executeUnprefixed(uint8_t opcode); + void execute10(uint8_t opcode); + void execute11(uint8_t opcode); // Register selection for "indexed" register16_t& RR(int which); diff --git a/MC6809/src/mc6809.cpp b/MC6809/src/mc6809.cpp index 0bc6181..e2b805d 100644 --- a/MC6809/src/mc6809.cpp +++ b/MC6809/src/mc6809.cpp @@ -2,6 +2,7 @@ #include "mc6809.h" #include +#include EightBit::mc6809::mc6809(Bus& bus) : BigEndianProcessor(bus) {} @@ -14,39 +15,46 @@ int EightBit::mc6809::step() { resetCycles(); auto returned = 0; if (LIKELY(powered())) { + m_prefix10 = m_prefix11 = false; ExecutingInstruction.fire(*this); - returned = execute(fetchByte()); + return execute(fetchByte()); ExecutedInstruction.fire(*this); } - return returned; + return cycles(); } void EightBit::mc6809::reset() { Processor::reset(); DP() = 0; // Reestablish zero page CC() |= (IF & FF); // Disable interrupts - m_prefix10 = m_prefix11 = false; jump(getWordPaged(0xff, RESETvector)); } int EightBit::mc6809::execute(uint8_t opcode) { - if (m_prefix10) - return execute10(opcode); - else if (m_prefix11) - return execute11(opcode); - return executeUnprefixed(opcode); + const bool prefixed = m_prefix10 || m_prefix11; + if (LIKELY(!prefixed)) { + executeUnprefixed(opcode); + } else { + if (m_prefix10) + execute10(opcode); + else if (m_prefix11) + execute11(opcode); + else + UNREACHABLE; + } + assert(cycles() > 0); + return cycles(); } -int EightBit::mc6809::executeUnprefixed(uint8_t opcode) { +void EightBit::mc6809::executeUnprefixed(uint8_t opcode) { - ASSUME(!m_prefix10); - ASSUME(!m_prefix11); - ASSUME(cycles() == 0); + assert(!(m_prefix10 || m_prefix11)); + assert(cycles() == 0); switch (opcode) { - case 0x10: m_prefix10 = true; break; - case 0x11: m_prefix11 = true; break; + case 0x10: m_prefix10 = true; execute(fetchByte()); break; + case 0x11: m_prefix11 = true; execute(fetchByte()); break; // ABX case 0x3a: addCycles(3); X() += B(); break; // ABX (inherent) @@ -406,20 +414,12 @@ int EightBit::mc6809::executeUnprefixed(uint8_t opcode) { default: UNREACHABLE; } - - if (m_prefix10 || m_prefix11) - ASSUME(cycles() == 0); - else - ASSUME(cycles() > 0); - - return cycles(); } -int EightBit::mc6809::execute10(uint8_t opcode) { +void EightBit::mc6809::execute10(uint8_t opcode) { - ASSUME(m_prefix10); - ASSUME(!m_prefix11); - ASSUME(cycles() == 0); + assert(m_prefix10 && !m_prefix11); + assert(cycles() == 0); switch (opcode) { @@ -485,18 +485,12 @@ int EightBit::mc6809::execute10(uint8_t opcode) { default: UNREACHABLE; } - - m_prefix10 = false; - - ASSUME(cycles() > 0); - return cycles(); } -int EightBit::mc6809::execute11(uint8_t opcode) { +void EightBit::mc6809::execute11(uint8_t opcode) { - ASSUME(m_prefix10); - ASSUME(!m_prefix11); - ASSUME(cycles() == 0); + assert(!m_prefix10 && m_prefix11); + assert(cycles() == 0); switch (opcode) { @@ -520,11 +514,6 @@ int EightBit::mc6809::execute11(uint8_t opcode) { default: UNREACHABLE; } - - m_prefix11 = false; - - ASSUME(cycles() > 0); - return cycles(); } //