use crate::memory::mapper::*;
const PRG_LAYOUT: PrgLayout = PrgLayout::new(&[
PrgWindow::new(0x6000, 0x7FFF, 8 * KIBIBYTE, Bank::EMPTY),
PrgWindow::new(0x8000, 0xBFFF, 16 * KIBIBYTE, Bank::switchable_rom(P0)),
PrgWindow::new(0xC000, 0xFFFF, 16 * KIBIBYTE, Bank::fixed_rom(BankIndex::LAST)),
]);
const CHR_LAYOUT: ChrLayout = ChrLayout::new(&[
ChrWindow::new(0x0000, 0x1FFF, 8 * KIBIBYTE, Bank::fixed_rom(BankIndex::FIRST)),
]);
const MIRRORINGS: [NameTableMirroring; 2] = [
NameTableMirroring::OneScreenLeftBank,
NameTableMirroring::OneScreenRightBank,
];
pub struct Mapper071;
impl Mapper for Mapper071 {
fn initial_layout(&self) -> InitialLayout {
InitialLayout::builder()
.prg_max_bank_count(16)
.prg_bank_size(16 * KIBIBYTE)
.prg_windows(PRG_LAYOUT)
.chr_max_bank_count(1)
.chr_bank_size(8 * KIBIBYTE)
.chr_windows(CHR_LAYOUT)
.name_table_mirroring_source(NameTableMirroringSource::Cartridge)
.build()
}
fn write_to_cartridge_space(&mut self, params: &mut MapperParams, address: CpuAddress, value: u8) {
let fields = splitbits!(value, "...mpppp");
match address.to_raw() {
0x0000..=0x401F => unreachable!(),
0x4020..=0x8FFF => { }
0x9000..=0x9FFF => params.set_name_table_mirroring(MIRRORINGS[fields.m as usize]),
0xA000..=0xBFFF => { }
0xC000..=0xFFFF => params.set_bank_register(P0, fields.p),
}
}
}