bsnes/higan/ws/cartridge/memory.cpp

69 lines
1.3 KiB
C++

//20000-fffff
auto Cartridge::romRead(uint addr) -> uint8 {
switch((uint4)(addr >> 16)) {
case 2: addr = r.bank_rom0 << 16 | (uint16)addr; break; //20000-2ffff
case 3: addr = r.bank_rom1 << 16 | (uint16)addr; break; //30000-3ffff
default: addr = r.bank_rom2 << 20 | (uint20)addr; break; //40000-fffff
}
if(!rom.data) return 0x00;
return rom.data[addr & rom.mask];
}
auto Cartridge::romWrite(uint addr, uint8 data) -> void {
}
//10000-1ffff
auto Cartridge::ramRead(uint addr) -> uint8 {
addr = r.bank_sram << 16 | (uint16)addr;
if(!ram.data) return 0x00;
return ram.data[addr & ram.mask];
}
auto Cartridge::ramWrite(uint addr, uint8 data) -> void {
addr = r.bank_sram << 16 | (uint16)addr;
if(!ram.data) return;
ram.data[addr & ram.mask] = data;
}
auto Cartridge::portRead(uint16 addr) -> uint8 {
if(addr == 0x00c0) {
return r.bank_rom2;
}
if(addr == 0x00c1) {
return r.bank_sram;
}
if(addr == 0x00c2) {
return r.bank_rom0;
}
if(addr == 0x00c3) {
return r.bank_rom1;
}
return 0x00;
}
auto Cartridge::portWrite(uint16 addr, uint8 data) -> void {
if(addr == 0x00c0) {
r.bank_rom2 = data;
return;
}
if(addr == 0x00c1) {
r.bank_sram = data;
return;
}
if(addr == 0x00c2) {
r.bank_rom0 = data;
return;
}
if(addr == 0x00c3) {
r.bank_rom1 = data;
return;
}
}