NES - start BANDAI-FCG-1 board (mappers 69 + 159)
This commit is contained in:
parent
a121ef1c77
commit
7c55b343ae
|
@ -0,0 +1,152 @@
|
||||||
|
using System;
|
||||||
|
using System.IO;
|
||||||
|
using System.Diagnostics;
|
||||||
|
|
||||||
|
namespace BizHawk.Emulation.Consoles.Nintendo
|
||||||
|
{
|
||||||
|
//AKA mapper 16 & 159
|
||||||
|
/*
|
||||||
|
Example Games:
|
||||||
|
--------------------------
|
||||||
|
Dragon Ball - Dai Maou Jukkatsu (016)
|
||||||
|
Dragon Ball Z Gaiden (016)
|
||||||
|
Dragon Ball Z 2 (016)
|
||||||
|
Rokudenashi Blues (016)
|
||||||
|
Akuma-kun - Makai no Wana (016)
|
||||||
|
Dragon Ball Z - Kyoushuu! Saiya Jin (159)
|
||||||
|
SD Gundam Gaiden (159)
|
||||||
|
Magical Taruruuto Kun 1, 2 (159)
|
||||||
|
|
||||||
|
PRG_ROM: 128KB
|
||||||
|
PRG_RAM: None
|
||||||
|
CHR-ROM: 128KB
|
||||||
|
CHR_RAM: None
|
||||||
|
No Batter
|
||||||
|
Mapper controlled mirroring
|
||||||
|
No CIC present
|
||||||
|
*/
|
||||||
|
|
||||||
|
class BANDAI_FCG_1 : NES.NESBoardBase
|
||||||
|
{
|
||||||
|
//configuration
|
||||||
|
int prg, chr_bank_mask_1k, mirror;
|
||||||
|
bool irq_countdown, irq_enabled, irq_asserted;
|
||||||
|
ushort irq_counter;
|
||||||
|
int clock_counter;
|
||||||
|
|
||||||
|
int addr_reg;
|
||||||
|
ByteBuffer regs = new ByteBuffer(12);
|
||||||
|
|
||||||
|
public override bool Configure(NES.EDetectionOrigin origin)
|
||||||
|
{
|
||||||
|
switch (Cart.board_type)
|
||||||
|
{
|
||||||
|
case "BANDAI-FCG-1":
|
||||||
|
AssertPrg(128); AssertChr(128); AssertWram(0); AssertVram(0);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void BaseConfigure()
|
||||||
|
{
|
||||||
|
chr_bank_mask_1k = Cart.chr_size - 1;
|
||||||
|
SetMirrorType(EMirrorType.Vertical);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override byte ReadPRG(int addr)
|
||||||
|
{
|
||||||
|
return ROM[addr + (prg * 0x8000)];
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void WritePRG(int addr, byte value)
|
||||||
|
{
|
||||||
|
switch (addr)
|
||||||
|
{
|
||||||
|
case 0: case 1: case 2: case 3:
|
||||||
|
case 4: case 5: case 6: case 7:
|
||||||
|
regs[addr_reg] = value;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
prg = value;
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
mirror = value & 0x03;
|
||||||
|
switch (mirror)
|
||||||
|
{
|
||||||
|
case 0: SetMirrorType(NES.NESBoardBase.EMirrorType.Vertical); break;
|
||||||
|
case 1: SetMirrorType(NES.NESBoardBase.EMirrorType.Horizontal); break;
|
||||||
|
case 2: SetMirrorType(NES.NESBoardBase.EMirrorType.OneScreenA); break;
|
||||||
|
case 3: SetMirrorType(NES.NESBoardBase.EMirrorType.OneScreenB); break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 0xA:
|
||||||
|
irq_enabled = value.Bit(0);
|
||||||
|
break;
|
||||||
|
case 0xB:
|
||||||
|
irq_counter &= 0xFF00;
|
||||||
|
irq_counter |= value;
|
||||||
|
break;
|
||||||
|
case 0xC:
|
||||||
|
irq_counter &= 0x00FF;
|
||||||
|
irq_counter |= (ushort)(value << 8);
|
||||||
|
break;
|
||||||
|
case 0xD:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override byte ReadPPU(int addr)
|
||||||
|
{
|
||||||
|
//return VRAM[addr + chr];
|
||||||
|
return base.ReadPPU(addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void WritePPU(int addr, byte value)
|
||||||
|
{
|
||||||
|
//VRAM[addr + chr] = value;
|
||||||
|
base.WritePPU(addr, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SyncIrq()
|
||||||
|
{
|
||||||
|
NES.irq_cart = irq_asserted;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void ClockPPU()
|
||||||
|
{
|
||||||
|
clock_counter++;
|
||||||
|
if (clock_counter == 3)
|
||||||
|
{
|
||||||
|
ClockCPU();
|
||||||
|
clock_counter = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ClockCPU()
|
||||||
|
{
|
||||||
|
if (!irq_countdown) return;
|
||||||
|
irq_counter--;
|
||||||
|
if (irq_counter == 0x0000)
|
||||||
|
{
|
||||||
|
irq_asserted = true;
|
||||||
|
SyncIrq();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void SyncState(Serializer ser)
|
||||||
|
{
|
||||||
|
base.SyncState(ser);
|
||||||
|
ser.Sync("prg", ref prg);
|
||||||
|
ser.Sync("chr_bank_mask_1k", ref chr_bank_mask_1k);
|
||||||
|
ser.Sync("mirror", ref mirror);
|
||||||
|
ser.Sync("irq_counter", ref irq_counter);
|
||||||
|
ser.Sync("irq_countdown", ref irq_countdown);
|
||||||
|
ser.Sync("irq_enabled", ref irq_enabled);
|
||||||
|
ser.Sync("irq_asserted", ref irq_asserted);
|
||||||
|
ser.Sync("clock_counter", ref clock_counter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue