2011-02-28 10:16:07 +00:00
|
|
|
using System.Diagnostics;
|
|
|
|
|
2011-03-08 07:25:35 +00:00
|
|
|
namespace BizHawk.Emulation.Consoles.Nintendo
|
2011-02-28 10:16:07 +00:00
|
|
|
{
|
2011-06-13 08:38:10 +00:00
|
|
|
//mapper 011
|
2011-02-28 10:16:07 +00:00
|
|
|
|
2011-03-01 09:32:12 +00:00
|
|
|
//Crystal Mines
|
|
|
|
//Metal Fighter
|
|
|
|
|
2013-08-25 01:08:17 +00:00
|
|
|
public sealed class IC_74x377 : NES.NESBoardBase
|
2011-02-28 10:16:07 +00:00
|
|
|
{
|
2011-03-01 09:32:12 +00:00
|
|
|
//configuration
|
2011-06-13 09:55:25 +00:00
|
|
|
int prg_bank_mask_32k, chr_bank_mask_8k;
|
2011-02-28 10:16:07 +00:00
|
|
|
bool bus_conflict = true;
|
2012-10-13 01:29:59 +00:00
|
|
|
bool bus_conflict_50282 = false;
|
2011-02-28 10:16:07 +00:00
|
|
|
|
2011-03-01 09:32:12 +00:00
|
|
|
//state
|
2011-06-13 09:55:25 +00:00
|
|
|
int prg_bank_32k, chr_bank_8k;
|
2011-03-01 09:32:12 +00:00
|
|
|
|
2011-03-20 02:12:10 +00:00
|
|
|
public override bool Configure(NES.EDetectionOrigin origin)
|
2011-02-28 10:16:07 +00:00
|
|
|
{
|
2011-03-08 07:25:35 +00:00
|
|
|
switch (Cart.board_type)
|
2011-03-07 10:41:46 +00:00
|
|
|
{
|
2012-03-22 06:20:10 +00:00
|
|
|
case "MAPPER011":
|
|
|
|
break;
|
|
|
|
|
2011-06-13 08:38:10 +00:00
|
|
|
case "Discrete_74x377-FLEX":
|
|
|
|
break;
|
2011-03-07 10:41:46 +00:00
|
|
|
case "COLORDREAMS-74*377":
|
2011-03-08 07:25:35 +00:00
|
|
|
AssertPrg(32,64,128); AssertChr(16,32,64,128); AssertVram(0); AssertWram(0);
|
2011-03-07 10:41:46 +00:00
|
|
|
break;
|
|
|
|
|
2012-10-13 01:29:59 +00:00
|
|
|
|
|
|
|
case "AGCI-50282": // death race
|
|
|
|
case "MAPPER144":
|
|
|
|
bus_conflict_50282 = true;
|
|
|
|
bus_conflict = false;
|
|
|
|
SetMirrorType(Cart.pad_h, Cart.pad_v);
|
|
|
|
break;
|
|
|
|
|
2011-03-07 10:41:46 +00:00
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
2011-06-13 09:55:25 +00:00
|
|
|
|
|
|
|
prg_bank_mask_32k = Cart.prg_size / 32 - 1;
|
|
|
|
chr_bank_mask_8k = Cart.chr_size / 8 - 1;
|
2011-02-28 10:16:07 +00:00
|
|
|
|
2011-03-07 10:41:46 +00:00
|
|
|
return true;
|
2011-02-28 10:16:07 +00:00
|
|
|
}
|
|
|
|
public override byte ReadPRG(int addr)
|
|
|
|
{
|
2011-06-13 09:55:25 +00:00
|
|
|
return ROM[addr + (prg_bank_32k << 15)];
|
2011-02-28 10:16:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public override byte ReadPPU(int addr)
|
|
|
|
{
|
|
|
|
if (addr < 0x2000)
|
|
|
|
{
|
2011-06-13 09:55:25 +00:00
|
|
|
return VROM[addr + (chr_bank_8k << 13)];
|
2011-02-28 10:16:07 +00:00
|
|
|
}
|
|
|
|
else return base.ReadPPU(addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
public override void WritePRG(int addr, byte value)
|
|
|
|
{
|
2012-10-13 01:29:59 +00:00
|
|
|
if (bus_conflict_50282)
|
|
|
|
{
|
|
|
|
// this is what fceux does
|
|
|
|
//if (addr == 0)
|
|
|
|
// return;
|
|
|
|
// this is what nesdev wiki does. seems to give same results as above?
|
|
|
|
value = (byte)((value | 1) & ReadPRG(addr));
|
|
|
|
}
|
2011-02-28 10:16:07 +00:00
|
|
|
if (bus_conflict)
|
|
|
|
{
|
|
|
|
byte old_value = value;
|
|
|
|
value &= ReadPRG(addr);
|
2012-03-07 00:40:20 +00:00
|
|
|
//Bible Adventures (Unl) (V1.3) [o1].nes will exercise this bus conflict, but not really test it. (works without bus conflict emulation
|
2011-02-28 10:16:07 +00:00
|
|
|
Debug.Assert(old_value == value, "Found a test case of Discrete_74x377 bus conflict. please report.");
|
|
|
|
}
|
|
|
|
|
2011-06-13 09:55:25 +00:00
|
|
|
prg_bank_32k = (value & 3) & prg_bank_mask_32k;
|
|
|
|
chr_bank_8k = ((value >> 4) & 0xF) & chr_bank_mask_8k;
|
2011-02-28 10:16:07 +00:00
|
|
|
}
|
2011-03-01 09:32:12 +00:00
|
|
|
|
2011-04-17 22:51:53 +00:00
|
|
|
public override void SyncState(Serializer ser)
|
2011-03-01 09:32:12 +00:00
|
|
|
{
|
2011-04-17 22:51:53 +00:00
|
|
|
base.SyncState(ser);
|
2011-06-13 09:55:25 +00:00
|
|
|
ser.Sync("prg_bank_32k", ref prg_bank_32k);
|
|
|
|
ser.Sync("chr_bank_8k", ref chr_bank_8k);
|
2011-03-01 09:32:12 +00:00
|
|
|
}
|
|
|
|
|
2011-02-28 10:16:07 +00:00
|
|
|
}
|
|
|
|
}
|