mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 16:29:37 -04:00 
			
		
		
		
	core, fix 68k cycles in cyclone,fame (exceptions,bit ops,ADDI.L,TAS,CHK,MUL*,DIV*)
also syncs these changes between fame and cyclone in accordance with the test_inst_speed, available here: https://gendev.spritesmind.net/forum/viewtopic.php?t=3321 DIV* is only closely approximated, it can be slightly on the high side.
This commit is contained in:
		
							parent
							
								
									02d578601b
								
							
						
					
					
						commit
						3f5918225a
					
				
					 4 changed files with 522 additions and 312 deletions
				
			
		
							
								
								
									
										2
									
								
								.gitmodules
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitmodules
									
										
									
									
										vendored
									
									
								
							|  | @ -3,7 +3,7 @@ | |||
| 	url = https://github.com/irixxxx/libpicofe.git | ||||
| [submodule "cpu/cyclone"] | ||||
| 	path = cpu/cyclone | ||||
| 	url = https://github.com/notaz/cyclone68000.git | ||||
| 	url = https://github.com/irixxxx/cyclone68000.git | ||||
| [submodule "pico/sound/emu2413"] | ||||
| 	path = pico/sound/emu2413 | ||||
| 	url = https://github.com/digital-sound-antiques/emu2413.git | ||||
|  |  | |||
|  | @ -1 +1 @@ | |||
| Subproject commit 425e3a4066ee1cc8a3bae28956fbbdc9a516001d | ||||
| Subproject commit ee45bb2b10b3abf10a4335ea24fc029e3f61c10a | ||||
|  | @ -183,6 +183,11 @@ | |||
| // internals core macros
 | ||||
| /////////////////////////
 | ||||
| 
 | ||||
| // helper macros
 | ||||
| #define BITCOUNT(r,v)	\ | ||||
|     (r = (v) - (((v)>>1)&0x55555555), r = (r&0x33333333) + ((r>>2)&0x33333333), \ | ||||
|      r = (((r + (r>>4))&0x0f0f0f0f) * 0x01010101)>>24) | ||||
| 
 | ||||
| #define XB		MEM_LE4(0) | ||||
| #define XW		MEM_LE2(0) | ||||
| 
 | ||||
|  | @ -525,13 +530,13 @@ static const s32 exception_cycle_table[256] = | |||
| 	 50, //  2: Bus Error
 | ||||
| 	 50, //  3: Address Error
 | ||||
| 	 34, //  4: Illegal Instruction
 | ||||
| 	 38, //  5: Divide by Zero
 | ||||
| 	 40, //  6: CHK
 | ||||
| 	 34, //  5: Divide by Zero
 | ||||
| 	 34, //  6: CHK
 | ||||
| 	 34, //  7: TRAPV
 | ||||
| 	 34, //  8: Privilege Violation
 | ||||
| 	 34, //  9: Trace
 | ||||
| 	  4, // 10:
 | ||||
| 	  4, // 11:
 | ||||
| 	 34, // 10: Line A
 | ||||
| 	 34, // 11: Line F
 | ||||
| 	  4, // 12: RESERVED
 | ||||
| 	  4, // 13: Coprocessor Protocol Violation
 | ||||
| 	  4, // 14: Format Error
 | ||||
|  |  | |||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 kub
						kub