mirror of
https://github.com/RaySollium99/picodrive.git
synced 2025-09-05 07:17:45 -04:00
32x, improve cartridge mapping, BIOS replication
This commit is contained in:
parent
44e4bf2b0f
commit
439cf7f850
2 changed files with 10 additions and 9 deletions
|
@ -145,13 +145,13 @@ void p32x_reset_sh2s(void)
|
|||
idl_src = CPU_BE2(*(u32 *)(Pico.rom + 0x3d4)) & ~0xf0000000;
|
||||
idl_dst = CPU_BE2(*(u32 *)(Pico.rom + 0x3d8)) & ~0xf0000000;
|
||||
idl_size= CPU_BE2(*(u32 *)(Pico.rom + 0x3dc));
|
||||
if (idl_size > Pico.romsize || idl_src + idl_size > Pico.romsize ||
|
||||
idl_size > 0x40000 || idl_dst + idl_size > 0x40000 || (idl_src & 3) || (idl_dst & 3)) {
|
||||
elprintf(EL_STATUS|EL_ANOMALY, "32x: invalid initial data ptrs: %06x -> %06x, %06x",
|
||||
idl_src, idl_dst, idl_size);
|
||||
// copy in guest memory space
|
||||
idl_src += 0x2000000;
|
||||
idl_dst += 0x6000000;
|
||||
while (idl_size >= 4) {
|
||||
p32x_sh2_write32(idl_dst, p32x_sh2_read32(idl_src, &msh2), &msh2);
|
||||
idl_src += 4, idl_dst += 4, idl_size -= 4;
|
||||
}
|
||||
else
|
||||
memcpy(Pico32xMem->sdram + idl_dst, Pico.rom + idl_src, idl_size);
|
||||
|
||||
// VBR
|
||||
vbr = CPU_BE2(*(u32 *)(Pico.rom + 0x3e8));
|
||||
|
|
|
@ -2382,9 +2382,10 @@ void PicoMemSetup32x(void)
|
|||
msh2_write32_map[0x00/2] = msh2_write32_map[0x20/2] = sh2_write32_cs0;
|
||||
// CS1 - ROM
|
||||
bank_switch_rom_sh2();
|
||||
msh2_read8_map[0x02/2].mask = msh2_read8_map[0x22/2].mask = 0x3fffff; // FIXME
|
||||
msh2_read16_map[0x02/2].mask = msh2_read16_map[0x22/2].mask = 0x3ffffe; // FIXME
|
||||
msh2_read32_map[0x02/2].mask = msh2_read32_map[0x22/2].mask = 0x3ffffc; // FIXME
|
||||
for (rs = 0x8000; rs < Pico.romsize && rs < 0x400000; rs *= 2) ;
|
||||
msh2_read8_map[0x02/2].mask = msh2_read8_map[0x22/2].mask = rs-1;
|
||||
msh2_read16_map[0x02/2].mask = msh2_read16_map[0x22/2].mask = rs-1;
|
||||
msh2_read32_map[0x02/2].mask = msh2_read32_map[0x22/2].mask = rs-1;
|
||||
msh2_write16_map[0x02/2] = msh2_write16_map[0x22/2] = sh2_write16_rom;
|
||||
msh2_write32_map[0x02/2] = msh2_write32_map[0x22/2] = sh2_write32_rom;
|
||||
// CS2 - DRAM
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue