NES - implement mapper 92
This commit is contained in:
parent
bcef8e62d7
commit
a2a9bfde3c
|
@ -143,6 +143,7 @@
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\JALECO_JF_05_06_07.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\JALECO_JF_05_06_07.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\JALECO_JF_13.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\JALECO_JF_13.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\JALECO_JF_17.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\JALECO_JF_17.cs" />
|
||||||
|
<Compile Include="Consoles\Nintendo\NES\Boards\JALECO_JF_19.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\Mapper069.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\Mapper069.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\Mapper107.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\Mapper107.cs" />
|
||||||
<Compile Include="Consoles\Nintendo\NES\Boards\Mapper164.cs" />
|
<Compile Include="Consoles\Nintendo\NES\Boards\Mapper164.cs" />
|
||||||
|
|
|
@ -0,0 +1,110 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace BizHawk.Emulation.Consoles.Nintendo
|
||||||
|
{
|
||||||
|
//iNES Mapper 92
|
||||||
|
//Example Games:
|
||||||
|
//Example Games:
|
||||||
|
//--------------------------
|
||||||
|
//Moero!! Pro Soccer
|
||||||
|
//Moero!! Pro Yakyuu '88 - Ketteiban
|
||||||
|
|
||||||
|
//Near Identical to Jaleco JF 17, except for a slight PRG setup
|
||||||
|
|
||||||
|
class JALECO_JF_19 : NES.NESBoardBase
|
||||||
|
{
|
||||||
|
//configuration
|
||||||
|
int prg_bank_mask_16k;
|
||||||
|
int chr_bank_mask_8k;
|
||||||
|
|
||||||
|
//state
|
||||||
|
int latch;
|
||||||
|
ByteBuffer prg_banks_16k = new ByteBuffer(2);
|
||||||
|
ByteBuffer chr_banks_8k = new ByteBuffer(1);
|
||||||
|
|
||||||
|
public override bool Configure(NES.EDetectionOrigin origin)
|
||||||
|
{
|
||||||
|
switch (Cart.board_type)
|
||||||
|
{
|
||||||
|
case "MAPPER092":
|
||||||
|
break;
|
||||||
|
case "JALECO-JF-19":
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
prg_bank_mask_16k = (Cart.prg_size / 16) - 1;
|
||||||
|
chr_bank_mask_8k = (Cart.chr_size / 8) - 1;
|
||||||
|
|
||||||
|
SetMirrorType(Cart.pad_h, Cart.pad_v);
|
||||||
|
|
||||||
|
prg_banks_16k[0] = 0;
|
||||||
|
chr_banks_8k[0] = 0;
|
||||||
|
SyncMap();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SyncMap()
|
||||||
|
{
|
||||||
|
ApplyMemoryMapMask(prg_bank_mask_16k, prg_banks_16k);
|
||||||
|
ApplyMemoryMapMask(chr_bank_mask_8k, chr_banks_8k);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Dispose()
|
||||||
|
{
|
||||||
|
prg_banks_16k.Dispose();
|
||||||
|
base.Dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void SyncState(Serializer ser)
|
||||||
|
{
|
||||||
|
base.SyncState(ser);
|
||||||
|
ser.Sync("latch", ref latch);
|
||||||
|
ser.Sync("prg_banks_16k", ref prg_banks_16k);
|
||||||
|
ser.Sync("chr_banks_8k", ref chr_banks_8k);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void WritePRG(int addr, byte value)
|
||||||
|
{
|
||||||
|
//Console.WriteLine("MAP {0:X4} = {1:X2}", addr, value);
|
||||||
|
|
||||||
|
value = HandleNormalPRGConflict(addr, value);
|
||||||
|
|
||||||
|
int command = value >> 6;
|
||||||
|
switch (command)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
if (latch == 1)
|
||||||
|
chr_banks_8k[0] = (byte)(value & 0xF);
|
||||||
|
else if (latch == 2)
|
||||||
|
prg_banks_16k[1] = (byte)(value & 0xF);
|
||||||
|
SyncMap();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
latch = command;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override byte ReadPRG(int addr)
|
||||||
|
{
|
||||||
|
addr = ApplyMemoryMap(14, prg_banks_16k, addr);
|
||||||
|
return ROM[addr];
|
||||||
|
}
|
||||||
|
|
||||||
|
public override byte ReadPPU(int addr)
|
||||||
|
{
|
||||||
|
if (addr < 0x2000)
|
||||||
|
{
|
||||||
|
addr = ApplyMemoryMap(13, chr_banks_8k, addr);
|
||||||
|
return base.ReadPPUChr(addr);
|
||||||
|
}
|
||||||
|
else return base.ReadPPU(addr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue