NEShawk - start mapper 6
This commit is contained in:
parent
ad5de7e0af
commit
0efd72c409
|
@ -484,6 +484,7 @@
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\CoolBoy.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\CoolBoy.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\DatachBarcode.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\DatachBarcode.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\Farid-UNROM-8-in-1.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\Farid-UNROM-8-in-1.cs" />
|
||||||
|
<Compile Include="Consoles\Nintendo\NES\Boards\FFE\Mapper006.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\FS304.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\FS304.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\GameGenie.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\GameGenie.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\inlnsf.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\inlnsf.cs" />
|
||||||
|
|
|
@ -0,0 +1,115 @@
|
||||||
|
using BizHawk.Common;
|
||||||
|
|
||||||
|
namespace BizHawk.Emulation.Cores.Nintendo.NES
|
||||||
|
{
|
||||||
|
public class Mapper006 : NES.NESBoardBase
|
||||||
|
{
|
||||||
|
private int _reg;
|
||||||
|
private int IRQa, mirr;
|
||||||
|
private int IRQCount, IRQLatch;
|
||||||
|
|
||||||
|
private int _prgMask16k;
|
||||||
|
|
||||||
|
public override bool Configure(NES.EDetectionOrigin origin)
|
||||||
|
{
|
||||||
|
switch (Cart.board_type)
|
||||||
|
{
|
||||||
|
case "MAPPER006":
|
||||||
|
Cart.vram_size = 32;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
SetMirrorType(Cart.pad_h, Cart.pad_v);
|
||||||
|
|
||||||
|
_prgMask16k = Cart.prg_size / 16 - 1;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void SyncState(Serializer ser)
|
||||||
|
{
|
||||||
|
base.SyncState(ser);
|
||||||
|
ser.Sync("reg", ref _reg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void WriteEXP(int addr, byte value)
|
||||||
|
{
|
||||||
|
// Mirroring
|
||||||
|
if (addr == 0x2FE || addr == 0x2FF)
|
||||||
|
{
|
||||||
|
int mirr = ((addr << 1) & 2) | ((addr >> 4) & 1);
|
||||||
|
SetMirror(mirr);
|
||||||
|
}
|
||||||
|
// IRQ
|
||||||
|
else if (addr >= 0x500 && addr <= 0x503)
|
||||||
|
{
|
||||||
|
switch (addr)
|
||||||
|
{
|
||||||
|
case 0x501:
|
||||||
|
break;
|
||||||
|
case 0x502:
|
||||||
|
break;
|
||||||
|
case 0x503:
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void WritePRG(int addr, byte value)
|
||||||
|
{
|
||||||
|
_reg = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override byte ReadPRG(int addr)
|
||||||
|
{
|
||||||
|
int bank = addr < 0x4000
|
||||||
|
? (_reg >> 2) & 0x3F
|
||||||
|
: 7;
|
||||||
|
bank &= _prgMask16k;
|
||||||
|
|
||||||
|
return ROM[(bank * 0x4000) + (addr & 0x3FFF)];
|
||||||
|
}
|
||||||
|
|
||||||
|
public override byte ReadPPU(int addr)
|
||||||
|
{
|
||||||
|
if (addr < 0x2000)
|
||||||
|
{
|
||||||
|
return VRAM[((_reg & 3) * 0x2000) + (addr & 0x1FFF)];
|
||||||
|
}
|
||||||
|
|
||||||
|
return base.ReadPPU(addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void WritePPU(int addr, byte value)
|
||||||
|
{
|
||||||
|
if (addr < 0x2000)
|
||||||
|
{
|
||||||
|
VRAM[((_reg & 3) * 0x2000) + (addr & 0x1FFF)] = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
base.WritePPU(addr, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetMirror(int mirr)
|
||||||
|
{
|
||||||
|
switch (mirr)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
SetMirrorType(EMirrorType.OneScreenA);
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
SetMirrorType(EMirrorType.OneScreenB);
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
SetMirrorType(EMirrorType.Vertical);
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
SetMirrorType(EMirrorType.Horizontal);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue