EightBit/MC6809/test/Board.cpp
Adrian Conlon 6bb8118c7f Add miscellaneous documentation and test gubbins
Signed-off-by: Adrian Conlon <Adrian.conlon@gmail.com>
2018-09-21 00:17:25 +01:00

79 lines
2.4 KiB
C++

#include "stdafx.h"
#include "Board.h"
Board::Board(const Configuration& configuration)
: m_configuration(configuration),
m_cpu(EightBit::mc6809(*this)),
m_disassembler(m_cpu) {
std::vector<uint8_t> content(m_unused2000.size());
std::fill(content.begin(), content.end(), 0xff);
m_unused2000.load(content);
}
void Board::initialise() {
const auto directory = m_configuration.getRomDirectory() + "\\";
loadHexFile(directory + "ExBasROM.hex");
if (m_configuration.isDebugMode()) {
CPU().ExecutingInstruction.connect(std::bind(&Board::Cpu_ExecutingInstruction_Debug, this, std::placeholders::_1));
CPU().ExecutedInstruction.connect(std::bind(&Board::Cpu_ExecutedInstruction_Debug, this, std::placeholders::_1));
}
CPU().ExecutedInstruction.connect(std::bind(&Board::Cpu_ExecutedInstruction_die, this, std::placeholders::_1));
//WrittenByte.connect(std::bind(&Board::Bus_WrittenByte, this, std::placeholders::_1));
//ReadingByte.connect(std::bind(&Board::Bus_ReadingByte, this, std::placeholders::_1));
CPU().powerOn();
CPU().raise(CPU().NMI());
CPU().raise(CPU().FIRQ());
CPU().reset();
}
void Board::Cpu_ExecutingInstruction_Debug(EightBit::mc6809&) {
m_disassembleAt = CPU().PC();
m_ignoreDisassembly = m_disassembler.ignore();
}
void Board::Cpu_ExecutedInstruction_Debug(EightBit::mc6809&) {
if (!m_ignoreDisassembly)
std::cout << m_disassembler.trace(m_disassembleAt) << std::endl;
}
void Board::Cpu_ExecutedInstruction_die(EightBit::mc6809& cpu) {
static uint64_t instructions = 0UL;
if (++instructions > 90000000)
cpu.powerOff();
}
void Board::Bus_WrittenByte(EightBit::EventArgs&) {
if ((ADDRESS().word > 0x9fff) && (ADDRESS().word < 0xc000))
std::cout << std::hex << "** IO wrote " << DATA() << " to " << ADDRESS() << std::endl;
}
void Board::Bus_ReadingByte(EightBit::EventArgs&) {
if ((ADDRESS().word > 0x9fff) && (ADDRESS().word < 0xc000)) {
std::cout << std::hex << "** IO reading " << ADDRESS() << std::endl;
switch (ADDRESS().word) {
case 0xa000:
poke(ADDRESS(), 0x03);
}
}
}
EightBit::MemoryMapping Board::mapping(uint16_t address) {
if (address < 0x8000)
return { m_ram, 0x0000, EightBit::MemoryMapping::ReadWrite };
if (address < 0xa000)
return { m_unused2000, 0x8000, EightBit::MemoryMapping::ReadOnly };
if (address < 0xc000)
return { m_io, 0xa000, EightBit::MemoryMapping::ReadWrite };
return { m_rom, 0xc000, EightBit::MemoryMapping::ReadOnly };
}