mirror of https://github.com/bsnes-emu/bsnes.git
131 lines
4.0 KiB
C++
131 lines
4.0 KiB
C++
//MOS Technologies MOS6502
|
|
|
|
#pragma once
|
|
|
|
namespace Processor {
|
|
|
|
struct MOS6502 {
|
|
virtual auto read(uint16 addr) -> uint8 = 0;
|
|
virtual auto write(uint16 addr, uint8 data) -> void = 0;
|
|
virtual auto lastCycle() -> void = 0;
|
|
virtual auto nmi(uint16& vector) -> void = 0;
|
|
virtual auto readDebugger(uint16 addr) -> uint8 { return 0; }
|
|
|
|
//mos6502.cpp
|
|
auto mdr() const -> uint8;
|
|
auto power() -> void;
|
|
|
|
//memory.cpp
|
|
auto idle() -> void;
|
|
auto idlePageCrossed(uint16, uint16) -> void;
|
|
auto idlePageAlways(uint16, uint16) -> void;
|
|
auto opcode() -> uint8;
|
|
auto operand() -> uint8;
|
|
auto load(uint8 addr) -> uint8;
|
|
auto store(uint8 addr, uint8 data) -> void;
|
|
auto push(uint8 data) -> void;
|
|
auto pull() -> uint8;
|
|
|
|
//algorithms.cpp
|
|
using fp = auto (MOS6502::*)(uint8) -> uint8;
|
|
auto algorithmADC(uint8) -> uint8;
|
|
auto algorithmAND(uint8) -> uint8;
|
|
auto algorithmASL(uint8) -> uint8;
|
|
auto algorithmBIT(uint8) -> uint8;
|
|
auto algorithmCMP(uint8) -> uint8;
|
|
auto algorithmCPX(uint8) -> uint8;
|
|
auto algorithmCPY(uint8) -> uint8;
|
|
auto algorithmDEC(uint8) -> uint8;
|
|
auto algorithmEOR(uint8) -> uint8;
|
|
auto algorithmINC(uint8) -> uint8;
|
|
auto algorithmLD (uint8) -> uint8;
|
|
auto algorithmLSR(uint8) -> uint8;
|
|
auto algorithmORA(uint8) -> uint8;
|
|
auto algorithmROL(uint8) -> uint8;
|
|
auto algorithmROR(uint8) -> uint8;
|
|
auto algorithmSBC(uint8) -> uint8;
|
|
|
|
//instruction.cpp
|
|
auto interrupt() -> void;
|
|
auto instruction() -> void;
|
|
|
|
//instructions.cpp
|
|
auto instructionAbsoluteModify(fp alu) -> void;
|
|
auto instructionAbsoluteModify(fp alu, uint8 index) -> void;
|
|
auto instructionAbsoluteRead(fp alu, uint8& data) -> void;
|
|
auto instructionAbsoluteRead(fp alu, uint8& data, uint8 index) -> void;
|
|
auto instructionAbsoluteWrite(uint8& data) -> void;
|
|
auto instructionAbsoluteWrite(uint8& data, uint8 index) -> void;
|
|
auto instructionBranch(bool take) -> void;
|
|
auto instructionBreak() -> void;
|
|
auto instructionCallAbsolute() -> void;
|
|
auto instructionClear(bool& flag) -> void;
|
|
auto instructionImmediate(fp alu, uint8& data) -> void;
|
|
auto instructionImplied(fp alu, uint8& data) -> void;
|
|
auto instructionIndirectXRead(fp alu, uint8& data) -> void;
|
|
auto instructionIndirectXWrite(uint8& data) -> void;
|
|
auto instructionIndirectYRead(fp alu, uint8& data) -> void;
|
|
auto instructionIndirectYWrite(uint8& data) -> void;
|
|
auto instructionJumpAbsolute() -> void;
|
|
auto instructionJumpIndirect() -> void;
|
|
auto instructionNoOperation() -> void;
|
|
auto instructionPull(uint8& data) -> void;
|
|
auto instructionPullP() -> void;
|
|
auto instructionPush(uint8& data) -> void;
|
|
auto instructionPushP() -> void;
|
|
auto instructionReturnInterrupt() -> void;
|
|
auto instructionReturnSubroutine() -> void;
|
|
auto instructionSet(bool& flag) -> void;
|
|
auto instructionTransfer(uint8& source, uint8& target, bool flag) -> void;
|
|
auto instructionZeroPageModify(fp alu) -> void;
|
|
auto instructionZeroPageModify(fp alu, uint8 index) -> void;
|
|
auto instructionZeroPageRead(fp alu, uint8& data) -> void;
|
|
auto instructionZeroPageRead(fp alu, uint8& data, uint8 index) -> void;
|
|
auto instructionZeroPageWrite(uint8& data) -> void;
|
|
auto instructionZeroPageWrite(uint8& data, uint8 index) -> void;
|
|
|
|
//serialization.cpp
|
|
auto serialize(serializer&) -> void;
|
|
|
|
//disassembler.cpp
|
|
auto disassemble(uint16 pc) -> string;
|
|
|
|
//set to false to disable BCD mode in ADC, SBC instructions
|
|
bool BCD = true;
|
|
|
|
struct Flags {
|
|
bool c; //carry
|
|
bool z; //zero
|
|
bool i; //interrupt disable
|
|
bool d; //decimal mode
|
|
bool v; //overflow
|
|
bool n; //negative
|
|
|
|
inline operator uint() const {
|
|
return c << 0 | z << 1 | i << 2 | d << 3 | v << 6 | n << 7;
|
|
}
|
|
|
|
inline auto& operator=(uint8 data) {
|
|
c = data.bit(0);
|
|
z = data.bit(1);
|
|
i = data.bit(2);
|
|
d = data.bit(3);
|
|
v = data.bit(6);
|
|
n = data.bit(7);
|
|
return *this;
|
|
}
|
|
};
|
|
|
|
struct Registers {
|
|
uint8 a;
|
|
uint8 x;
|
|
uint8 y;
|
|
uint8 s;
|
|
uint16 pc;
|
|
Flags p;
|
|
uint8 mdr;
|
|
} r;
|
|
};
|
|
|
|
}
|