namespace BizHawk.Emulation.Consoles.TurboGrafx { public partial class PCEngine { // The SuperGrafx has 32K of RAM and a different port configuration to allow // I/O access to VDC1, VDC2, and the VPC. private byte ReadMemorySGX(int addr) { if (addr < 0xFFFFF) // read ROM return RomData[addr % RomLength]; if (addr >= 0x1F0000 && addr < 0x1F8000) // read RAM return Ram[addr & 0x7FFF]; if (addr >= 0x1FE000) // hardware page. { if (addr < 0x1FE400) { addr &= 0x1F; if (addr <= 0x07) return VDC1.ReadVDC(addr); if (addr <= 0x0F) return VPC.ReadVPC(addr); if (addr <= 0x17) return VDC2.ReadVDC(addr); return 0xFF; } if (addr < 0x1FE800) { Cpu.PendingCycles--; return VCE.ReadVCE(addr); } if (addr < 0x1FEC00) return IOBuffer; if (addr < 0x1FF000) { IOBuffer = (byte)(Cpu.TimerValue | (IOBuffer & 0x80)); return IOBuffer; } if (addr >= 0x1FF000 && addr < 0x1FF400) { IOBuffer = ReadInput(); return IOBuffer; } if ((addr & ~1) == 0x1FF400) return IOBuffer; if (addr == 0x1FF402) { IOBuffer = (byte)(Cpu.IRQControlByte | (IOBuffer & 0xF8)); return IOBuffer; } if (addr == 0x1FF403) { IOBuffer = (byte)(Cpu.ReadIrqStatus() | (IOBuffer & 0xF8)); return IOBuffer; } } Log.Error("MEM", "UNHANDLED READ: {0:X6}", addr); return 0xFF; } private void WriteMemorySGX(int addr, byte value) { if (addr >= 0x1F0000 && addr < 0x1F8000) // write RAM. Ram[addr & 0x7FFF] = value; else if (addr >= 0x1FE000) // hardware page. { if (addr < 0x1FE400) { addr &= 0x1F; if (addr <= 0x07) VDC1.WriteVDC(addr, value); else if (addr <= 0x0F) VPC.WriteVPC(addr, value); else if (addr <= 0x17) VDC2.WriteVDC(addr, value); } else if (addr < 0x1FE800) { Cpu.PendingCycles--; VCE.WriteVCE(addr, value); } else if (addr < 0x1FEC00) { IOBuffer = value; PSG.WritePSG((byte)addr, value, Cpu.TotalExecutedCycles); } else if (addr == 0x1FEC00) { IOBuffer = value; Cpu.WriteTimer(value); } else if (addr == 0x1FEC01) { IOBuffer = value; Cpu.WriteTimerEnable(value); } else if (addr >= 0x1FF000 && addr < 0x1FF400) { IOBuffer = value; WriteInput(value); } else if (addr == 0x1FF402) { IOBuffer = value; Cpu.WriteIrqControl(value); } else if (addr == 0x1FF403) { IOBuffer = value; Cpu.WriteIrqStatus(); } else Log.Error("MEM", "unhandled hardware write [{0:X6}] : {1:X2}", addr, value); } else Log.Error("MEM","UNHANDLED WRITE: {0:X6}:{1:X2}",addr,value); } } }