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:
commit
3e666a08ae
@ -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;
|
||||||
|
@ -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());
|
||||||
|
Loading…
x
Reference in New Issue
Block a user