mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 16:29:37 -04:00 
			
		
		
		
	core, add TH pad pin latency after switching to input
This commit is contained in:
		
							parent
							
								
									54f74b8100
								
							
						
					
					
						commit
						66e9abff6d
					
				
					 1 changed files with 9 additions and 4 deletions
				
			
		|  | @ -314,6 +314,8 @@ static port_read_func *port_readers[3] = { | |||
|   read_nothing | ||||
| }; | ||||
| 
 | ||||
| static int padTHLatency[3]; | ||||
| 
 | ||||
| static NOINLINE u32 port_read(int i) | ||||
| { | ||||
|   u32 data_reg = PicoMem.ioports[i + 1]; | ||||
|  | @ -326,10 +328,8 @@ static NOINLINE u32 port_read(int i) | |||
|   // disables output before doing TH-low read, so don't emulate it for TH.
 | ||||
|   // Decap Attack reportedly doesn't work on Nomad but works on must
 | ||||
|   // other MD revisions (different pull-up strength?).
 | ||||
|   if (PicoIn.AHW & (PAHW_32X|PAHW_MCD)) // don't do it on 32X, it breaks WWF Raw
 | ||||
|     out |= 0x7f & ~ctrl_reg; | ||||
|   else | ||||
|     out |= 0x3f & ~ctrl_reg; | ||||
|   u32 mask = 0x3f | (padTHLatency[i] < SekCyclesDone() ? 0x40 : 0); | ||||
|   out |= mask & ~ctrl_reg; | ||||
| 
 | ||||
|   in = port_readers[i](i, out); | ||||
| 
 | ||||
|  | @ -407,6 +407,11 @@ NOINLINE void io_ports_write(u32 a, u32 d) | |||
|       Pico.m.padTHPhase[a - 1]++; | ||||
|   } | ||||
| 
 | ||||
|   // after pulling down TH there's a latency before the new value can be read
 | ||||
|   // back as input (see Decap Attack, not in Samurai Showdown, 32x WWF Raw)
 | ||||
|   if (a >= 4 && a <= 5 && !(d & 0x40)) | ||||
|     padTHLatency[a - 4] = SekCyclesDone() + 25; | ||||
| 
 | ||||
|   // certain IO ports can be used as RAM
 | ||||
|   PicoMem.ioports[a] = d; | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 kub
						kub