mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 16:29:37 -04:00 
			
		
		
		
	32x, reset handling and synchronization changes
This commit is contained in:
		
							parent
							
								
									7e0c38c9c7
								
							
						
					
					
						commit
						eb990fd62a
					
				
					 3 changed files with 6 additions and 23 deletions
				
			
		|  | @ -212,6 +212,7 @@ void PicoReset32x(void) | |||
|     p32x_sh2_poll_event(&ssh2, SH2_IDLE_STATES, SekCyclesDone()); | ||||
|     p32x_pwm_ctl_changed(); | ||||
|     p32x_timers_recalc(); | ||||
|     Pico32x.vdp_regs[0] &= ~P32XV_Mx; // 32X graphics disabled
 | ||||
|   } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -59,7 +59,7 @@ static void (*m68k_write16_io)(u32 a, u32 d); | |||
| #define REG8IN16(ptr, offs) ((u8 *)ptr)[MEM_BE2(offs)] | ||||
| 
 | ||||
| // poll detection
 | ||||
| #define POLL_THRESHOLD 9  // cosmic carnage
 | ||||
| #define POLL_THRESHOLD 9  // Primal Rage
 | ||||
| 
 | ||||
| static struct { | ||||
|   u32 addr1, addr2, cycles; | ||||
|  | @ -203,7 +203,7 @@ static NOINLINE u32 sh2_poll_read(u32 a, u32 d, unsigned int cycles, SH2* sh2) | |||
|     idx = (idx+1) % PFIFO_SZ; | ||||
| 
 | ||||
|     if (cpu != p->cpu) { | ||||
|       if (CYCLES_GT(cycles, p->cycles+80)) { | ||||
|       if (CYCLES_GT(cycles, p->cycles+60)) { // ~180 sh2 cycles, Spiderman
 | ||||
|         // drop older fifo stores that may cause synchronisation problems.
 | ||||
|         p->a = -1; | ||||
|       } else if (p->a == a) { | ||||
|  | @ -1694,23 +1694,6 @@ static void REGPARM(3) sh2_write8_da(u32 a, u32 d, SH2 *sh2) | |||
| } | ||||
| #endif | ||||
| 
 | ||||
| static NOINLINE void REGPARM(3) sh2_write8_sdram_sync(u32 a, u32 d, SH2 *sh2) | ||||
| { | ||||
|   DRC_SAVE_SR(sh2); | ||||
|   sh2_end_run(sh2, 32); | ||||
|   DRC_RESTORE_SR(sh2); | ||||
|   sh2_write8_sdram(a, d, sh2); | ||||
| } | ||||
| 
 | ||||
| static void REGPARM(3) sh2_write8_sdram_wt(u32 a, u32 d, SH2 *sh2) | ||||
| { | ||||
|   // xmen sync hack..
 | ||||
|   if ((a << 8) >> 17) // ((a & 0x00ffffff) < 0x200)
 | ||||
|     sh2_write8_sdram(a, d, sh2); | ||||
|   else | ||||
|     sh2_write8_sdram_sync(a, d, sh2); | ||||
| } | ||||
| 
 | ||||
| // write16
 | ||||
| static void REGPARM(3) sh2_write16_unmapped(u32 a, u32 d, SH2 *sh2) | ||||
| { | ||||
|  | @ -2403,7 +2386,6 @@ void PicoMemSetup32x(void) | |||
|   msh2_read16_map[0x06/2].addr  = msh2_read16_map[0x26/2].addr  = | ||||
|   msh2_read32_map[0x06/2].addr  = msh2_read32_map[0x26/2].addr  = MAP_MEMORY(Pico32xMem->sdram); | ||||
|   msh2_write8_map[0x06/2]       = msh2_write8_map[0x26/2]       = sh2_write8_sdram; | ||||
|   msh2_write8_map[0x26/2]       = sh2_write8_sdram_wt; | ||||
| 
 | ||||
|   msh2_write16_map[0x06/2]      = msh2_write16_map[0x26/2]      = sh2_write16_sdram; | ||||
|   msh2_write32_map[0x06/2]      = msh2_write32_map[0x26/2]      = sh2_write32_sdram; | ||||
|  |  | |||
|  | @ -192,6 +192,9 @@ int PicoReset(void) | |||
| 
 | ||||
|   SekFinishIdleDet(); | ||||
| 
 | ||||
|   if (PicoIn.opt & POPT_EN_32X) | ||||
|     PicoReset32x(); | ||||
| 
 | ||||
|   if (PicoIn.AHW & PAHW_MCD) { | ||||
|     PicoResetMCD(); | ||||
|     return 0; | ||||
|  | @ -201,9 +204,6 @@ int PicoReset(void) | |||
|   if (!(PicoIn.opt & POPT_DIS_IDLE_DET)) | ||||
|     SekInitIdleDet(); | ||||
| 
 | ||||
|   if (PicoIn.opt & POPT_EN_32X) | ||||
|     PicoReset32x(); | ||||
| 
 | ||||
|   // reset sram state; enable sram access by default if it doesn't overlap with ROM
 | ||||
|   Pico.m.sram_reg = 0; | ||||
|   if ((Pico.sv.flags & SRF_EEPROM) || Pico.romsize <= Pico.sv.start) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 kub
						kub