2013-04-14 20:39:19 +00:00
|
|
|
|
namespace BizHawk.Emulation.Consoles.Atari._2600
|
2012-03-31 20:32:40 +00:00
|
|
|
|
{
|
2012-04-29 21:01:06 +00:00
|
|
|
|
/*
|
|
|
|
|
F6 (Atari style 16K)
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
This is a fairly standard 16K bankswitching method. It works like F8, except there's
|
|
|
|
|
four 4K banks of ROM, selected by accessing 1FF6 through 1FF9. These sequentially
|
|
|
|
|
select one of the 4 banks. i.e. 1FF6 selects bank 0, 1FF7 selects bank 1, etc.
|
|
|
|
|
*/
|
|
|
|
|
|
2012-03-31 20:32:40 +00:00
|
|
|
|
class mF6 : MapperBase
|
|
|
|
|
{
|
2013-04-16 00:42:57 +00:00
|
|
|
|
int toggle;
|
2012-03-31 20:32:40 +00:00
|
|
|
|
|
2013-03-11 01:46:12 +00:00
|
|
|
|
private byte ReadMem(ushort addr, bool peek)
|
2012-03-31 20:32:40 +00:00
|
|
|
|
{
|
2013-03-11 01:46:12 +00:00
|
|
|
|
if (!peek)
|
|
|
|
|
{
|
|
|
|
|
Address(addr);
|
|
|
|
|
}
|
|
|
|
|
|
2012-03-31 20:32:40 +00:00
|
|
|
|
if (addr < 0x1000) return base.ReadMemory(addr);
|
2013-03-11 01:46:12 +00:00
|
|
|
|
return core.rom[(toggle << 12) + (addr & 0xFFF)];
|
2012-03-31 20:32:40 +00:00
|
|
|
|
}
|
2013-03-11 01:46:12 +00:00
|
|
|
|
|
|
|
|
|
public override byte ReadMemory(ushort addr)
|
|
|
|
|
{
|
|
|
|
|
return ReadMem(addr, false);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override byte PeekMemory(ushort addr)
|
|
|
|
|
{
|
|
|
|
|
return ReadMem(addr, true);
|
|
|
|
|
}
|
|
|
|
|
|
2012-03-31 20:32:40 +00:00
|
|
|
|
public override void WriteMemory(ushort addr, byte value)
|
|
|
|
|
{
|
|
|
|
|
Address(addr);
|
|
|
|
|
if (addr < 0x1000) base.WriteMemory(addr, value);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void SyncState(Serializer ser)
|
|
|
|
|
{
|
|
|
|
|
base.SyncState(ser);
|
|
|
|
|
ser.Sync("toggle", ref toggle);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void Address(ushort addr)
|
|
|
|
|
{
|
|
|
|
|
if (addr == 0x1FF6) toggle = 0;
|
|
|
|
|
if (addr == 0x1FF7) toggle = 1;
|
|
|
|
|
if (addr == 0x1FF8) toggle = 2;
|
|
|
|
|
if (addr == 0x1FF9) toggle = 3;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|