1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-17 02:30:54 +00:00

Don't invent an address for STP and WAI.

This commit is contained in:
Thomas Harte 2022-06-24 13:05:32 -04:00
parent 1c1ce625a7
commit ef5ac1442f

View File

@ -26,7 +26,6 @@ struct BusHandler: public CPU::MOS6502Esque::BusHandler<uint32_t> {
Cycles perform_bus_operation(CPU::MOS6502Esque::BusOperation operation, uint32_t address, uint8_t *value) { Cycles perform_bus_operation(CPU::MOS6502Esque::BusOperation operation, uint32_t address, uint8_t *value) {
// Record the basics of the operation. // Record the basics of the operation.
auto &cycle = cycles.emplace_back(); auto &cycle = cycles.emplace_back();
cycle.address = address;
cycle.operation = operation; cycle.operation = operation;
cycle.extended_bus = processor.get_extended_bus_output(); cycle.extended_bus = processor.get_extended_bus_output();
@ -41,9 +40,12 @@ struct BusHandler: public CPU::MOS6502Esque::BusHandler<uint32_t> {
throw StopException(); throw StopException();
} }
initial_pc = address; initial_pc = address;
[[fallthrough]];
case BusOperation::Read: case BusOperation::Read:
case BusOperation::ReadProgram: case BusOperation::ReadProgram:
case BusOperation::ReadVector: case BusOperation::ReadVector:
cycle.address = address;
if(ram_value != ram.end()) { if(ram_value != ram.end()) {
cycle.value = *value = ram_value->second; cycle.value = *value = ram_value->second;
} else { } else {
@ -53,6 +55,7 @@ struct BusHandler: public CPU::MOS6502Esque::BusHandler<uint32_t> {
break; break;
case BusOperation::Write: case BusOperation::Write:
cycle.address = address;
cycle.value = ram[address] = *value; cycle.value = ram[address] = *value;
break; break;
@ -61,8 +64,12 @@ struct BusHandler: public CPU::MOS6502Esque::BusHandler<uint32_t> {
throw StopException(); throw StopException();
break; break;
case BusOperation::InternalOperationRead:
case BusOperation::InternalOperationWrite: case BusOperation::InternalOperationWrite:
cycle.value = *value = ram_value->second;
[[fallthrough]];
case BusOperation::InternalOperationRead:
cycle.address = address;
break; break;
default: assert(false); default: assert(false);
@ -97,7 +104,7 @@ struct BusHandler: public CPU::MOS6502Esque::BusHandler<uint32_t> {
struct Cycle { struct Cycle {
CPU::MOS6502Esque::BusOperation operation; CPU::MOS6502Esque::BusOperation operation;
uint32_t address; std::optional<uint32_t> address;
std::optional<uint8_t> value; std::optional<uint8_t> value;
int extended_bus; int extended_bus;
}; };
@ -246,7 +253,12 @@ void print_ram(FILE *file, const std::unordered_map<uint32_t, uint8_t> &data) {
const bool index_size = cycle.extended_bus & ExtendedBusOutput::IndexSize; const bool index_size = cycle.extended_bus & ExtendedBusOutput::IndexSize;
const bool memory_lock = cycle.extended_bus & ExtendedBusOutput::MemoryLock; const bool memory_lock = cycle.extended_bus & ExtendedBusOutput::MemoryLock;
fprintf(target, "[%d, ", cycle.address); fprintf(target, "[");
if(cycle.address) {
fprintf(target, "%d, ", *cycle.address);
} else {
fprintf(target, "null, ");
}
if(cycle.value) { if(cycle.value) {
fprintf(target, "%d, ", *cycle.value); fprintf(target, "%d, ", *cycle.value);
} else { } else {