91 lines
3.3 KiB
C#
91 lines
3.3 KiB
C#
|
//////////////////////////////////////////////////////////////////////////
|
|||
|
// Mapper015 100-in-1 chip //
|
|||
|
//////////////////////////////////////////////////////////////////////////
|
|||
|
using static VirtualNes.MMU;
|
|||
|
|
|||
|
|
|||
|
namespace VirtualNes.Core
|
|||
|
{
|
|||
|
public class Mapper015 : Mapper
|
|||
|
{
|
|||
|
|
|||
|
public Mapper015(NES parent) : base(parent) { }
|
|||
|
|
|||
|
public override void Reset()
|
|||
|
{
|
|||
|
SetPROM_32K_Bank(0, 1, 2, 3);
|
|||
|
}
|
|||
|
|
|||
|
//void Mapper015::Write(WORD addr, BYTE data)
|
|||
|
public override void Write(ushort addr, byte data)
|
|||
|
{
|
|||
|
switch (addr)
|
|||
|
{
|
|||
|
case 0x8000:
|
|||
|
if ((data & 0x80) != 0)
|
|||
|
{
|
|||
|
SetPROM_8K_Bank(4, (data & 0x3F) * 2 + 1);
|
|||
|
SetPROM_8K_Bank(5, (data & 0x3F) * 2 + 0);
|
|||
|
SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 3);
|
|||
|
SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 2);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
SetPROM_8K_Bank(4, (data & 0x3F) * 2 + 0);
|
|||
|
SetPROM_8K_Bank(5, (data & 0x3F) * 2 + 1);
|
|||
|
SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 2);
|
|||
|
SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 3);
|
|||
|
}
|
|||
|
if ((data & 0x40) != 0)
|
|||
|
SetVRAM_Mirror(VRAM_HMIRROR);
|
|||
|
else SetVRAM_Mirror(VRAM_VMIRROR);
|
|||
|
break;
|
|||
|
case 0x8001:
|
|||
|
if ((data & 0x80) != 0)
|
|||
|
{
|
|||
|
SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 1);
|
|||
|
SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 0);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 0);
|
|||
|
SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 1);
|
|||
|
}
|
|||
|
break;
|
|||
|
case 0x8002:
|
|||
|
if ((data & 0x80) != 0)
|
|||
|
{
|
|||
|
SetPROM_8K_Bank(4, (data & 0x3F) * 2 + 1);
|
|||
|
SetPROM_8K_Bank(5, (data & 0x3F) * 2 + 1);
|
|||
|
SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 1);
|
|||
|
SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 1);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
SetPROM_8K_Bank(4, (data & 0x3F) * 2 + 0);
|
|||
|
SetPROM_8K_Bank(5, (data & 0x3F) * 2 + 0);
|
|||
|
SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 0);
|
|||
|
SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 0);
|
|||
|
}
|
|||
|
break;
|
|||
|
case 0x8003:
|
|||
|
if ((data & 0x80) != 0)
|
|||
|
{
|
|||
|
SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 1);
|
|||
|
SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 0);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
SetPROM_8K_Bank(6, (data & 0x3F) * 2 + 0);
|
|||
|
SetPROM_8K_Bank(7, (data & 0x3F) * 2 + 1);
|
|||
|
}
|
|||
|
if ((data & 0x40) != 0) SetVRAM_Mirror(VRAM_HMIRROR);
|
|||
|
else SetVRAM_Mirror(VRAM_VMIRROR);
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
}
|
|||
|
}
|