2011-11-04 11:57:54 +00:00
|
|
|
struct KonamiVRC3 : Board {
|
|
|
|
|
|
|
|
struct Settings {
|
|
|
|
bool mirror; //0 = horizontal, 1 = vertical
|
|
|
|
} settings;
|
|
|
|
|
|
|
|
VRC3 vrc3;
|
|
|
|
|
|
|
|
void main() {
|
|
|
|
vrc3.main();
|
|
|
|
}
|
|
|
|
|
|
|
|
uint8 prg_read(unsigned addr) {
|
|
|
|
if((addr & 0xe000) == 0x6000) return prgram.read(addr & 0x1fff);
|
|
|
|
if(addr & 0x8000) return prgrom.read(vrc3.prg_addr(addr));
|
|
|
|
return cpu.mdr();
|
|
|
|
}
|
|
|
|
|
|
|
|
void prg_write(unsigned addr, uint8 data) {
|
|
|
|
if((addr & 0xe000) == 0x6000) return prgram.write(addr & 0x1fff, data);
|
|
|
|
if(addr & 0x8000) return vrc3.reg_write(addr, data);
|
|
|
|
}
|
|
|
|
|
|
|
|
uint8 chr_read(unsigned addr) {
|
|
|
|
if(addr & 0x2000) {
|
|
|
|
if(settings.mirror == 0) addr = ((addr & 0x0800) >> 1) | (addr & 0x03ff);
|
|
|
|
return ppu.ciram_read(addr & 0x07ff);
|
|
|
|
}
|
|
|
|
return chrram.read(addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void chr_write(unsigned addr, uint8 data) {
|
|
|
|
if(addr & 0x2000) {
|
|
|
|
if(settings.mirror == 0) addr = ((addr & 0x0800) >> 1) | (addr & 0x03ff);
|
|
|
|
return ppu.ciram_write(addr & 0x07ff, data);
|
|
|
|
}
|
|
|
|
return chrram.write(addr, data);
|
|
|
|
}
|
|
|
|
|
|
|
|
void power() {
|
|
|
|
vrc3.power();
|
|
|
|
}
|
|
|
|
|
|
|
|
void reset() {
|
|
|
|
vrc3.reset();
|
|
|
|
}
|
|
|
|
|
2013-05-05 09:21:30 +00:00
|
|
|
void serialize(serializer& s) {
|
2011-11-04 11:57:54 +00:00
|
|
|
Board::serialize(s);
|
|
|
|
vrc3.serialize(s);
|
|
|
|
}
|
|
|
|
|
2013-05-05 09:21:30 +00:00
|
|
|
KonamiVRC3(Markup::Node& document) : Board(document), vrc3(*this) {
|
Update to v094r17 release.
byuu says:
This updates higan to use the new Markup::Node changes. This is a really
big change, and one slight typo anywhere could break certain classes of
games from playing.
I don't have ananke hooked up again yet, so I don't have the ability to
test this much. If anyone with some v094 game folders wouldn't mind
testing, I'd help out a great deal.
I'm most concerned about testing one of each SNES special chip game.
Most notably, systems like the SA-1, HitachiDSP and NEC-DSP were using
the fancier lookups, eg node["rom[0]/name"], which I had to convert to
a rather ugly node["rom"].at(0)["name"], which I'm fairly confident
won't work. I'm going to blame that on the fumes from the shelves I just
stained >.> Might work with node.find("rom[0]/name")(0) though ...? But
so ugly ... ugh.
That aside, this WIP adds the accuracy-PPU inlining, so the accuracy
profile should run around 7.5% faster than before.
2015-05-02 13:05:46 +00:00
|
|
|
settings.mirror = document["cartridge/mirror/mode"].text() == "vertical" ? 1 : 0;
|
2011-11-04 11:57:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
};
|