2014-04-05 00:58:43 +00:00
|
|
|
|
using BizHawk.Common;
|
2014-04-04 19:46:41 +00:00
|
|
|
|
|
|
|
|
|
namespace BizHawk.Emulation.Cores.Atari.Atari2600
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
This is an extended version of the CBS RAM Plus bankswitching scheme
|
|
|
|
|
supported by the Harmony cartridge.
|
|
|
|
|
|
|
|
|
|
There are six (or seven) 4K banks and 256 bytes of RAM.
|
|
|
|
|
*/
|
|
|
|
|
internal class mFA2 : MapperBase
|
|
|
|
|
{
|
2014-04-05 00:58:43 +00:00
|
|
|
|
private int _bank4k;
|
2014-04-06 22:40:10 +00:00
|
|
|
|
private ByteBuffer _ram = new ByteBuffer(256);
|
|
|
|
|
|
2014-04-11 01:31:10 +00:00
|
|
|
|
public override bool HasCartRam
|
|
|
|
|
{
|
|
|
|
|
get { return true; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override ByteBuffer CartRam
|
|
|
|
|
{
|
|
|
|
|
get { return _ram; }
|
|
|
|
|
}
|
|
|
|
|
|
2014-04-06 22:40:10 +00:00
|
|
|
|
public override void SyncState(Serializer ser)
|
|
|
|
|
{
|
|
|
|
|
base.SyncState(ser);
|
|
|
|
|
ser.Sync("bank4k", ref _bank4k);
|
|
|
|
|
ser.Sync("auxRam", ref _ram);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void Dispose()
|
|
|
|
|
{
|
|
|
|
|
base.Dispose();
|
|
|
|
|
_ram.Dispose();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void HardReset()
|
|
|
|
|
{
|
|
|
|
|
_bank4k = 0;
|
|
|
|
|
_ram = new ByteBuffer(256);
|
|
|
|
|
base.HardReset();
|
|
|
|
|
}
|
2014-04-05 00:58:43 +00:00
|
|
|
|
|
|
|
|
|
private byte ReadMem(ushort addr, bool peek)
|
|
|
|
|
{
|
|
|
|
|
if (!peek)
|
|
|
|
|
{
|
|
|
|
|
Address(addr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (addr < 0x1000)
|
|
|
|
|
{
|
|
|
|
|
return base.ReadMemory(addr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (addr < 0x1100)
|
|
|
|
|
{
|
|
|
|
|
return 0xFF;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (addr < 0x1200)
|
|
|
|
|
{
|
2014-04-06 22:40:10 +00:00
|
|
|
|
return _ram[addr & 0xFF];
|
2014-04-05 00:58:43 +00:00
|
|
|
|
}
|
|
|
|
|
|
2014-04-05 14:13:05 +00:00
|
|
|
|
return Core.Rom[(_bank4k << 12) + (addr & 0xFFF)];
|
2014-04-05 00:58:43 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override byte ReadMemory(ushort addr)
|
|
|
|
|
{
|
|
|
|
|
return ReadMem(addr, false);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override byte PeekMemory(ushort addr)
|
|
|
|
|
{
|
|
|
|
|
return ReadMem(addr, true);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void WriteMemory(ushort addr, byte value)
|
|
|
|
|
{
|
|
|
|
|
Address(addr);
|
|
|
|
|
if (addr < 0x1000)
|
|
|
|
|
{
|
|
|
|
|
base.WriteMemory(addr, value);
|
|
|
|
|
}
|
|
|
|
|
else if (addr < 0x1100)
|
|
|
|
|
{
|
2014-04-06 22:40:10 +00:00
|
|
|
|
_ram[addr & 0xFF] = value;
|
2014-04-05 00:58:43 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Address(ushort addr)
|
2014-04-04 19:46:41 +00:00
|
|
|
|
{
|
2014-04-05 00:58:43 +00:00
|
|
|
|
if (addr == 0x1FF5) _bank4k = 0;
|
|
|
|
|
if (addr == 0x1FF6) _bank4k = 1;
|
|
|
|
|
if (addr == 0x1FF7) _bank4k = 2;
|
|
|
|
|
if (addr == 0x1FF8) _bank4k = 3;
|
|
|
|
|
if (addr == 0x1FF9) _bank4k = 4;
|
|
|
|
|
if (addr == 0x1FFA) _bank4k = 5;
|
2014-04-05 14:13:05 +00:00
|
|
|
|
if (addr == 0x1FFB && Core.Rom.Length == 28 * 1024) // Only available on 28k Roms
|
2014-04-05 00:58:43 +00:00
|
|
|
|
{
|
|
|
|
|
_bank4k = 6;
|
|
|
|
|
}
|
2014-04-04 19:46:41 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|