2018-08-26 19:09:34 +01:00
|
|
|
#include "stdafx.h"
|
|
|
|
#include "Board.h"
|
|
|
|
|
|
|
|
Board::Board(const Configuration& configuration)
|
|
|
|
: m_configuration(configuration),
|
|
|
|
m_cpu(EightBit::mc6809(*this)),
|
|
|
|
m_disassembler(m_cpu) {}
|
|
|
|
|
|
|
|
void Board::initialise() {
|
|
|
|
|
|
|
|
const auto directory = m_configuration.getRomDirectory() + "\\";
|
|
|
|
|
2018-09-15 14:35:59 +01:00
|
|
|
loadHexFile(directory + "ExBasROM.hex");
|
2018-08-26 19:09:34 +01:00
|
|
|
|
|
|
|
if (m_configuration.isDebugMode()) {
|
|
|
|
CPU().ExecutingInstruction.connect(std::bind(&Board::Cpu_ExecutingInstruction_Debug, this, std::placeholders::_1));
|
2018-08-30 01:37:09 +01:00
|
|
|
CPU().ExecutedInstruction.connect(std::bind(&Board::Cpu_ExecutedInstruction_Debug, this, std::placeholders::_1));
|
2018-08-26 19:09:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
CPU().powerOn();
|
2018-09-15 14:35:59 +01:00
|
|
|
CPU().raise(CPU().NMI());
|
|
|
|
CPU().raise(CPU().FIRQ());
|
2018-08-26 19:09:34 +01:00
|
|
|
CPU().reset();
|
|
|
|
}
|
|
|
|
|
2018-08-27 10:43:12 +01:00
|
|
|
void Board::Cpu_ExecutingInstruction_Debug(EightBit::mc6809&) {
|
2018-08-30 01:37:09 +01:00
|
|
|
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;
|
2018-08-26 19:09:34 +01:00
|
|
|
}
|
|
|
|
|
2018-09-15 14:35:59 +01:00
|
|
|
EightBit::MemoryMapping Board::mapping(uint16_t address) {
|
2018-08-26 19:09:34 +01:00
|
|
|
|
|
|
|
if (address < 0x8000)
|
2018-09-15 14:35:59 +01:00
|
|
|
return { m_ram, 0x0000, EightBit::MemoryMapping::ReadWrite };
|
2018-08-26 19:09:34 +01:00
|
|
|
|
|
|
|
if (address < 0xc000)
|
2018-09-15 14:35:59 +01:00
|
|
|
return { m_io, 0x8000, EightBit::MemoryMapping::ReadWrite };
|
2018-08-26 19:09:34 +01:00
|
|
|
|
2018-09-15 14:35:59 +01:00
|
|
|
return { m_rom, 0xc000, EightBit::MemoryMapping::ReadOnly };
|
2018-08-26 19:09:34 +01:00
|
|
|
}
|