2024-08-05 00:44:30 +08:00
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
|
// Mapper046 Rumble Station //
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
|
|
|
using static VirtualNes.MMU;
|
2024-08-16 10:20:00 +08:00
|
|
|
|
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
|
|
|
|
namespace VirtualNes.Core
|
|
|
|
|
{
|
2024-08-16 10:20:00 +08:00
|
|
|
|
public class Mapper046 : Mapper
|
|
|
|
|
{
|
|
|
|
|
int[] reg = new int[4];
|
|
|
|
|
public Mapper046(NES parent) : base(parent)
|
|
|
|
|
{
|
|
|
|
|
}
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
public override void Reset()
|
|
|
|
|
{
|
|
|
|
|
reg[0] = 0;
|
|
|
|
|
reg[1] = 0;
|
|
|
|
|
reg[2] = 0;
|
|
|
|
|
reg[3] = 0;
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
SetBank();
|
|
|
|
|
SetVRAM_Mirror(VRAM_VMIRROR);
|
|
|
|
|
}
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
//void Mapper046::WriteLow(WORD addr, BYTE data)
|
|
|
|
|
public override void WriteLow(ushort addr, byte data)
|
|
|
|
|
{
|
|
|
|
|
reg[0] = data & 0x0F;
|
|
|
|
|
reg[1] = (data & 0xF0) >> 4;
|
|
|
|
|
SetBank();
|
|
|
|
|
}
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
//void Mapper046::Write(WORD addr, BYTE data)
|
|
|
|
|
public override void Write(ushort addr, byte data)
|
|
|
|
|
{
|
|
|
|
|
reg[2] = data & 0x01;
|
|
|
|
|
reg[3] = (data & 0x70) >> 4;
|
|
|
|
|
SetBank();
|
|
|
|
|
}
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
void SetBank()
|
|
|
|
|
{
|
|
|
|
|
SetPROM_8K_Bank(4, reg[0] * 8 + reg[2] * 4 + 0);
|
|
|
|
|
SetPROM_8K_Bank(5, reg[0] * 8 + reg[2] * 4 + 1);
|
|
|
|
|
SetPROM_8K_Bank(6, reg[0] * 8 + reg[2] * 4 + 2);
|
|
|
|
|
SetPROM_8K_Bank(7, reg[0] * 8 + reg[2] * 4 + 3);
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
SetVROM_1K_Bank(0, reg[1] * 64 + reg[3] * 8 + 0);
|
|
|
|
|
SetVROM_1K_Bank(1, reg[1] * 64 + reg[3] * 8 + 1);
|
|
|
|
|
SetVROM_1K_Bank(2, reg[1] * 64 + reg[3] * 8 + 2);
|
|
|
|
|
SetVROM_1K_Bank(3, reg[1] * 64 + reg[3] * 8 + 3);
|
|
|
|
|
SetVROM_1K_Bank(4, reg[1] * 64 + reg[3] * 8 + 4);
|
|
|
|
|
SetVROM_1K_Bank(5, reg[1] * 64 + reg[3] * 8 + 5);
|
|
|
|
|
SetVROM_1K_Bank(6, reg[1] * 64 + reg[3] * 8 + 6);
|
|
|
|
|
SetVROM_1K_Bank(7, reg[1] * 64 + reg[3] * 8 + 7);
|
|
|
|
|
}
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
//void Mapper046::SaveState(LPBYTE p)
|
|
|
|
|
public override void SaveState(byte[] p)
|
|
|
|
|
{
|
|
|
|
|
p[0] = (byte)reg[0];
|
|
|
|
|
p[1] = (byte)reg[1];
|
|
|
|
|
p[2] = (byte)reg[2];
|
|
|
|
|
p[3] = (byte)reg[3];
|
|
|
|
|
}
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
//void Mapper046::LoadState(LPBYTE p)
|
|
|
|
|
public override void LoadState(byte[] p)
|
|
|
|
|
{
|
|
|
|
|
reg[0] = p[0];
|
|
|
|
|
reg[1] = p[1];
|
|
|
|
|
reg[2] = p[2];
|
|
|
|
|
reg[3] = p[3];
|
|
|
|
|
}
|
2024-08-05 00:44:30 +08:00
|
|
|
|
|
|
|
|
|
|
2024-08-16 10:20:00 +08:00
|
|
|
|
public override bool IsStateSave()
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-08-05 00:44:30 +08:00
|
|
|
|
}
|