1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-27 22:30:49 +00:00

Merge pull request #1161 from TomHarte/6502Idling

6502: add final read cycle to illegal NOPs.
This commit is contained in:
Thomas Harte 2023-08-29 21:24:04 -04:00 committed by GitHub
commit 3e666a08ae
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 10 additions and 6 deletions

View File

@ -131,10 +131,10 @@ template <bool has_emulation, typename Processor> void print_registers(FILE *fil
using Register = CPU::MOS6502Esque::Register; using Register = CPU::MOS6502Esque::Register;
fprintf(file, "\"pc\": %d, ", (processor.value_of(Register::ProgramCounter) + pc_offset) & 65535); fprintf(file, "\"pc\": %d, ", (processor.value_of(Register::ProgramCounter) + pc_offset) & 65535);
fprintf(file, "\"s\": %d, ", processor.value_of(Register::StackPointer)); fprintf(file, "\"s\": %d, ", processor.value_of(Register::StackPointer));
fprintf(file, "\"p\": %d, ", processor.value_of(Register::Flags));
fprintf(file, "\"a\": %d, ", processor.value_of(Register::A)); fprintf(file, "\"a\": %d, ", processor.value_of(Register::A));
fprintf(file, "\"x\": %d, ", processor.value_of(Register::X)); fprintf(file, "\"x\": %d, ", processor.value_of(Register::X));
fprintf(file, "\"y\": %d, ", processor.value_of(Register::Y)); fprintf(file, "\"y\": %d, ", processor.value_of(Register::Y));
fprintf(file, "\"p\": %d, ", processor.value_of(Register::Flags));
if constexpr (has_emulation) { if constexpr (has_emulation) {
fprintf(file, "\"dbr\": %d, ", processor.value_of(Register::DataBank)); fprintf(file, "\"dbr\": %d, ", processor.value_of(Register::DataBank));
fprintf(file, "\"d\": %d, ", processor.value_of(Register::Direct)); fprintf(file, "\"d\": %d, ", processor.value_of(Register::Direct));
@ -169,7 +169,8 @@ template <CPU::MOS6502Esque::Type type> void generate() {
for(int operation = 0; operation < (has_emulation ? 512 : 256); operation++) { for(int operation = 0; operation < (has_emulation ? 512 : 256); operation++) {
// Make tests repeatable, at least for any given instance of // Make tests repeatable, at least for any given instance of
// the runtime. // the runtime.
srand(65816 + operation); constexpr auto type_offset = int(CPU::MOS6502Esque::Type::TWDC65816) - int(type);
srand(65816 + operation + type_offset);
const bool is_emulated = operation & 256; const bool is_emulated = operation & 256;
const uint8_t opcode = operation & 255; const uint8_t opcode = operation & 255;

View File

@ -68,11 +68,14 @@ using namespace CPU::MOS6502;
#define ZeroNop() Program(Zero, CycleFetchOperandFromAddress) #define ZeroNop() Program(Zero, CycleFetchOperandFromAddress)
#define ZeroXNop() Program(ZeroX, CycleFetchOperandFromAddress) #define ZeroXNop() Program(ZeroX, CycleFetchOperandFromAddress)
#define AbsoluteNop() Program(Absolute) #define AbsoluteNop() Program(Absolute, CycleFetchOperandFromAddress)
#define AbsoluteXNop() Program(AbsoluteX) #define AbsoluteXNop() Program(AbsoluteX, CycleFetchOperandFromAddress)
#define ImpliedNop() {OperationMoveToNextProgram} #define ImpliedNop() {OperationMoveToNextProgram}
#define ImmediateNop() Program(OperationIncrementPC) #define ImmediateNop() Program(OperationIncrementPC)
#define AbsoluteNopNoFetch() Program(Absolute)
#define AbsoluteXNopNoFetch() Program(AbsoluteX)
#define JAM {CycleFetchOperand, OperationScheduleJam} #define JAM {CycleFetchOperand, OperationScheduleJam}
ProcessorStorage::ProcessorStorage(Personality personality) { ProcessorStorage::ProcessorStorage(Personality personality) {
@ -425,10 +428,10 @@ ProcessorStorage::ProcessorStorage(Personality personality) {
} }
} else { } else {
for(int location = 0x0f; location <= 0xef; location += 0x20) { for(int location = 0x0f; location <= 0xef; location += 0x20) {
Install(location, AbsoluteNop()); Install(location, AbsoluteNopNoFetch());
} }
for(int location = 0x1f; location <= 0xff; location += 0x20) { for(int location = 0x1f; location <= 0xff; location += 0x20) {
Install(location, AbsoluteXNop()); Install(location, AbsoluteXNopNoFetch());
} }
for(int c = 0x07; c <= 0xe7; c += 0x20) { for(int c = 0x07; c <= 0xe7; c += 0x20) {
Install(c, ZeroNop()); Install(c, ZeroNop());