2011-10-02 10:05:45 +00:00
|
|
|
//NES-GNROM
|
|
|
|
//NES-MHROM
|
2011-09-29 12:44:49 +00:00
|
|
|
|
2011-10-02 10:05:45 +00:00
|
|
|
struct NES_GxROM : Board {
|
2015-12-05 05:44:49 +00:00
|
|
|
NES_GxROM(Markup::Node& document) : Board(document) {
|
2016-01-12 11:08:34 +00:00
|
|
|
settings.mirror = document["board/mirror/mode"].text() == "vertical" ? 1 : 0;
|
2015-12-05 05:44:49 +00:00
|
|
|
}
|
2011-09-29 12:44:49 +00:00
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
auto prg_read(uint addr) -> uint8 {
|
|
|
|
if(addr & 0x8000) return prgrom.read((prg_bank << 15) | (addr & 0x7fff));
|
|
|
|
return cpu.mdr();
|
|
|
|
}
|
2011-09-29 12:44:49 +00:00
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
auto prg_write(uint addr, uint8 data) -> void {
|
|
|
|
if(addr & 0x8000) {
|
|
|
|
prg_bank = (data & 0x30) >> 4;
|
|
|
|
chr_bank = (data & 0x03) >> 0;
|
|
|
|
}
|
2011-10-02 10:05:45 +00:00
|
|
|
}
|
2011-09-29 12:44:49 +00:00
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
auto chr_read(uint addr) -> uint8 {
|
|
|
|
if(addr & 0x2000) {
|
|
|
|
if(settings.mirror == 0) addr = ((addr & 0x0800) >> 1) | (addr & 0x03ff);
|
2016-06-26 08:54:12 +00:00
|
|
|
return ppu.readCIRAM(addr & 0x07ff);
|
2015-12-05 05:44:49 +00:00
|
|
|
}
|
|
|
|
addr = (chr_bank * 0x2000) + (addr & 0x1fff);
|
|
|
|
return Board::chr_read(addr);
|
2011-09-29 12:44:49 +00:00
|
|
|
}
|
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
auto chr_write(uint addr, uint8 data) -> void {
|
|
|
|
if(addr & 0x2000) {
|
|
|
|
if(settings.mirror == 0) addr = ((addr & 0x0800) >> 1) | (addr & 0x03ff);
|
2016-06-26 08:54:12 +00:00
|
|
|
return ppu.writeCIRAM(addr & 0x07ff, data);
|
2015-12-05 05:44:49 +00:00
|
|
|
}
|
|
|
|
addr = (chr_bank * 0x2000) + (addr & 0x1fff);
|
|
|
|
Board::chr_write(addr, data);
|
2011-09-29 12:44:49 +00:00
|
|
|
}
|
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
auto power() -> void {
|
|
|
|
}
|
2011-09-29 12:44:49 +00:00
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
auto reset() -> void {
|
|
|
|
prg_bank = 0;
|
|
|
|
chr_bank = 0;
|
|
|
|
}
|
2011-09-29 12:44:49 +00:00
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
auto serialize(serializer& s) -> void {
|
|
|
|
Board::serialize(s);
|
|
|
|
s.integer(prg_bank);
|
|
|
|
s.integer(chr_bank);
|
|
|
|
}
|
2011-09-29 12:44:49 +00:00
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
struct Settings {
|
|
|
|
bool mirror; //0 = horizontal, 1 = vertical
|
|
|
|
} settings;
|
2011-09-29 12:44:49 +00:00
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
uint2 prg_bank;
|
|
|
|
uint2 chr_bank;
|
2011-09-29 12:44:49 +00:00
|
|
|
};
|