2017-07-26 12:42:06 +00:00
|
|
|
auto Cartridge::MBC2::read(uint16 address) -> uint8 {
|
|
|
|
if((address & 0xc000) == 0x0000) { //$0000-3fff
|
|
|
|
return cartridge.rom.read(address.bits(0,13));
|
2011-01-03 04:28:36 +00:00
|
|
|
}
|
|
|
|
|
2017-07-26 12:42:06 +00:00
|
|
|
if((address & 0xc000) == 0x4000) { //$4000-7fff
|
|
|
|
return cartridge.rom.read(io.rom.bank << 14 | address.bits(0,13));
|
2011-01-03 04:28:36 +00:00
|
|
|
}
|
|
|
|
|
2017-07-26 12:42:06 +00:00
|
|
|
if((address & 0xee01) == 0xa000) { //$a000-a1ff (even)
|
|
|
|
if(!io.ram.enable) return 0xff;
|
|
|
|
auto ram = cartridge.ram.read(address.bits(1,8));
|
|
|
|
return 0xf0 | ram.bits(0,3);
|
|
|
|
}
|
|
|
|
|
|
|
|
if((address & 0xee01) == 0xa001) { //$a000-a1ff (odd)
|
|
|
|
if(!io.ram.enable) return 0xff;
|
|
|
|
auto ram = cartridge.ram.read(address.bits(1,8));
|
|
|
|
return 0xf0 | ram.bits(4,7);
|
2011-01-03 04:28:36 +00:00
|
|
|
}
|
|
|
|
|
2016-01-08 09:23:46 +00:00
|
|
|
return 0xff;
|
2011-01-03 04:28:36 +00:00
|
|
|
}
|
|
|
|
|
2017-07-26 12:42:06 +00:00
|
|
|
auto Cartridge::MBC2::write(uint16 address, uint8 data) -> void {
|
|
|
|
if((address & 0xe000) == 0x0000) { //$0000-1fff
|
|
|
|
if(!address.bit(8)) io.ram.enable = data.bits(0,3) == 0x0a;
|
2011-01-04 10:42:27 +00:00
|
|
|
return;
|
2011-01-03 04:28:36 +00:00
|
|
|
}
|
|
|
|
|
2017-07-26 12:42:06 +00:00
|
|
|
if((address & 0xe000) == 0x2000) { //$2000-3fff
|
|
|
|
if(address.bit(8)) io.rom.bank = data.bits(0,3);
|
|
|
|
if(!io.rom.bank) io.rom.bank = 0x01;
|
2011-01-04 10:42:27 +00:00
|
|
|
return;
|
2011-01-03 04:28:36 +00:00
|
|
|
}
|
|
|
|
|
2017-07-26 12:42:06 +00:00
|
|
|
if((address & 0xee01) == 0xa000) { //$a000-a1ff (even)
|
|
|
|
if(!io.ram.enable) return;
|
|
|
|
auto ram = cartridge.ram.read(address.bits(1,8));
|
|
|
|
ram.bits(0,3) = data.bits(0,3);
|
|
|
|
cartridge.ram.write(address.bits(1,8), ram);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if((address & 0xee01) == 0xa001) { //$a000-a1ff (odd)
|
|
|
|
if(!io.ram.enable) return;
|
|
|
|
auto ram = cartridge.ram.read(address.bits(1,8));
|
|
|
|
ram.bits(4,7) = data.bits(0,3);
|
|
|
|
cartridge.ram.write(address.bits(1,8), ram);
|
2011-01-04 10:42:27 +00:00
|
|
|
return;
|
2011-01-03 04:28:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-21 07:36:48 +00:00
|
|
|
auto Cartridge::MBC2::power() -> void {
|
2017-07-26 12:42:06 +00:00
|
|
|
io = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
auto Cartridge::MBC2::serialize(serializer& s) -> void {
|
|
|
|
s.integer(io.rom.bank);
|
|
|
|
s.integer(io.ram.enable);
|
2011-01-03 04:28:36 +00:00
|
|
|
}
|