mapper 183 - second level crash fix

This commit is contained in:
CaH4e3 2013-05-26 07:55:23 +00:00
parent 175c4af22b
commit 1b5220a004
2 changed files with 23 additions and 19 deletions

View File

@ -22,8 +22,7 @@
#include "mapinc.h" #include "mapinc.h"
static uint8 prg[4]; static uint8 prg[4], chr[8], mirr;
static uint8 chr[8];
static uint8 IRQCount; static uint8 IRQCount;
static uint8 IRQPre; static uint8 IRQPre;
static uint8 IRQa; static uint8 IRQa;
@ -32,6 +31,7 @@ static SFORMAT StateRegs[] =
{ {
{ prg, 4, "PRG" }, { prg, 4, "PRG" },
{ chr, 8, "CHR" }, { chr, 8, "CHR" },
{ &mirr, 1, "MIRR" },
{ &IRQCount, 1, "IRQC" }, { &IRQCount, 1, "IRQC" },
{ &IRQPre, 1, "IRQP" }, { &IRQPre, 1, "IRQP" },
{ &IRQa, 1, "IRQA" }, { &IRQa, 1, "IRQA" },
@ -39,13 +39,22 @@ static SFORMAT StateRegs[] =
}; };
static void SyncPrg(void) { static void SyncPrg(void) {
setprg8(0x6000, 0); setprg8(0x6000, prg[3]);
setprg8(0x8000, prg[0]); setprg8(0x8000, prg[0]);
setprg8(0xA000, prg[1]); setprg8(0xA000, prg[1]);
setprg8(0xC000, prg[2]); setprg8(0xC000, prg[2]);
setprg8(0xE000, ~0); setprg8(0xE000, ~0);
} }
static void SyncMirr(void) {
switch (mirr) {
case 0: setmirror(MI_V); break;
case 1: setmirror(MI_H); break;
case 2: setmirror(MI_0); break;
case 3: setmirror(MI_1); break;
}
}
static void SyncChr(void) { static void SyncChr(void) {
int i; int i;
for (i = 0; i < 8; i++) for (i = 0; i < 8; i++)
@ -55,10 +64,14 @@ static void SyncChr(void) {
static void StateRestore(int version) { static void StateRestore(int version) {
SyncPrg(); SyncPrg();
SyncChr(); SyncChr();
SyncMirr();
} }
static DECLFW(M183Write) { static DECLFW(M183Write) {
if (((A & 0xF80C) >= 0xB000) && ((A & 0xF80C) <= 0xE00C)) { if ((A & 0xF800) == 0x6800) {
prg[3] = A & 0x3F;
SyncPrg();
} else if (((A & 0xF80C) >= 0xB000) && ((A & 0xF80C) <= 0xE00C)) {
int index = (((A >> 11) - 6) | (A >> 3)) & 7; int index = (((A >> 11) - 6) | (A >> 3)) & 7;
chr[index] = (chr[index] & (0xF0 >> (A & 4))) | ((V & 0x0F) << (A & 4)); chr[index] = (chr[index] & (0xF0 >> (A & 4))) | ((V & 0x0F) << (A & 4));
SyncChr(); SyncChr();
@ -66,14 +79,7 @@ static DECLFW(M183Write) {
case 0x8800: prg[0] = V; SyncPrg(); break; case 0x8800: prg[0] = V; SyncPrg(); break;
case 0xA800: prg[1] = V; SyncPrg(); break; case 0xA800: prg[1] = V; SyncPrg(); break;
case 0xA000: prg[2] = V; SyncPrg(); break; case 0xA000: prg[2] = V; SyncPrg(); break;
case 0x9800: case 0x9800: mirr = V & 3; SyncMirr(); break;
switch (V & 3) {
case 0: setmirror(MI_V); break;
case 1: setmirror(MI_H); break;
case 2: setmirror(MI_0); break;
case 3: setmirror(MI_1); break;
}
break;
case 0xF000: IRQCount = ((IRQCount & 0xF0) | (V & 0xF)); break; case 0xF000: IRQCount = ((IRQCount & 0xF0) | (V & 0xF)); break;
case 0xF004: IRQCount = ((IRQCount & 0x0F) | ((V & 0xF) << 4)); break; case 0xF004: IRQCount = ((IRQCount & 0x0F) | ((V & 0xF) << 4)); break;
case 0xF008: IRQa = V; if (!V) IRQPre = 0; X6502_IRQEnd(FCEU_IQEXT); break; case 0xF008: IRQa = V; if (!V) IRQPre = 0; X6502_IRQEnd(FCEU_IQEXT); break;
@ -91,9 +97,8 @@ static void M183IRQCounter(void) {
static void M183Power(void) { static void M183Power(void) {
IRQPre = IRQCount = IRQa = 0; IRQPre = IRQCount = IRQa = 0;
SetReadHandler(0x8000, 0xFFFF, CartBR); SetReadHandler(0x6000, 0xFFFF, CartBR);
SetWriteHandler(0x8000, 0xFFFF, M183Write); SetWriteHandler(0x6000, 0xFFFF, M183Write);
SetReadHandler(0x6000, 0x7FFF, CartBR);
SyncPrg(); SyncPrg();
SyncChr(); SyncChr();
} }

View File

@ -75,7 +75,7 @@ static DECLFW(M69Write0) {
} }
static DECLFW(M69Write1) { static DECLFW(M69Write1) {
switch(cmdreg) { switch (cmdreg) {
case 0x0: creg[0] = V; Sync(); break; case 0x0: creg[0] = V; Sync(); break;
case 0x1: creg[1] = V; Sync(); break; case 0x1: creg[1] = V; Sync(); break;
case 0x2: creg[2] = V; Sync(); break; case 0x2: creg[2] = V; Sync(); break;
@ -88,7 +88,7 @@ static DECLFW(M69Write1) {
case 0x9: preg[0] = V; Sync(); break; case 0x9: preg[0] = V; Sync(); break;
case 0xA: preg[1] = V; Sync(); break; case 0xA: preg[1] = V; Sync(); break;
case 0xB: preg[2] = V; Sync(); break; case 0xB: preg[2] = V; Sync(); break;
case 0xC: mirr = V & 3; Sync(); break; case 0xC: mirr = V & 3; Sync();break;
case 0xD: IRQa = V; X6502_IRQEnd(FCEU_IQEXT); break; case 0xD: IRQa = V; X6502_IRQEnd(FCEU_IQEXT); break;
case 0xE: IRQCount &= 0xFF00; IRQCount |= V; X6502_IRQEnd(FCEU_IQEXT); break; case 0xE: IRQCount &= 0xFF00; IRQCount |= V; X6502_IRQEnd(FCEU_IQEXT); break;
case 0xF: IRQCount &= 0x00FF; IRQCount |= V << 8; X6502_IRQEnd(FCEU_IQEXT); break; case 0xF: IRQCount &= 0x00FF; IRQCount |= V << 8; X6502_IRQEnd(FCEU_IQEXT); break;
@ -234,8 +234,7 @@ static void M69Power(void) {
SetWriteHandler(0xE000, 0xFFFF, M69SWrite1); SetWriteHandler(0xE000, 0xFFFF, M69SWrite1);
} }
static void M69Close(void) static void M69Close(void) {
{
if (WRAM) if (WRAM)
FCEU_gfree(WRAM); FCEU_gfree(WRAM);
WRAM = NULL; WRAM = NULL;