mirror of https://github.com/bsnes-emu/bsnes.git
282 lines
5.4 KiB
C++
282 lines
5.4 KiB
C++
//Super Accelerator 1
|
|
|
|
struct SA1 : Processor::WDC65816, Thread {
|
|
//sa1.cpp
|
|
static auto Enter() -> void;
|
|
auto main() -> void;
|
|
auto step(uint clocks) -> void;
|
|
auto interrupt() -> void override;
|
|
|
|
alwaysinline auto triggerIRQ() -> void;
|
|
alwaysinline auto lastCycle() -> void override;
|
|
alwaysinline auto interruptPending() const -> bool override;
|
|
auto synchronizing() const -> bool override;
|
|
|
|
auto unload() -> void;
|
|
auto power() -> void;
|
|
|
|
//dma.cpp
|
|
struct DMA {
|
|
enum CDEN : uint { DmaNormal = 0, DmaCharConversion = 1 };
|
|
enum SD : uint { SourceROM = 0, SourceBWRAM = 1, SourceIRAM = 2 };
|
|
enum DD : uint { DestIRAM = 0, DestBWRAM = 1 };
|
|
uint line;
|
|
};
|
|
|
|
auto dmaNormal() -> void;
|
|
auto dmaCC1() -> void;
|
|
auto dmaCC1Read(uint addr) -> uint8;
|
|
auto dmaCC2() -> void;
|
|
|
|
//memory.cpp
|
|
alwaysinline auto conflictROM() const -> bool;
|
|
alwaysinline auto conflictBWRAM() const -> bool;
|
|
alwaysinline auto conflictIRAM() const -> bool;
|
|
|
|
alwaysinline auto idle() -> void override;
|
|
alwaysinline auto idleJump() -> void override;
|
|
alwaysinline auto idleBranch() -> void override;
|
|
alwaysinline auto read(uint24 addr) -> uint8 override;
|
|
alwaysinline auto write(uint24 addr, uint8 data) -> void override;
|
|
auto readVBR(uint24 addr, uint8 data = 0) -> uint8;
|
|
|
|
//io.cpp
|
|
auto readIO(uint24 addr, uint8 data) -> uint8;
|
|
auto writeIO(uint24 addr, uint8 data) -> void;
|
|
|
|
//serialization.cpp
|
|
auto serialize(serializer&) -> void;
|
|
|
|
struct ROM : ReadableMemory {
|
|
//rom.cpp
|
|
alwaysinline auto conflict() const -> bool;
|
|
|
|
alwaysinline auto read(uint24 address, uint8 data = 0) -> uint8 override;
|
|
alwaysinline auto write(uint24 address, uint8 data) -> void override;
|
|
|
|
auto readCPU(uint24 address, uint8 data = 0) -> uint8;
|
|
auto writeCPU(uint24 address, uint8 data) -> void;
|
|
|
|
auto readSA1(uint24 address, uint8 data = 0) -> uint8;
|
|
auto writeSA1(uint24 address, uint8 data) -> void;
|
|
} rom;
|
|
|
|
struct BWRAM : WritableMemory {
|
|
//bwram.cpp
|
|
alwaysinline auto conflict() const -> bool;
|
|
|
|
alwaysinline auto read(uint24 address, uint8 data = 0) -> uint8 override;
|
|
alwaysinline auto write(uint24 address, uint8 data) -> void override;
|
|
|
|
auto readCPU(uint24 address, uint8 data = 0) -> uint8;
|
|
auto writeCPU(uint24 address, uint8 data) -> void;
|
|
|
|
auto readSA1(uint24 address, uint8 data = 0) -> uint8;
|
|
auto writeSA1(uint24 address, uint8 data) -> void;
|
|
|
|
auto readLinear(uint24 address, uint8 data = 0) -> uint8;
|
|
auto writeLinear(uint24 address, uint8 data) -> void;
|
|
|
|
auto readBitmap(uint20 address, uint8 data = 0) -> uint8;
|
|
auto writeBitmap(uint20 address, uint8 data) -> void;
|
|
|
|
bool dma;
|
|
} bwram;
|
|
|
|
struct IRAM : WritableMemory {
|
|
//iram.cpp
|
|
alwaysinline auto conflict() const -> bool;
|
|
|
|
alwaysinline auto read(uint24 address, uint8 data = 0) -> uint8 override;
|
|
alwaysinline auto write(uint24 address, uint8 data) -> void override;
|
|
|
|
auto readCPU(uint24 address, uint8 data) -> uint8;
|
|
auto writeCPU(uint24 address, uint8 data) -> void;
|
|
|
|
auto readSA1(uint24 address, uint8 data = 0) -> uint8;
|
|
auto writeSA1(uint24 address, uint8 data) -> void;
|
|
} iram;
|
|
|
|
private:
|
|
DMA dma;
|
|
|
|
struct Status {
|
|
uint8 counter;
|
|
|
|
bool interruptPending;
|
|
|
|
uint16 scanlines;
|
|
uint16 vcounter;
|
|
uint16 hcounter;
|
|
} status;
|
|
|
|
struct MMIO {
|
|
//$2200 CCNT
|
|
bool sa1_irq;
|
|
bool sa1_rdyb;
|
|
bool sa1_resb;
|
|
bool sa1_nmi;
|
|
uint8 smeg;
|
|
|
|
//$2201 SIE
|
|
bool cpu_irqen;
|
|
bool chdma_irqen;
|
|
|
|
//$2202 SIC
|
|
bool cpu_irqcl;
|
|
bool chdma_irqcl;
|
|
|
|
//$2203,$2204 CRV
|
|
uint16 crv;
|
|
|
|
//$2205,$2206 CNV
|
|
uint16 cnv;
|
|
|
|
//$2207,$2208 CIV
|
|
uint16 civ;
|
|
|
|
//$2209 SCNT
|
|
bool cpu_irq;
|
|
bool cpu_ivsw;
|
|
bool cpu_nvsw;
|
|
uint8 cmeg;
|
|
|
|
//$220a CIE
|
|
bool sa1_irqen;
|
|
bool timer_irqen;
|
|
bool dma_irqen;
|
|
bool sa1_nmien;
|
|
|
|
//$220b CIC
|
|
bool sa1_irqcl;
|
|
bool timer_irqcl;
|
|
bool dma_irqcl;
|
|
bool sa1_nmicl;
|
|
|
|
//$220c,$220d SNV
|
|
uint16 snv;
|
|
|
|
//$220e,$220f SIV
|
|
uint16 siv;
|
|
|
|
//$2210 TMC
|
|
bool hvselb;
|
|
bool ven;
|
|
bool hen;
|
|
|
|
//$2212,$2213
|
|
uint16 hcnt;
|
|
|
|
//$2214,$2215
|
|
uint16 vcnt;
|
|
|
|
//$2220 CXB
|
|
bool cbmode;
|
|
uint cb;
|
|
|
|
//$2221 DXB
|
|
bool dbmode;
|
|
uint db;
|
|
|
|
//$2222 EXB
|
|
bool ebmode;
|
|
uint eb;
|
|
|
|
//$2223 FXB
|
|
bool fbmode;
|
|
uint fb;
|
|
|
|
//$2224 BMAPS
|
|
uint8 sbm;
|
|
|
|
//$2225 BMAP
|
|
bool sw46;
|
|
uint8 cbm;
|
|
|
|
//$2226 SBWE
|
|
bool swen;
|
|
|
|
//$2227 CBWE
|
|
bool cwen;
|
|
|
|
//$2228 BWPA
|
|
uint8 bwp;
|
|
|
|
//$2229 SIWP
|
|
uint8 siwp;
|
|
|
|
//$222a CIWP
|
|
uint8 ciwp;
|
|
|
|
//$2230 DCNT
|
|
bool dmaen;
|
|
bool dprio;
|
|
bool cden;
|
|
bool cdsel;
|
|
bool dd;
|
|
uint8 sd;
|
|
|
|
//$2231 CDMA
|
|
bool chdend;
|
|
uint8 dmasize;
|
|
uint8 dmacb;
|
|
|
|
//$2232-$2234 SDA
|
|
uint32 dsa;
|
|
|
|
//$2235-$2237 DDA
|
|
uint32 dda;
|
|
|
|
//$2238,$2239 DTC
|
|
uint16 dtc;
|
|
|
|
//$223f BBF
|
|
bool bbf;
|
|
|
|
//$2240-224f BRF
|
|
uint8 brf[16];
|
|
|
|
//$2250 MCNT
|
|
bool acm;
|
|
bool md;
|
|
|
|
//$2251,$2252 MA
|
|
uint16 ma;
|
|
|
|
//$2253,$2254 MB
|
|
uint16 mb;
|
|
|
|
//$2258 VBD
|
|
bool hl;
|
|
uint8 vb;
|
|
|
|
//$2259-$225b VDA
|
|
uint32 va;
|
|
uint8 vbit;
|
|
|
|
//$2300 SFR
|
|
bool cpu_irqfl;
|
|
bool chdma_irqfl;
|
|
|
|
//$2301 CFR
|
|
bool sa1_irqfl;
|
|
bool timer_irqfl;
|
|
bool dma_irqfl;
|
|
bool sa1_nmifl;
|
|
|
|
//$2302,$2303 HCR
|
|
uint16 hcr;
|
|
|
|
//$2304,$2305 VCR
|
|
uint16 vcr;
|
|
|
|
//$2306-230a MR
|
|
uint64 mr;
|
|
|
|
//$230b OF
|
|
bool overflow;
|
|
} mmio;
|
|
};
|
|
|
|
extern SA1 sa1;
|