mirror of https://github.com/bsnes-emu/bsnes.git
252 lines
8.4 KiB
C++
252 lines
8.4 KiB
C++
#pragma once
|
|
|
|
//Zilog Z80
|
|
|
|
namespace Processor {
|
|
|
|
struct Z80 {
|
|
struct Bus {
|
|
virtual auto requested() -> bool { return _requested; }
|
|
virtual auto granted() -> bool { return _granted; }
|
|
|
|
virtual auto request(bool value) -> void { _requested = value; }
|
|
virtual auto grant(bool value) -> void { _granted = value; }
|
|
|
|
virtual auto read(uint16 addr) -> uint8 = 0;
|
|
virtual auto write(uint16 addr, uint8 data) -> void = 0;
|
|
|
|
virtual auto in(uint8 addr) -> uint8 = 0;
|
|
virtual auto out(uint8 addr, uint8 data) -> void = 0;
|
|
|
|
//serialization.cpp
|
|
virtual auto serialize(serializer&) -> void;
|
|
|
|
private:
|
|
bool _requested;
|
|
bool _granted;
|
|
};
|
|
|
|
virtual auto step(uint clocks) -> void = 0;
|
|
|
|
//z80.cpp
|
|
auto power() -> void;
|
|
|
|
auto irq(bool maskable, uint16 vector = 0x0000, uint8 extbus = 0xff) -> bool;
|
|
auto parity(uint8) const -> bool;
|
|
|
|
//memory.cpp
|
|
auto yield() -> void;
|
|
auto wait(uint clocks = 1) -> void;
|
|
auto opcode() -> uint8;
|
|
auto operand() -> uint8;
|
|
auto operands() -> uint16;
|
|
auto push(uint16) -> void;
|
|
auto pop() -> uint16;
|
|
auto displace(uint16&) -> uint16;
|
|
auto read(uint16 addr) -> uint8;
|
|
auto write(uint16 addr, uint8 data) -> void;
|
|
auto in(uint8 addr) -> uint8;
|
|
auto out(uint8 addr, uint8 data) -> void;
|
|
|
|
//instruction.cpp
|
|
auto instruction() -> void;
|
|
auto instruction(uint8 code) -> void;
|
|
auto instructionCB(uint8 code) -> void;
|
|
auto instructionCBd(uint16 addr, uint8 code) -> void;
|
|
auto instructionED(uint8 code) -> void;
|
|
|
|
//algorithms.cpp
|
|
auto ADD(uint8, uint8, bool = false) -> uint8;
|
|
auto AND(uint8, uint8) -> uint8;
|
|
auto BIT(uint3, uint8) -> uint8;
|
|
auto DEC(uint8) -> uint8;
|
|
auto INC(uint8) -> uint8;
|
|
auto OR (uint8, uint8) -> uint8;
|
|
auto RES(uint3, uint8) -> uint8;
|
|
auto RL (uint8) -> uint8;
|
|
auto RLC(uint8) -> uint8;
|
|
auto RR (uint8) -> uint8;
|
|
auto RRC(uint8) -> uint8;
|
|
auto SET(uint3, uint8) -> uint8;
|
|
auto SLA(uint8) -> uint8;
|
|
auto SLL(uint8) -> uint8;
|
|
auto SRA(uint8) -> uint8;
|
|
auto SRL(uint8) -> uint8;
|
|
auto SUB(uint8, uint8, bool = false) -> uint8;
|
|
auto XOR(uint8, uint8) -> uint8;
|
|
|
|
//instructions.cpp
|
|
auto instructionADC_a_irr(uint16&) -> void;
|
|
auto instructionADC_a_n() -> void;
|
|
auto instructionADC_a_r(uint8&) -> void;
|
|
auto instructionADC_hl_rr(uint16&) -> void;
|
|
auto instructionADD_a_irr(uint16&) -> void;
|
|
auto instructionADD_a_n() -> void;
|
|
auto instructionADD_a_r(uint8&) -> void;
|
|
auto instructionADD_hl_rr(uint16&) -> void;
|
|
auto instructionAND_a_irr(uint16&) -> void;
|
|
auto instructionAND_a_n() -> void;
|
|
auto instructionAND_a_r(uint8&) -> void;
|
|
auto instructionBIT_o_irr(uint3, uint16&) -> void;
|
|
auto instructionBIT_o_irr_r(uint3, uint16&, uint8&) -> void;
|
|
auto instructionBIT_o_r(uint3, uint8&) -> void;
|
|
auto instructionCALL_c_nn(bool c) -> void;
|
|
auto instructionCALL_nn() -> void;
|
|
auto instructionCCF() -> void;
|
|
auto instructionCP_a_irr(uint16& x) -> void;
|
|
auto instructionCP_a_n() -> void;
|
|
auto instructionCP_a_r(uint8& x) -> void;
|
|
auto instructionCPD() -> void;
|
|
auto instructionCPDR() -> void;
|
|
auto instructionCPI() -> void;
|
|
auto instructionCPIR() -> void;
|
|
auto instructionCPL() -> void;
|
|
auto instructionDAA() -> void;
|
|
auto instructionDEC_irr(uint16&) -> void;
|
|
auto instructionDEC_r(uint8&) -> void;
|
|
auto instructionDEC_rr(uint16&) -> void;
|
|
auto instructionDI() -> void;
|
|
auto instructionDJNZ_e() -> void;
|
|
auto instructionEI() -> void;
|
|
auto instructionEX_irr_rr(uint16&, uint16&) -> void;
|
|
auto instructionEX_rr_rr(uint16&, uint16&) -> void;
|
|
auto instructionEXX() -> void;
|
|
auto instructionHALT() -> void;
|
|
auto instructionIM_o(uint2) -> void;
|
|
auto instructionIN_a_in() -> void;
|
|
auto instructionIN_r_ic(uint8&) -> void;
|
|
auto instructionINC_irr(uint16&) -> void;
|
|
auto instructionINC_r(uint8&) -> void;
|
|
auto instructionINC_rr(uint16&) -> void;
|
|
auto instructionIND() -> void;
|
|
auto instructionINDR() -> void;
|
|
auto instructionINI() -> void;
|
|
auto instructionINIR() -> void;
|
|
auto instructionJP_c_nn(bool) -> void;
|
|
auto instructionJP_rr(uint16&) -> void;
|
|
auto instructionJR_c_e(bool) -> void;
|
|
auto instructionLD_a_inn() -> void;
|
|
auto instructionLD_a_irr(uint16& x) -> void;
|
|
auto instructionLD_inn_a() -> void;
|
|
auto instructionLD_inn_rr(uint16&) -> void;
|
|
auto instructionLD_irr_a(uint16&) -> void;
|
|
auto instructionLD_irr_n(uint16&) -> void;
|
|
auto instructionLD_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionLD_r_n(uint8&) -> void;
|
|
auto instructionLD_r_irr(uint8&, uint16&) -> void;
|
|
auto instructionLD_r_r(uint8&, uint8&) -> void;
|
|
auto instructionLD_r_r1(uint8&, uint8&) -> void;
|
|
auto instructionLD_rr_inn(uint16&) -> void;
|
|
auto instructionLD_rr_nn(uint16&) -> void;
|
|
auto instructionLD_sp_rr(uint16&) -> void;
|
|
auto instructionLDD() -> void;
|
|
auto instructionLDDR() -> void;
|
|
auto instructionLDI() -> void;
|
|
auto instructionLDIR() -> void;
|
|
auto instructionNEG() -> void;
|
|
auto instructionNOP() -> void;
|
|
auto instructionOR_a_irr(uint16&) -> void;
|
|
auto instructionOR_a_n() -> void;
|
|
auto instructionOR_a_r(uint8&) -> void;
|
|
auto instructionOTDR() -> void;
|
|
auto instructionOTIR() -> void;
|
|
auto instructionOUT_ic_r(uint8&) -> void;
|
|
auto instructionOUT_n_a() -> void;
|
|
auto instructionOUTD() -> void;
|
|
auto instructionOUTI() -> void;
|
|
auto instructionPOP_rr(uint16&) -> void;
|
|
auto instructionPUSH_rr(uint16&) -> void;
|
|
auto instructionRES_o_irr(uint3, uint16&) -> void;
|
|
auto instructionRES_o_irr_r(uint3, uint16&, uint8&) -> void;
|
|
auto instructionRES_o_r(uint3, uint8&) -> void;
|
|
auto instructionRET() -> void;
|
|
auto instructionRET_c(bool c) -> void;
|
|
auto instructionRETI() -> void;
|
|
auto instructionRETN() -> void;
|
|
auto instructionRL_irr(uint16&) -> void;
|
|
auto instructionRL_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionRL_r(uint8&) -> void;
|
|
auto instructionRLA() -> void;
|
|
auto instructionRLC_irr(uint16&) -> void;
|
|
auto instructionRLC_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionRLC_r(uint8&) -> void;
|
|
auto instructionRLCA() -> void;
|
|
auto instructionRLD() -> void;
|
|
auto instructionRR_irr(uint16&) -> void;
|
|
auto instructionRR_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionRR_r(uint8&) -> void;
|
|
auto instructionRRA() -> void;
|
|
auto instructionRRC_irr(uint16&) -> void;
|
|
auto instructionRRC_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionRRC_r(uint8&) -> void;
|
|
auto instructionRRCA() -> void;
|
|
auto instructionRRD() -> void;
|
|
auto instructionRST_o(uint3) -> void;
|
|
auto instructionSBC_a_irr(uint16&) -> void;
|
|
auto instructionSBC_a_n() -> void;
|
|
auto instructionSBC_a_r(uint8&) -> void;
|
|
auto instructionSBC_hl_rr(uint16&) -> void;
|
|
auto instructionSCF() -> void;
|
|
auto instructionSET_o_irr(uint3, uint16&) -> void;
|
|
auto instructionSET_o_irr_r(uint3, uint16&, uint8&) -> void;
|
|
auto instructionSET_o_r(uint3, uint8&) -> void;
|
|
auto instructionSLA_irr(uint16&) -> void;
|
|
auto instructionSLA_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionSLA_r(uint8&) -> void;
|
|
auto instructionSLL_irr(uint16&) -> void;
|
|
auto instructionSLL_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionSLL_r(uint8&) -> void;
|
|
auto instructionSRA_irr(uint16&) -> void;
|
|
auto instructionSRA_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionSRA_r(uint8&) -> void;
|
|
auto instructionSRL_irr(uint16&) -> void;
|
|
auto instructionSRL_irr_r(uint16&, uint8&) -> void;
|
|
auto instructionSRL_r(uint8&) -> void;
|
|
auto instructionSUB_a_irr(uint16&) -> void;
|
|
auto instructionSUB_a_n() -> void;
|
|
auto instructionSUB_a_r(uint8&) -> void;
|
|
auto instructionXOR_a_irr(uint16&) -> void;
|
|
auto instructionXOR_a_n() -> void;
|
|
auto instructionXOR_a_r(uint8&) -> void;
|
|
|
|
//serialization.cpp
|
|
auto serialize(serializer&) -> void;
|
|
|
|
//disassembler.cpp
|
|
auto disassemble(uint16 pc) -> string;
|
|
auto disassemble(uint16 pc, uint8 prefix, uint8 code) -> string;
|
|
auto disassembleCB(uint16 pc, uint8 prefix, uint8 code) -> string;
|
|
auto disassembleCBd(uint16 pc, uint8 prefix, int8 d, uint8 code) -> string;
|
|
auto disassembleED(uint16 pc, uint8 prefix, uint8 code) -> string;
|
|
|
|
struct Registers {
|
|
union Pair {
|
|
Pair() : word(0) {}
|
|
uint16 word;
|
|
struct Byte { uint8 order_msb2(hi, lo); } byte;
|
|
};
|
|
|
|
Pair af, af_;
|
|
Pair bc, bc_;
|
|
Pair de, de_;
|
|
Pair hl, hl_;
|
|
Pair ix;
|
|
Pair iy;
|
|
Pair ir;
|
|
uint16 sp;
|
|
uint16 pc;
|
|
|
|
bool ei; //EI instruction executed
|
|
bool halt; //HALT instruction executed
|
|
bool iff1; //interrupt flip-flop 1
|
|
bool iff2; //interrupt flip-flop 2
|
|
uint2 im; //interrupt mode (0-2)
|
|
|
|
Pair* hlp = nullptr;
|
|
} r;
|
|
|
|
Bus* bus = nullptr;
|
|
};
|
|
|
|
}
|