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 | 	url = https://github.com/irixxxx/libpicofe.git | ||||||
| [submodule "cpu/cyclone"] | [submodule "cpu/cyclone"] | ||||||
| 	path = cpu/cyclone | 	path = cpu/cyclone | ||||||
| 	url = https://github.com/notaz/cyclone68000.git | 	url = https://github.com/irixxxx/cyclone68000.git | ||||||
| [submodule "pico/sound/emu2413"] | [submodule "pico/sound/emu2413"] | ||||||
| 	path = pico/sound/emu2413 | 	path = pico/sound/emu2413 | ||||||
| 	url = https://github.com/digital-sound-antiques/emu2413.git | 	url = https://github.com/digital-sound-antiques/emu2413.git | ||||||
|  |  | ||||||
|  | @ -1 +1 @@ | ||||||
| Subproject commit 425e3a4066ee1cc8a3bae28956fbbdc9a516001d | Subproject commit ee45bb2b10b3abf10a4335ea24fc029e3f61c10a | ||||||
|  | @ -183,6 +183,11 @@ | ||||||
| // internals core macros
 | // 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 XB		MEM_LE4(0) | ||||||
| #define XW		MEM_LE2(0) | #define XW		MEM_LE2(0) | ||||||
| 
 | 
 | ||||||
|  | @ -525,13 +530,13 @@ static const s32 exception_cycle_table[256] = | ||||||
| 	 50, //  2: Bus Error
 | 	 50, //  2: Bus Error
 | ||||||
| 	 50, //  3: Address Error
 | 	 50, //  3: Address Error
 | ||||||
| 	 34, //  4: Illegal Instruction
 | 	 34, //  4: Illegal Instruction
 | ||||||
| 	 38, //  5: Divide by Zero
 | 	 34, //  5: Divide by Zero
 | ||||||
| 	 40, //  6: CHK
 | 	 34, //  6: CHK
 | ||||||
| 	 34, //  7: TRAPV
 | 	 34, //  7: TRAPV
 | ||||||
| 	 34, //  8: Privilege Violation
 | 	 34, //  8: Privilege Violation
 | ||||||
| 	 34, //  9: Trace
 | 	 34, //  9: Trace
 | ||||||
| 	  4, // 10:
 | 	 34, // 10: Line A
 | ||||||
| 	  4, // 11:
 | 	 34, // 11: Line F
 | ||||||
| 	  4, // 12: RESERVED
 | 	  4, // 12: RESERVED
 | ||||||
| 	  4, // 13: Coprocessor Protocol Violation
 | 	  4, // 13: Coprocessor Protocol Violation
 | ||||||
| 	  4, // 14: Format Error
 | 	  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