more mapper madness

This commit is contained in:
CaH4e3 2012-11-09 15:49:58 +00:00
parent 2de90cafdd
commit 4d763e782f
9 changed files with 594 additions and 513 deletions

View File

@ -16,7 +16,21 @@
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
* TXC mappers *
* TXC mappers, originally much complex banksitching
*
* 01-22111-000 (05-00002-010) (132, 22211) - MGC-001 Qi Wang
* 01-22110-000 (52S ) - MGC-002 2-in-1 Gun
* 01-22111-100 (02-00002-010) (173 ) - MGC-008 Mahjong Block
* (079 ) - MGC-012 Poke Block
* 01-22110-200 (05-00002-010) (036 ) - MGC-014 Strike Wolf
* 01-22000-400 (05-00002-010) (036 ) - MGC-015 Policeman
* 01-22017-000 (05-PT017-080) (189 ) - MGC-017 Thunder Warrior
* 01-11160-000 (04-02310-000) ( , 11160) - MGC-023 6-in-1
* 01-22270-000 (05-00002-010) (132, 22211) - MGC-xxx Creatom
* 01-22200-400 (------------) (079 ) - ET.03 F-15 City War
* (172 ) - 1991 Du Ma Racing
*
*/ */
#include "mapinc.h" #include "mapinc.h"
@ -29,8 +43,7 @@ static SFORMAT StateRegs[]=
{ 0 } { 0 }
}; };
static void Sync(void) static void Sync(void) {
{
setprg32(0x8000, (reg[2] >> 2) & 1); setprg32(0x8000, (reg[2] >> 2) & 1);
if (is172) if (is172)
setchr8((((cmd ^ reg[2]) >> 3) & 2) | (((cmd ^ reg[2]) >> 5) & 1)); // 1991 DU MA Racing probably CHR bank sequence is WRONG, so it is possible to setchr8((((cmd ^ reg[2]) >> 3) & 2) | (((cmd ^ reg[2]) >> 5) & 1)); // 1991 DU MA Racing probably CHR bank sequence is WRONG, so it is possible to
@ -39,21 +52,18 @@ static void Sync(void)
setchr8(reg[2] & 3); setchr8(reg[2] & 3);
} }
static DECLFW(UNL22211WriteLo) static DECLFW(UNL22211WriteLo) {
{
// FCEU_printf("bs %04x %02x\n",A,V); // FCEU_printf("bs %04x %02x\n",A,V);
reg[A & 3] = V; reg[A & 3] = V;
} }
static DECLFW(UNL22211WriteHi) static DECLFW(UNL22211WriteHi) {
{
// FCEU_printf("bs %04x %02x\n",A,V); // FCEU_printf("bs %04x %02x\n",A,V);
cmd = V; cmd = V;
Sync(); Sync();
} }
static DECLFR(UNL22211ReadLo) static DECLFR(UNL22211ReadLo) {
{
return (reg[1] ^ reg[2]) | (is173 ? 0x01 : 0x40); return (reg[1] ^ reg[2]) | (is173 ? 0x01 : 0x40);
// if(reg[3]) // if(reg[3])
// return reg[2]; // return reg[2];
@ -61,8 +71,7 @@ static DECLFR(UNL22211ReadLo)
// return X.DB; // return X.DB;
} }
static void UNL22211Power(void) static void UNL22211Power(void) {
{
Sync(); Sync();
SetReadHandler(0x8000, 0xFFFF, CartBR); SetReadHandler(0x8000, 0xFFFF, CartBR);
SetReadHandler(0x4100, 0x4100, UNL22211ReadLo); SetReadHandler(0x4100, 0x4100, UNL22211ReadLo);
@ -70,13 +79,11 @@ static void UNL22211Power(void)
SetWriteHandler(0x8000, 0xFFFF, UNL22211WriteHi); SetWriteHandler(0x8000, 0xFFFF, UNL22211WriteHi);
} }
static void StateRestore(int version) static void StateRestore(int version) {
{
Sync(); Sync();
} }
void UNL22211_Init(CartInfo *info) void UNL22211_Init(CartInfo *info) {
{
is172 = 0; is172 = 0;
is173 = 0; is173 = 0;
info->Power = UNL22211Power; info->Power = UNL22211Power;
@ -84,8 +91,7 @@ void UNL22211_Init(CartInfo *info)
AddExState(&StateRegs, ~0, 0, 0); AddExState(&StateRegs, ~0, 0, 0);
} }
void Mapper172_Init(CartInfo *info) void Mapper172_Init(CartInfo *info) {
{
is172 = 1; is172 = 1;
is173 = 0; is173 = 0;
info->Power = UNL22211Power; info->Power = UNL22211Power;
@ -93,11 +99,11 @@ void Mapper172_Init(CartInfo *info)
AddExState(&StateRegs, ~0, 0, 0); AddExState(&StateRegs, ~0, 0, 0);
} }
void Mapper173_Init(CartInfo *info) void Mapper173_Init(CartInfo *info) {
{
is172 = 0; is172 = 0;
is173 = 1; is173 = 1;
info->Power = UNL22211Power; info->Power = UNL22211Power;
GameStateRestore = StateRestore; GameStateRestore = StateRestore;
AddExState(&StateRegs, ~0, 0, 0); AddExState(&StateRegs, ~0, 0, 0);
} }

View File

@ -16,6 +16,15 @@
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* Many-in-one hacked mapper crap.
*
* Original BNROM is actually AxROM variations without mirroring control,
* and haven't SRAM on-board, so it must be removed from here
*
* Difficult banking is what NINA board doing, most hacks for 34 mapper are
* NINA hacks, so this is actually 34 mapper
*
*/ */
#include "mapinc.h" #include "mapinc.h"
@ -30,21 +39,18 @@ static SFORMAT StateRegs[]=
{ 0 } { 0 }
}; };
static void Sync(void) static void Sync(void) {
{
setprg8r(0x10, 0x6000, 0); setprg8r(0x10, 0x6000, 0);
setprg32(0x8000, regs[0]); setprg32(0x8000, regs[0]);
setchr4(0x0000, regs[1]); setchr4(0x0000, regs[1]);
setchr4(0x1000, regs[2]); setchr4(0x1000, regs[2]);
} }
static DECLFW(M34Write) static DECLFW(M34Write) {
{
if (A >= 0x8000) if (A >= 0x8000)
regs[0] = V; regs[0] = V;
else else
switch(A) switch (A) {
{
case 0x7ffd: regs[0] = V; break; case 0x7ffd: regs[0] = V; break;
case 0x7ffe: regs[1] = V; break; case 0x7ffe: regs[1] = V; break;
case 0x7fff: regs[2] = V; break; case 0x7fff: regs[2] = V; break;
@ -52,9 +58,9 @@ static DECLFW(M34Write)
Sync(); Sync();
} }
static void M34Power(void) static void M34Power(void) {
{ regs[0] = regs[1] = 0;
regs[0] = 0; regs[2] = 1;
Sync(); Sync();
SetReadHandler(0x6000, 0x7ffc, CartBR); SetReadHandler(0x6000, 0x7ffc, CartBR);
SetWriteHandler(0x6000, 0x7ffc, CartBW); SetWriteHandler(0x6000, 0x7ffc, CartBW);
@ -62,20 +68,17 @@ static void M34Power(void)
SetWriteHandler(0x7ffd, 0xffff, M34Write); SetWriteHandler(0x7ffd, 0xffff, M34Write);
} }
static void M34Close(void) static void M34Close(void) {
{
if (WRAM) if (WRAM)
FCEU_gfree(WRAM); FCEU_gfree(WRAM);
WRAM = NULL; WRAM = NULL;
} }
static void StateRestore(int version) static void StateRestore(int version) {
{
Sync(); Sync();
} }
void Mapper34_Init(CartInfo *info) void Mapper34_Init(CartInfo *info) {
{
info->Power = M34Power; info->Power = M34Power;
info->Close = M34Close; info->Close = M34Close;
GameStateRestore = StateRestore; GameStateRestore = StateRestore;

View File

@ -44,8 +44,8 @@ static void LatchPower(void) {
if (WRAM) { if (WRAM) {
SetReadHandler(0x6000, 0x7FFF, CartBR); SetReadHandler(0x6000, 0x7FFF, CartBR);
SetWriteHandler(0x6000, 0x7FFF, CartBW); SetWriteHandler(0x6000, 0x7FFF, CartBW);
} } else
SetReadHandler(0x8000, 0xFFFF, defread); SetReadHandler(0x6000, 0xFFFF, defread);
SetWriteHandler(addrreg0, addrreg1, LatchWrite); SetWriteHandler(addrreg0, addrreg1, LatchWrite);
} }
@ -67,7 +67,7 @@ static void Latch_Init(CartInfo *info, void (*proc)(void), readfunc func, uint16
if (func != NULL) if (func != NULL)
defread = func; defread = func;
else else
defread = CartBR; defread = CartBROB;
info->Power = LatchPower; info->Power = LatchPower;
info->Reset = LatchReset; info->Reset = LatchReset;
info->Close = LatchClose; info->Close = LatchClose;
@ -249,11 +249,14 @@ void Mapper201_Init(CartInfo *info) {
//------------------ Map 202 --------------------------- //------------------ Map 202 ---------------------------
static void M202Sync(void) { static void M202Sync(void) {
int32 tmp = (latche >> 1) & 0x7; // According to more carefull hardware tests and PCB study
setmirror((latche & 1)^1); int32 mirror = latche & 1;
setprg16(0x8000, tmp); int32 bank = (latche >> 1) & 0x7;
setprg16(0xc000, tmp + (((tmp & 0x6) == 0x6) ? 1 : 0)); int32 select = (mirror & (bank >> 2));
setchr8(tmp); setprg16(0x8000, select ? (bank & 6) | 0 : bank);
setprg16(0xc000, select ? (bank & 6) | 1 : bank);
setmirror(mirror ^ 1);
setchr8(bank);
} }
void Mapper202_Init(CartInfo *info) { void Mapper202_Init(CartInfo *info) {
@ -277,6 +280,13 @@ void Mapper204_Init(CartInfo *info) {
//------------------ Map 212 --------------------------- //------------------ Map 212 ---------------------------
static DECLFR(M212Read) {
uint8 ret = CartBROB(A);
if ((A & 0xE010) == 0x6000)
ret |= 0x80;
return ret;
}
static void M212Sync(void) { static void M212Sync(void) {
if(latche & 0x4000) { if(latche & 0x4000) {
setprg32(0x8000, (latche >> 1) & 3); setprg32(0x8000, (latche >> 1) & 3);
@ -289,7 +299,7 @@ static void M212Sync(void) {
} }
void Mapper212_Init(CartInfo *info) { void Mapper212_Init(CartInfo *info) {
Latch_Init(info, M212Sync, NULL, 0xFFFF, 0x8000, 0xFFFF, 0); Latch_Init(info, M212Sync, M212Read, 0xFFFF, 0x8000, 0xFFFF, 0);
} }
//------------------ Map 213 --------------------------- //------------------ Map 213 ---------------------------
@ -315,6 +325,17 @@ void Mapper214_Init(CartInfo *info) {
Latch_Init(info, M214Sync, NULL, 0x0000, 0x8000, 0xFFFF, 0); Latch_Init(info, M214Sync, NULL, 0x0000, 0x8000, 0xFFFF, 0);
} }
//------------------ Map 217 ---------------------------
static void M217Sync(void) {
setprg32(0x8000, (latche >> 2) & 3);
setchr8(latche & 7);
}
void Mapper217_Init(CartInfo *info) {
Latch_Init(info, M217Sync, NULL, 0x0000, 0x8000, 0xFFFF, 0);
}
//------------------ Map 227 --------------------------- //------------------ Map 227 ---------------------------
static void M227Sync(void) { static void M227Sync(void) {
@ -408,9 +429,9 @@ void Mapper242_Init(CartInfo *info) {
//------------------ 190in1 --------------------------- //------------------ 190in1 ---------------------------
static void BMC190in1Sync(void) { static void BMC190in1Sync(void) {
setprg16(0x8000, (latche >> 2) & 0x07); setprg16(0x8000, (latche >> 2) & 7);
setprg16(0xC000, (latche >> 2) & 0x07); setprg16(0xC000, (latche >> 2) & 7);
setchr8((latche >> 2) & 0x07); setchr8((latche >> 2) & 7);
setmirror((latche & 1) ^ 1); setmirror((latche & 1) ^ 1);
} }
@ -457,3 +478,25 @@ static void BMCNTD03Sync(void) {
void BMCNTD03_Init(CartInfo *info) { void BMCNTD03_Init(CartInfo *info) {
Latch_Init(info, BMCNTD03Sync, NULL, 0x0000, 0x8000, 0xFFFF, 0); Latch_Init(info, BMCNTD03Sync, NULL, 0x0000, 0x8000, 0xFFFF, 0);
} }
//-------------- BMCG-146 ------------------------
static void BMCG146Sync(void) {
setchr8(0);
if (latche & 0x800) { // UNROM mode
setprg16(0x8000, (latche & 0x1F) | (latche & ((latche & 0x40) >> 6)));
setprg16(0xC000, (latche & 0x18) | 7);
} else {
if (latche & 0x40) { // 16K mode
setprg16(0x8000, latche & 0x1F);
setprg16(0xC000, latche & 0x1F);
} else {
setprg32(0x8000, (latche >> 1) & 0x0F);
}
}
setmirror(((latche & 0x80) >> 7) ^ 1);
}
void BMCG146_Init(CartInfo *info) {
Latch_Init(info, BMCG146Sync, NULL, 0x0000, 0x8000, 0xFFFF, 0);
}

View File

@ -478,3 +478,16 @@ void BMCA65AS_Init(CartInfo *info) {
Latch_Init(info, BMCA65ASSync, 0, 0x8000, 0xFFFF, 0, 0); Latch_Init(info, BMCA65ASSync, 0, 0x8000, 0xFFFF, 0, 0);
} }
//------------------ BMC-11160 ---------------------------
// Simple BMC discrete mapper by TXC
static void BMC11160Sync(void) {
uint32 bank = (latche >> 4) & 7;
setprg32(0x8000, bank);
setchr8((bank << 2) | (latche & 3));
setmirror((latche >> 7) & 1);
}
void BMC11160_Init(CartInfo *info) {
Latch_Init(info, BMC11160Sync, 0, 0x8000, 0xFFFF, 0, 0);
}

View File

@ -178,6 +178,7 @@
{0x5b457641, 157, 8}, /* Datach Ultraman Club */ {0x5b457641, 157, 8}, /* Datach Ultraman Club */
{0xf51a7f46, 157, 8}, /* Datach Yuu Yuu Hakusho */ {0xf51a7f46, 157, 8}, /* Datach Yuu Yuu Hakusho */
{0x58152b42, 160, 1}, /* Pipe 5 (Sachen) */ {0x58152b42, 160, 1}, /* Pipe 5 (Sachen) */
{0x1c098942, 162, -1}, /* Xi You Ji Hou Zhuan (Ch) */
{0x081caaff, 163, -1}, /* Commandos (Ch) */ {0x081caaff, 163, -1}, /* Commandos (Ch) */
{0x02c41438, 176, -1}, /* Xing He Zhan Shi (C) */ {0x02c41438, 176, -1}, /* Xing He Zhan Shi (C) */
{0x558c0dc3, 178, -1}, /* Super 2in1 (unl)[!] {mapper unsupported} */ {0x558c0dc3, 178, -1}, /* Super 2in1 (unl)[!] {mapper unsupported} */
@ -226,11 +227,21 @@
{0xd323b806, 210, 1}, /* Wagyan Land 3 */ {0xd323b806, 210, 1}, /* Wagyan Land 3 */
{0xbd523011, 210, 2}, /* Dream Master */ {0xbd523011, 210, 2}, /* Dream Master */
{0x5daae69a, 211, -1}, /* Aladdin - Return of Jaffar, The (Unl) [!] */ {0x5daae69a, 211, -1}, /* Aladdin - Return of Jaffar, The (Unl) [!] */
{0x046d70cc, 217, -1}, /* 500-in-1 (Anim Splash, Alt Mapper)[p1][!] */
{0x12f86a4d, 217, -1}, /* 500-in-1 (Static Splash, Alt Mapper)[p1][!] */
{0xd09f778d, 217, -1}, /* 9999999-in-1 (Static Splash, Alt Mapper)[p1][!] */
{0x62ef6c79, 232, 8}, /* Quattro Sports -Aladdin */ {0x62ef6c79, 232, 8}, /* Quattro Sports -Aladdin */
{0x2705eaeb, 234, -1}, /* Maxi 15 */ {0x2705eaeb, 234, -1}, /* Maxi 15 */
{0x6f12afc5, 235, -1}, /* Golden Game 150-in-1 */ {0x6f12afc5, 235, -1}, /* Golden Game 150-in-1 */
{0xfb2b6b10, 241, -1}, /* Fan Kong Jing Ying (Ch) */ {0xfb2b6b10, 241, -1}, /* Fan Kong Jing Ying (Ch) */
{0xb5e83c9a, 241, -1}, /* Xing Ji Zheng Ba (Ch) */ {0xb5e83c9a, 241, -1}, /* Xing Ji Zheng Ba (Ch) */
{0x2537b3e6, 241, -1}, /* Dance Xtreme - Prima (Unl) */
{0x11611e89, 241, -1}, /* Darkseed (Unl) [p1] */
{0x81a37827, 241, -1}, /* Darkseed (Unl) [p1][b1] */
{0xc2730c30, 241, -1}, /* Deadly Towers (U) [!] */
{0x368c19a8, 241, -1}, /* LIKO Study Cartridge 3-in-1 (Unl) [!] */
{0xa21e675c, 241, -1}, /* Mashou (J) [!] */
{0x54d98b79, 241, -1}, /* Titanic 1912 (Unl) */
{0x6bea1235, 245, -1}, /* MMC3 cart, but with nobanking applied to CHR-RAM, so let it be there */ {0x6bea1235, 245, -1}, /* MMC3 cart, but with nobanking applied to CHR-RAM, so let it be there */
{0x345ee51a, 245, -1}, /* DQ4c */ {0x345ee51a, 245, -1}, /* DQ4c */
{0x57514c6c, 245, -1}, /* Yong Zhe Dou E Long - Dragon Quest VI (Ch) */ {0x57514c6c, 245, -1}, /* Yong Zhe Dou E Long - Dragon Quest VI (Ch) */

View File

@ -740,7 +740,7 @@ static BMAPPINGLocal bmap[] = {
{"", 214, Mapper214_Init}, {"", 214, Mapper214_Init},
{"", 215, UNL8237_Init}, {"", 215, UNL8237_Init},
{"", 216, Mapper216_Init}, {"", 216, Mapper216_Init},
// {"", 217, UNL8237A_Init}, {"", 217, Mapper217_Init}, // Redefined to a new Discrete BMC mapper
// {"", 218, Mapper218_Init}, // {"", 218, Mapper218_Init},
{"UNLA9746", 219, UNLA9746_Init}, {"UNLA9746", 219, UNLA9746_Init},
{"Debug Mapper", 220, UNLKS7057_Init}, {"Debug Mapper", 220, UNLKS7057_Init},
@ -774,11 +774,11 @@ static BMAPPINGLocal bmap[] = {
// {"", 248, Mapper248_Init}, // {"", 248, Mapper248_Init},
{"", 249, Mapper249_Init}, {"", 249, Mapper249_Init},
{"", 250, Mapper250_Init}, {"", 250, Mapper250_Init},
// {"", 251, Mapper251_Init}, // {"", 251, Mapper251_Init}, // No good dumps for this mapper, use UNIF version
{"SAN GUO ZHI PIRATE", 252, Mapper252_Init}, {"SAN GUO ZHI PIRATE", 252, Mapper252_Init},
{"DRAGON BALL PIRATE", 253, Mapper253_Init}, {"DRAGON BALL PIRATE", 253, Mapper253_Init},
{"", 254, Mapper254_Init}, {"", 254, Mapper254_Init},
// {"", 255, Mapper255_Init}, // Doesn't have any good dump for this mapper // {"", 255, Mapper255_Init}, // No good dumps for this mapper
{"", 0, NULL} {"", 0, NULL}
}; };

View File

@ -485,6 +485,7 @@ void Mapper212_Init(CartInfo *);
void Mapper213_Init(CartInfo *); void Mapper213_Init(CartInfo *);
void Mapper214_Init(CartInfo *); void Mapper214_Init(CartInfo *);
void Mapper216_Init(CartInfo *); void Mapper216_Init(CartInfo *);
void Mapper217_Init(CartInfo *);
void Mapper220_Init(CartInfo *); void Mapper220_Init(CartInfo *);
void Mapper222_Init(CartInfo *); void Mapper222_Init(CartInfo *);
void Mapper225_Init(CartInfo *); void Mapper225_Init(CartInfo *);

View File

@ -317,6 +317,7 @@ static int LoadCHR(FCEUFILE *fp)
static BMAPPING bmap[] = { static BMAPPING bmap[] = {
{ "11160", BMC11160_Init, 0 },
{ "12-IN-1", BMC12IN1_Init, 0 }, { "12-IN-1", BMC12IN1_Init, 0 },
{ "13in1JY110", BMC13in1JY110_Init, 0 }, { "13in1JY110", BMC13in1JY110_Init, 0 },
{ "190in1", BMC190in1_Init, 0 }, { "190in1", BMC190in1_Init, 0 },
@ -356,6 +357,7 @@ static BMAPPING bmap[] = {
{ "FK23C", BMCFK23C_Init, BMCFLAG_EXPCHRR }, { "FK23C", BMCFK23C_Init, BMCFLAG_EXPCHRR },
{ "FK23CA", BMCFK23CA_Init, BMCFLAG_EXPCHRR }, { "FK23CA", BMCFK23CA_Init, BMCFLAG_EXPCHRR },
{ "FS304", UNLFS304_Init, 0 }, { "FS304", UNLFS304_Init, 0 },
{ "G-146", BMCG146_Init, 0 },
{ "GK-192", BMCGK192_Init, 0 }, { "GK-192", BMCGK192_Init, 0 },
{ "GS-2004", BMCGS2004_Init, 0 }, { "GS-2004", BMCGS2004_Init, 0 },
{ "GS-2013", BMCGS2013_Init, 0 }, { "GS-2013", BMCGS2013_Init, 0 },

View File

@ -20,6 +20,7 @@
void AC08_Init(CartInfo *info); void AC08_Init(CartInfo *info);
void ANROM_Init(CartInfo *info); void ANROM_Init(CartInfo *info);
void BMC11160_Init(CartInfo *info);
void BMC12IN1_Init(CartInfo *info); void BMC12IN1_Init(CartInfo *info);
void BMC13in1JY110_Init(CartInfo *info); void BMC13in1JY110_Init(CartInfo *info);
void BMC190in1_Init(CartInfo *info); void BMC190in1_Init(CartInfo *info);
@ -34,6 +35,7 @@ void BMCBS5_Init(CartInfo *info);
void BMCD1038_Init(CartInfo *info); void BMCD1038_Init(CartInfo *info);
void BMCFK23CA_Init(CartInfo *info); void BMCFK23CA_Init(CartInfo *info);
void BMCFK23C_Init(CartInfo *info); void BMCFK23C_Init(CartInfo *info);
void BMCG146_Init(CartInfo *info);
void BMCGK192_Init(CartInfo *info); void BMCGK192_Init(CartInfo *info);
void BMCGS2004_Init(CartInfo *info); void BMCGS2004_Init(CartInfo *info);
void BMCGS2013_Init(CartInfo *info); void BMCGS2013_Init(CartInfo *info);