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:
parent
1c1ce625a7
commit
ef5ac1442f
@ -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 {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user