////////////////////////////////////////////////////////////////////////// // Mapper080 Taito X1-005 // ////////////////////////////////////////////////////////////////////////// using static VirtualNes.MMU; namespace VirtualNes.Core { public class Mapper080 : Mapper { public Mapper080(NES parent) : base(parent) { } public override void Reset() { SetPROM_32K_Bank(0, 1, PROM_8K_SIZE - 2, PROM_8K_SIZE - 1); if (VROM_8K_SIZE != 0) { SetVROM_8K_Bank(0); } } //void Mapper080::WriteLow(WORD addr, BYTE data) public override void WriteLow(ushort addr, byte data) { switch (addr) { case 0x7EF0: SetVROM_2K_Bank(0, (data >> 1) & 0x3F); if (PROM_8K_SIZE == 32) { if ((data & 0x80) != 0) { SetVRAM_1K_Bank(8, 1); SetVRAM_1K_Bank(9, 1); } else { SetVRAM_1K_Bank(8, 0); SetVRAM_1K_Bank(9, 0); } } break; case 0x7EF1: SetVROM_2K_Bank(2, (data >> 1) & 0x3F); if (PROM_8K_SIZE == 32) { if ((data & 0x80) != 0) { SetVRAM_1K_Bank(10, 1); SetVRAM_1K_Bank(11, 1); } else { SetVRAM_1K_Bank(10, 0); SetVRAM_1K_Bank(11, 0); } } break; case 0x7EF2: SetVROM_1K_Bank(4, data); break; case 0x7EF3: SetVROM_1K_Bank(5, data); break; case 0x7EF4: SetVROM_1K_Bank(6, data); break; case 0x7EF5: SetVROM_1K_Bank(7, data); break; case 0x7EF6: if ((data & 0x01) != 0) SetVRAM_Mirror(VRAM_VMIRROR); else SetVRAM_Mirror(VRAM_HMIRROR); break; case 0x7EFA: case 0x7EFB: SetPROM_8K_Bank(4, data); break; case 0x7EFC: case 0x7EFD: SetPROM_8K_Bank(5, data); break; case 0x7EFE: case 0x7EFF: SetPROM_8K_Bank(6, data); break; default: base.WriteLow(addr, data); break; } } } }