mirror of
https://github.com/RaySollium99/picodrive.git
synced 2025-09-05 23:37:46 -04:00
Radica mapper added
git-svn-id: file:///home/notaz/opt/svn/PicoDrive@482 be3aeb3a-fb24-0410-a615-afba39da0efa
This commit is contained in:
parent
1832075ec7
commit
0b35350da6
3 changed files with 70 additions and 2 deletions
|
@ -707,6 +707,12 @@ static void PicoCartDetect(void)
|
||||||
carthw_realtec_startup();
|
carthw_realtec_startup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Radica mapper
|
||||||
|
else if (name_cmp("KID CHAMELEON") == 0 && Pico.romsize > 0x100000)
|
||||||
|
{
|
||||||
|
carthw_radica_startup();
|
||||||
|
}
|
||||||
|
|
||||||
// Some games malfunction if SRAM is not filled with 0xff
|
// Some games malfunction if SRAM is not filled with 0xff
|
||||||
if (name_cmp("DINO DINI'S SOCCER") == 0 ||
|
if (name_cmp("DINO DINI'S SOCCER") == 0 ||
|
||||||
name_cmp("MICRO MACHINES II") == 0)
|
name_cmp("MICRO MACHINES II") == 0)
|
||||||
|
|
|
@ -44,7 +44,7 @@ static void carthw_12in1_write8(unsigned int a, unsigned int d, int realsize)
|
||||||
a &= 0x3f; a <<= 16;
|
a &= 0x3f; a <<= 16;
|
||||||
len = Pico.romsize - a;
|
len = Pico.romsize - a;
|
||||||
if (len <= 0) {
|
if (len <= 0) {
|
||||||
elprintf(EL_ANOMALY, "12-in-1: missing bank @ %06x", a);
|
elprintf(EL_ANOMALY|EL_STATUS, "12-in-1: missing bank @ %06x", a);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -132,7 +132,7 @@ static void carthw_realtec_write8(unsigned int a, unsigned int d, int realsize)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void carthw_realtec_reset(void)
|
static void carthw_realtec_reset(void)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
/* map boot code */
|
/* map boot code */
|
||||||
|
@ -162,3 +162,64 @@ void carthw_realtec_startup(void)
|
||||||
PicoResetHook = carthw_realtec_reset;
|
PicoResetHook = carthw_realtec_reset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Radica mapper, based on DevSter's info
|
||||||
|
* http://devster.monkeeh.com/sega/radica/
|
||||||
|
*/
|
||||||
|
static unsigned int carthw_radica_baddr = 0;
|
||||||
|
|
||||||
|
static carthw_state_chunk carthw_radica_state[] =
|
||||||
|
{
|
||||||
|
{ CHUNK_CARTHW, sizeof(carthw_radica_baddr), &carthw_radica_baddr },
|
||||||
|
{ 0, 0, NULL }
|
||||||
|
};
|
||||||
|
|
||||||
|
static unsigned int carthw_radica_read16(unsigned int a, int realsize)
|
||||||
|
{
|
||||||
|
if ((a & 0xffff80) != 0xa13000) {
|
||||||
|
elprintf(EL_UIO, "radica: r16 %06x", a);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
carthw_radica_baddr = a;
|
||||||
|
a = (a & 0x7e) << 15;
|
||||||
|
if (a >= Pico.romsize) {
|
||||||
|
elprintf(EL_ANOMALY|EL_STATUS, "radica: missing bank @ %06x", a);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
memcpy(Pico.rom, Pico.rom + Pico.romsize + a, Pico.romsize - a);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void carthw_radica_statef(void)
|
||||||
|
{
|
||||||
|
carthw_radica_read16(carthw_radica_baddr, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void carthw_radica_reset(void)
|
||||||
|
{
|
||||||
|
memcpy(Pico.rom, Pico.rom + Pico.romsize, Pico.romsize);
|
||||||
|
}
|
||||||
|
|
||||||
|
void carthw_radica_startup(void)
|
||||||
|
{
|
||||||
|
void *tmp;
|
||||||
|
|
||||||
|
elprintf(EL_STATUS, "Radica mapper detected");
|
||||||
|
|
||||||
|
tmp = realloc(Pico.rom, Pico.romsize * 2);
|
||||||
|
if (tmp == NULL)
|
||||||
|
{
|
||||||
|
elprintf(EL_STATUS, "OOM");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Pico.rom = tmp;
|
||||||
|
memcpy(Pico.rom + Pico.romsize, Pico.rom, Pico.romsize);
|
||||||
|
|
||||||
|
PicoRead16Hook = carthw_radica_read16;
|
||||||
|
PicoResetHook = carthw_radica_reset;
|
||||||
|
PicoLoadStateHook = carthw_radica_statef;
|
||||||
|
carthw_chunks = carthw_radica_state;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -20,3 +20,4 @@ void PicoSVPWrite16(unsigned int a, unsigned int d, int realsize);
|
||||||
/* misc */
|
/* misc */
|
||||||
void carthw_12in1_startup(void);
|
void carthw_12in1_startup(void);
|
||||||
void carthw_realtec_startup(void);
|
void carthw_realtec_startup(void);
|
||||||
|
void carthw_radica_startup(void);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue