mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 08:19:38 -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
	
	 kub
						kub