UNIF DSOUNDV1 - pre beta mapper, nw

various mapper improvements
UNIF MALISB - Mali Splash Bomb dump
mapper 19 - Dream Master mirror fix
SOUND - low quality 69 mapper exp sound fix
This commit is contained in:
CaH4e3 2013-02-18 13:41:44 +00:00
parent 71eec979e8
commit 71f2d5bc9c
14 changed files with 247 additions and 33 deletions

View File

@ -22,14 +22,14 @@
#include "mapinc.h" #include "mapinc.h"
static uint8 SWRAM[2816]; static uint8 SWRAM[3072];
static uint8 *WRAM = NULL; static uint8 *WRAM = NULL;
static uint8 regs[4]; static uint8 regs[4];
static SFORMAT StateRegs[] = static SFORMAT StateRegs[] =
{ {
{ regs, 4, "DREG" }, { regs, 4, "DREG" },
{ SWRAM, 2816, "SWRM" }, { SWRAM, 3072, "SWRM" },
{ 0 } { 0 }
}; };
@ -67,8 +67,8 @@ static void M186Power(void) {
SetWriteHandler(0x6000, 0xFFFF, CartBW); SetWriteHandler(0x6000, 0xFFFF, CartBW);
SetReadHandler(0x4200, 0x43FF, M186Read); SetReadHandler(0x4200, 0x43FF, M186Read);
SetWriteHandler(0x4200, 0x43FF, M186Write); SetWriteHandler(0x4200, 0x43FF, M186Write);
SetReadHandler(0x4400, 0x4EFF, ASWRAM); SetReadHandler(0x4400, 0x4FFF, ASWRAM);
SetWriteHandler(0x4400, 0x4EFF, BSWRAM); SetWriteHandler(0x4400, 0x4FFF, BSWRAM);
regs[0] = regs[1] = regs[2] = regs[3]; regs[0] = regs[1] = regs[2] = regs[3];
Sync(); Sync();
} }

View File

@ -38,6 +38,8 @@ static void Sync(void) {
setchr1(0x1000 + (x << 10), DRegs[2 + x]); setchr1(0x1000 + (x << 10), DRegs[2 + x]);
setprg8(0x8000, DRegs[6]); setprg8(0x8000, DRegs[6]);
setprg8(0xa000, DRegs[7]); setprg8(0xa000, DRegs[7]);
setprg8(0xc000, ~1);
setprg8(0xe000, ~0);
} }
static void StateRestore(int version) { static void StateRestore(int version) {
@ -60,10 +62,9 @@ static DECLFW(M206Write) {
} }
static void M206Power(void) { static void M206Power(void) {
setprg8(0xc000, 0xE);
setprg8(0xe000, 0xF);
cmd = 0; cmd = 0;
memset(DRegs, 0, 8); DRegs[6] = 0;
DRegs[7] = 1;
Sync(); Sync();
SetReadHandler(0x8000, 0xFFFF, CartBR); SetReadHandler(0x8000, 0xFFFF, CartBR);
SetWriteHandler(0x8000, 0xFFFF, M206Write); SetWriteHandler(0x8000, 0xFFFF, M206Write);

View File

@ -63,9 +63,10 @@ static DECLFR(M208ProtRead) {
static void M208Power(void) { static void M208Power(void) {
EXPREGS[5] = 3; EXPREGS[5] = 3;
GenMMC3Power(); GenMMC3Power();
SetWriteHandler(0x4800, 0x4FFF, M208Write); SetWriteHandler(0x4800, 0x4fff, M208Write);
SetWriteHandler(0x6800, 0x6fff, M208Write);
SetWriteHandler(0x5000, 0x5fff, M208ProtWrite); SetWriteHandler(0x5000, 0x5fff, M208ProtWrite);
SetReadHandler(0x5800, 0x5FFF, M208ProtRead); SetReadHandler(0x5800, 0x5fff, M208ProtRead);
SetReadHandler(0x8000, 0xffff, CartBR); SetReadHandler(0x8000, 0xffff, CartBR);
} }

View File

@ -1,7 +1,7 @@
/* FCE Ultra - NES/Famicom Emulator /* FCE Ultra - NES/Famicom Emulator
* *
* Copyright notice for this file: * Copyright notice for this file:
* Copyright (C) 2012 CaH4e3 * Copyright (C) 2013 CaH4e3
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by

View File

@ -435,6 +435,9 @@ void Mapper240_Init(CartInfo *info) {
static void M241Sync(void) { static void M241Sync(void) {
setchr8(0); setchr8(0);
setprg8r(0x10, 0x6000, 0); setprg8r(0x10, 0x6000, 0);
if(latche & 0x80)
setprg32(0x8000, latche | 8); // no 241 actually, but why not afterall?
else
setprg32(0x8000, latche); setprg32(0x8000, latche);
} }

175
src/boards/dsoundv1.cpp Normal file
View File

@ -0,0 +1,175 @@
/* FCE Ultra - NES/Famicom Emulator
*
* Copyright notice for this file:
* Copyright (C) 2013 CaH4e3
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "mapinc.h"
static uint8 reg[4];
static uint8 *WRAM = NULL;
static uint32 WRAMSIZE;
// SND Registers
static uint8 pcm_enable = 0;
static int16 pcm_latch = 0x3F6, pcm_clock = 0x3F6;
static writefunc pcmwrite;
static SFORMAT StateRegs[] =
{
{ reg, 4, "REGS" },
{ 0 }
};
static int16 step_size[49] = {
16, 17, 19, 21, 23, 25, 28, 31, 34, 37,
41, 45, 50, 55, 60, 66, 73, 80, 88, 97,
107, 118, 130, 143, 157, 173, 190, 209, 230, 253,
279, 307, 337, 371, 408, 449, 494, 544, 598, 658,
724, 796, 876, 963, 1060, 1166, 1282, 1411, 1552
}; //49 items
static int32 step_adj[16] = { -1, -1, -1, -1, 2, 5, 7, 9, -1, -1, -1, -1, 2, 5, 7, 9 };
//decode stuff
static int32 jedi_table[16 * 49];
static int32 acc = 0; //ADPCM accumulator, initial condition must be 0
static int32 decstep = 0; //ADPCM decoding step, initial condition must be 0
static void jedi_table_init()
{
int step, nib;
for (step = 0; step < 49; step++)
{
for (nib = 0; nib < 16; nib++)
{
int value = (2 * (nib & 0x07) + 1) * step_size[step] / 8;
jedi_table[step * 16 + nib] = ((nib & 0x08) != 0) ? -value : value;
}
}
}
static uint8 decode(uint8 code)
{
acc += jedi_table[decstep + code];
if ((acc & ~0x7ff) != 0) // acc is > 2047
acc |= ~0xfff;
else acc &= 0xfff;
decstep += step_adj[code & 7] * 16;
if (decstep < 0) decstep = 0;
if (decstep > 48 * 16) decstep = 48 * 16;
return (acc >> 8) & 0xff;
}
static void Sync(void) {
uint32 sbank = reg[1] & 0x7;
uint32 bbank = reg[2];
setchr8(0);
setprg8r(0x10, 0x6000, reg[3] & 3);
if(reg[0] & 2) { // UNROM mode
setprg16(0x8000, (bbank << 3) | sbank);
if(reg[0] & 4)
setprg16(0xC000, (bbank << 3) | 6 | (reg[1] & 1));
else
setprg16(0xC000, (bbank << 3) | 7);
} else { // NROM mode
uint32 bank = (bbank << 3) | sbank;
if(reg[0] & 4) {
setprg16(0x8000, bank);
setprg16(0xC000, bank);
} else
setprg32(0x8000, bank >> 1);
}
setmirror((reg[0] & 1) ^ 1);
}
static DECLFW(UNLDSOUNDV1Write) {
reg[A & 3] = V;
// FCEU_printf("cmd %04x:%02x\n", A, V);
Sync();
}
static DECLFW(UNLDSOUNDV1WriteSnd) {
if(A == 0x5800) {
if(V & 0xF0) {
pcm_enable = 1;
// pcmwrite(0x4011, (V & 0xF) << 3);
pcmwrite(0x4011, decode(V & 0xf));
} else
pcm_enable = 0;
} else
FCEU_printf("misc %04x:%02x\n", A, V);
}
static DECLFR(UNLDSOUNDV1ReadSnd) {
if(A == 0x5800)
return (X.DB & 0xBF) | ((pcm_enable ^ 1) <<6);
else
return X.DB;
}
static void UNLDSOUNDV1Power(void) {
reg[0] = reg[1] = reg[2] = reg[3] = 0;
Sync();
pcmwrite = GetWriteHandler(0x4011);
SetWriteHandler(0x4800, 0x4fff, UNLDSOUNDV1Write);
SetWriteHandler(0x5800, 0x5fff, UNLDSOUNDV1WriteSnd);
SetReadHandler(0x5800, 0x5fff, UNLDSOUNDV1ReadSnd);
SetReadHandler(0x6000, 0x7fff, CartBR);
SetWriteHandler(0x6000, 0x7fff, CartBW);
SetReadHandler(0x8000, 0xffff, CartBR);
}
static void UNLDSOUNDV1SndClk(int a) {
if (pcm_enable) {
pcm_latch -= a;
if (pcm_latch <= 0) {
pcm_latch += pcm_clock;
pcm_enable = 0;
}
}
}
static void UNLDSOUNDV1Close(void) {
if (WRAM)
FCEU_gfree(WRAM);
WRAM = NULL;
}
static void StateRestore(int version) {
Sync();
}
void UNLDSOUNDV1_Init(CartInfo *info) {
info->Power = UNLDSOUNDV1Power;
info->Close = UNLDSOUNDV1Close;
GameStateRestore = StateRestore;
MapIRQHook = UNLDSOUNDV1SndClk;
jedi_table_init();
WRAMSIZE = 32768;
WRAM = (uint8*)FCEU_gmalloc(WRAMSIZE);
SetupCartPRGMapping(0x10, WRAM, WRAMSIZE, 1);
AddExState(WRAM, WRAMSIZE, 0, "WRAM");
if (info->battery) {
info->SaveGame[0] = WRAM;
info->SaveGameLen[0] = WRAMSIZE;
}
AddExState(&StateRegs, ~0, 0, 0);
}

View File

@ -749,8 +749,9 @@ static void M115CW(uint32 A, uint8 V) {
} }
static DECLFW(M115Write) { static DECLFW(M115Write) {
if (A == 0x5080) EXPREGS[2] = V; if (A == 0x5080)
if (A == 0x6000) EXPREGS[2] = V; // Extra prot hardware 2-in-1 mode
else if (A == 0x6000)
EXPREGS[0] = V; EXPREGS[0] = V;
else if (A == 0x6001) else if (A == 0x6001)
EXPREGS[1] = V; EXPREGS[1] = V;
@ -772,7 +773,7 @@ void Mapper115_Init(CartInfo *info) {
cwrap = M115CW; cwrap = M115CW;
pwrap = M115PW; pwrap = M115PW;
info->Power = M115Power; info->Power = M115Power;
AddExState(EXPREGS, 2, 0, "EXPR"); AddExState(EXPREGS, 3, 0, "EXPR");
} }
// ---------------------------- Mapper 118 ------------------------------ // ---------------------------- Mapper 118 ------------------------------
@ -986,25 +987,18 @@ void Mapper195_Init(CartInfo *info) {
// game // game
static void M196PW(uint32 A, uint8 V) { static void M196PW(uint32 A, uint8 V) {
if (EXPREGS[0]) // Tenchi o Kurau II - Shokatsu Koumei Den (J) (C).nes if (EXPREGS[0])
setprg32(0x8000, EXPREGS[1]); setprg32(0x8000, EXPREGS[1]);
else else
setprg8(A, V); setprg8(A, V);
// setprg8(A,(V&3)|((V&8)>>1)|((V&4)<<1)); // Mali Splash Bomb
} }
//static void M196CW(uint32 A, uint8 V)
//{
// setchr1(A,(V&0xDD)|((V&0x20)>>4)|((V&2)<<4));
//}
static DECLFW(Mapper196Write) { static DECLFW(Mapper196Write) {
if (A >= 0xC000) { if (A >= 0xC000) {
A = (A & 0xFFFE) | ((A >> 2) & 1) | ((A >> 3) & 1); A = (A & 0xFFFE) | ((A >> 2) & 1) | ((A >> 3) & 1);
MMC3_IRQWrite(A, V); MMC3_IRQWrite(A, V);
} else { } else {
A = (A & 0xFFFE) | ((A >> 2) & 1) | ((A >> 3) & 1) | ((A >> 1) & 1); A = (A & 0xFFFE) | ((A >> 2) & 1) | ((A >> 3) & 1) | ((A >> 1) & 1);
// A=(A&0xFFFE)|((A>>3)&1); // Mali Splash Bomb
MMC3_CMDWrite(A, V); MMC3_CMDWrite(A, V);
} }
} }
@ -1025,10 +1019,44 @@ static void Mapper196Power(void) {
void Mapper196_Init(CartInfo *info) { void Mapper196_Init(CartInfo *info) {
GenMMC3_Init(info, 128, 128, 0, 0); GenMMC3_Init(info, 128, 128, 0, 0);
pwrap = M196PW; pwrap = M196PW;
// cwrap=M196CW; // Mali Splash Bomb
info->Power = Mapper196Power; info->Power = Mapper196Power;
} }
// ---------------------------- Mali Splash Bomb----------------------------
// The same board as for 196 mapper games, but with additional data bit swap
// Also, it is impossible to work on the combined 196 mapper source with
// all data bits merged, because it's using one of them as 8000 reg...
static void UNLMaliSBPW(uint32 A, uint8 V) {
setprg8(A, (V & 3)|((V & 8) >> 1)|((V & 4) << 1));
}
static void UNLMaliSBCW(uint32 A, uint8 V) {
setchr1(A, (V & 0xDD) | ((V & 0x20) >> 4) | ((V & 2) << 4));
}
static DECLFW(UNLMaliSBWrite) {
if (A >= 0xC000) {
A = (A & 0xFFFE) | ((A >> 2) & 1) | ((A >> 3) & 1);
MMC3_IRQWrite(A, V);
} else {
A = (A & 0xFFFE) | ((A >> 3) & 1);
MMC3_CMDWrite(A, V);
}
}
static void UNLMaliSBPower(void) {
GenMMC3Power();
SetWriteHandler(0x8000, 0xFFFF, UNLMaliSBWrite);
}
void UNLMaliSB_Init(CartInfo *info) {
GenMMC3_Init(info, 128, 128, 0, 0);
pwrap = UNLMaliSBPW;
cwrap = UNLMaliSBCW;
info->Power = UNLMaliSBPower;
}
// ---------------------------- Mapper 197 ------------------------------- // ---------------------------- Mapper 197 -------------------------------
static void M197CW(uint32 A, uint8 V) { static void M197CW(uint32 A, uint8 V) {

View File

@ -228,7 +228,7 @@
{0x2447e03b, 210, 1}, /* Top Striker */ {0x2447e03b, 210, 1}, /* Top Striker */
{0x1dc0f740, 210, 1}, /* Wagyan Land 2 */ {0x1dc0f740, 210, 1}, /* Wagyan Land 2 */
{0xd323b806, 210, 1}, /* Wagyan Land 3 */ {0xd323b806, 210, 1}, /* Wagyan Land 3 */
{0xbd523011, 210, 2}, /* Dream Master */ {0xbd523011, 210, 0}, /* Dream Master */
{0x5daae69a, 211, -1}, /* Aladdin - Return of Jaffar, The (Unl) [!] */ {0x5daae69a, 211, -1}, /* Aladdin - Return of Jaffar, The (Unl) [!] */
{0x1ec1dfeb, 217, -1}, /* 255-in-1 (Cut version) [p1] */ {0x1ec1dfeb, 217, -1}, /* 255-in-1 (Cut version) [p1] */
{0x046d70cc, 217, -1}, /* 500-in-1 (Anim Splash, Alt Mapper)[p1][!] */ {0x046d70cc, 217, -1}, /* 500-in-1 (Anim Splash, Alt Mapper)[p1][!] */

View File

@ -45,7 +45,7 @@
extern SFORMAT FCEUVSUNI_STATEINFO[]; extern SFORMAT FCEUVSUNI_STATEINFO[];
//mbg merge 6/29/06 - these need to be global //mbg merge 6/29/06 - these need to be global
uint8 *trainerpoo = 0; uint8 *trainerpoo = NULL;
uint8 *ROM = NULL; uint8 *ROM = NULL;
uint8 *VROM = NULL; uint8 *VROM = NULL;
uint8 *ExtraNTARAM = NULL; uint8 *ExtraNTARAM = NULL;
@ -234,7 +234,6 @@ struct BADINF {
uint32 type; uint32 type;
}; };
static struct BADINF BadROMImages[] = static struct BADINF BadROMImages[] =
{ {
#include "ines-bad.h" #include "ines-bad.h"
@ -719,6 +718,9 @@ int iNESLoad(const char *name, FCEUFILE *fp, int OverwriteVidMode) {
MapperNo = (head.ROM_type >> 4); MapperNo = (head.ROM_type >> 4);
MapperNo |= (head.ROM_type2 & 0xF0); MapperNo |= (head.ROM_type2 & 0xF0);
if (head.ROM_type & 8) {
Mirroring = 2;
} else
Mirroring = (head.ROM_type & 1); Mirroring = (head.ROM_type & 1);
if (!head.ROM_size) if (!head.ROM_size)
@ -741,10 +743,6 @@ int iNESLoad(const char *name, FCEUFILE *fp, int OverwriteVidMode) {
} }
} }
if (head.ROM_type & 8) {
Mirroring = 2;
}
if ((ROM = (uint8*)FCEU_malloc(ROM_size << 14)) == NULL) if ((ROM = (uint8*)FCEU_malloc(ROM_size << 14)) == NULL)
return 0; return 0;
memset(ROM, 0xFF, ROM_size << 14); memset(ROM, 0xFF, ROM_size << 14);

View File

@ -74,7 +74,7 @@ static uint8 *malloced[32];
static uint32 mallocedsizes[32]; static uint32 mallocedsizes[32];
static int FixRomSize(uint32 size, uint32 minimum) { static int FixRomSize(uint32 size, uint32 minimum) {
uint32 x = 1; //mbg merge 7/17/06 made uint uint32 x = 1;
if (size < minimum) if (size < minimum)
return minimum; return minimum;
@ -348,6 +348,7 @@ static BMAPPING bmap[] = {
{ "DANCE", UNLOneBus_Init, 0 }, // redundant { "DANCE", UNLOneBus_Init, 0 }, // redundant
{ "DANCE2000", UNLD2000_Init, 0 }, { "DANCE2000", UNLD2000_Init, 0 },
{ "DREAMTECH01", DreamTech01_Init, 0 }, { "DREAMTECH01", DreamTech01_Init, 0 },
{ "DSOUNDV1", UNLDSOUNDV1_Init, 0 },
{ "EDU2000", UNLEDU2000_Init, 0 }, { "EDU2000", UNLEDU2000_Init, 0 },
{ "EKROM", EKROM_Init, 0 }, { "EKROM", EKROM_Init, 0 },
{ "ELROM", ELROM_Init, 0 }, { "ELROM", ELROM_Init, 0 },
@ -377,6 +378,7 @@ static BMAPPING bmap[] = {
{ "LH10", LH10_Init, 0 }, { "LH10", LH10_Init, 0 },
{ "LH32", LH32_Init, 0 }, { "LH32", LH32_Init, 0 },
{ "LH53", LH53_Init, 0 }, { "LH53", LH53_Init, 0 },
{ "MALISB", UNLMaliSB_Init, 0 },
{ "MARIO1-MALEE2", MALEE_Init, 0 }, { "MARIO1-MALEE2", MALEE_Init, 0 },
{ "MHROM", MHROM_Init, 0 }, { "MHROM", MHROM_Init, 0 },
{ "N625092", UNLN625092_Init, 0 }, { "N625092", UNLN625092_Init, 0 },

View File

@ -105,6 +105,7 @@ void TSROM_Init(CartInfo *info);
void Transformer_Init(CartInfo *info); void Transformer_Init(CartInfo *info);
void UNL22211_Init(CartInfo *info); void UNL22211_Init(CartInfo *info);
void UNL3DBlock_Init(CartInfo *info); void UNL3DBlock_Init(CartInfo *info);
void UNLDSOUNDV1_Init(CartInfo *info);
void UNL43272_Init(CartInfo *info); void UNL43272_Init(CartInfo *info);
void UNL6035052_Init(CartInfo *info); void UNL6035052_Init(CartInfo *info);
void UNL8157_Init(CartInfo *info); void UNL8157_Init(CartInfo *info);
@ -129,6 +130,7 @@ void UNLKS7032_Init(CartInfo *info);
void UNLKS7037_Init(CartInfo *info); void UNLKS7037_Init(CartInfo *info);
void UNLKS7057_Init(CartInfo *info); void UNLKS7057_Init(CartInfo *info);
void UNLN625092_Init(CartInfo *info); void UNLN625092_Init(CartInfo *info);
void UNLMaliSB_Init(CartInfo *info);
void UNLOneBus_Init(CartInfo *info); void UNLOneBus_Init(CartInfo *info);
void UNLPEC586Init(CartInfo *info); void UNLPEC586Init(CartInfo *info);
void UNLSC127_Init(CartInfo *info); void UNLSC127_Init(CartInfo *info);

View File

@ -308,6 +308,7 @@
<ClCompile Include="..\src\boards\bb.cpp" /> <ClCompile Include="..\src\boards\bb.cpp" />
<ClCompile Include="..\src\boards\cityfighter.cpp" /> <ClCompile Include="..\src\boards\cityfighter.cpp" />
<ClCompile Include="..\src\boards\dance2000.cpp" /> <ClCompile Include="..\src\boards\dance2000.cpp" />
<ClCompile Include="..\src\boards\dsoundv1.cpp" />
<ClCompile Include="..\src\boards\famicombox.cpp" /> <ClCompile Include="..\src\boards\famicombox.cpp" />
<ClCompile Include="..\src\boards\ffe.cpp" /> <ClCompile Include="..\src\boards\ffe.cpp" />
<ClCompile Include="..\src\boards\ks7012.cpp" /> <ClCompile Include="..\src\boards\ks7012.cpp" />

View File

@ -952,6 +952,9 @@
<ClCompile Include="..\src\boards\vrc6.cpp"> <ClCompile Include="..\src\boards\vrc6.cpp">
<Filter>boards</Filter> <Filter>boards</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\src\boards\dsoundv1.cpp">
<Filter>boards</Filter>
</ClCompile>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ClInclude Include="..\src\drivers\common\args.h"> <ClInclude Include="..\src\drivers\common\args.h">