2011-11-04 11:57:54 +00:00
|
|
|
struct KonamiVRC2 : Board {
|
2015-12-05 05:44:49 +00:00
|
|
|
KonamiVRC2(Markup::Node& document) : Board(document), vrc2(*this) {
|
2016-01-12 11:08:34 +00:00
|
|
|
settings.pinout.a0 = 1 << document["board/chip/pinout/a0"].natural();
|
|
|
|
settings.pinout.a1 = 1 << document["board/chip/pinout/a1"].natural();
|
2015-12-05 05:44:49 +00:00
|
|
|
}
|
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
auto readPRG(uint addr) -> uint8 {
|
2015-12-05 05:44:49 +00:00
|
|
|
if(addr < 0x6000) return cpu.mdr();
|
2016-06-27 13:07:57 +00:00
|
|
|
if(addr < 0x8000) return vrc2.readRAM(addr);
|
|
|
|
return prgrom.read(vrc2.addrPRG(addr));
|
2015-12-05 05:44:49 +00:00
|
|
|
}
|
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
auto writePRG(uint addr, uint8 data) -> void {
|
2015-12-05 05:44:49 +00:00
|
|
|
if(addr < 0x6000) return;
|
2016-06-27 13:07:57 +00:00
|
|
|
if(addr < 0x8000) return vrc2.writeRAM(addr, data);
|
2015-12-05 05:44:49 +00:00
|
|
|
|
|
|
|
bool a0 = (addr & settings.pinout.a0);
|
|
|
|
bool a1 = (addr & settings.pinout.a1);
|
|
|
|
addr &= 0xfff0;
|
|
|
|
addr |= (a0 << 0) | (a1 << 1);
|
2016-06-27 13:07:57 +00:00
|
|
|
return vrc2.writeIO(addr, data);
|
2015-12-05 05:44:49 +00:00
|
|
|
}
|
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
auto readCHR(uint addr) -> uint8 {
|
|
|
|
if(addr & 0x2000) return ppu.readCIRAM(vrc2.addrCIRAM(addr));
|
|
|
|
return Board::readCHR(vrc2.addrCHR(addr));
|
2015-12-05 05:44:49 +00:00
|
|
|
}
|
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
auto writeCHR(uint addr, uint8 data) -> void {
|
|
|
|
if(addr & 0x2000) return ppu.writeCIRAM(vrc2.addrCIRAM(addr), data);
|
|
|
|
return Board::writeCHR(vrc2.addrCHR(addr), data);
|
2015-12-05 05:44:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
auto power() -> void {
|
|
|
|
vrc2.power();
|
|
|
|
}
|
|
|
|
|
|
|
|
auto serialize(serializer& s) -> void {
|
|
|
|
Board::serialize(s);
|
|
|
|
vrc2.serialize(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Settings {
|
|
|
|
struct Pinout {
|
|
|
|
uint a0;
|
|
|
|
uint a1;
|
|
|
|
} pinout;
|
|
|
|
} settings;
|
|
|
|
|
|
|
|
VRC2 vrc2;
|
2011-11-04 11:57:54 +00:00
|
|
|
};
|