mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 16:29:37 -04:00 
			
		
		
		
	deal with some strict aliasing issues
This commit is contained in:
		
							parent
							
								
									a76fad4129
								
							
						
					
					
						commit
						895d15121b
					
				
					 6 changed files with 38 additions and 17 deletions
				
			
		|  | @ -1208,9 +1208,9 @@ static u32 sh2_read8_cs0(u32 a, SH2 *sh2) | |||
| 
 | ||||
|   // TODO: mirroring?
 | ||||
|   if (!sh2->is_slave && a < sizeof(Pico32xMem->sh2_rom_m)) | ||||
|     return Pico32xMem->sh2_rom_m[a ^ 1]; | ||||
|     return Pico32xMem->sh2_rom_m.b[a ^ 1]; | ||||
|   if (sh2->is_slave  && a < sizeof(Pico32xMem->sh2_rom_s)) | ||||
|     return Pico32xMem->sh2_rom_s[a ^ 1]; | ||||
|     return Pico32xMem->sh2_rom_s.b[a ^ 1]; | ||||
| 
 | ||||
|   if ((a & 0x3fe00) == 0x4200) { | ||||
|     d = Pico32xMem->pal[(a & 0x1ff) / 2]; | ||||
|  | @ -1263,9 +1263,9 @@ static u32 sh2_read16_cs0(u32 a, SH2 *sh2) | |||
|   } | ||||
| 
 | ||||
|   if (!sh2->is_slave && a < sizeof(Pico32xMem->sh2_rom_m)) | ||||
|     return *(u16 *)(Pico32xMem->sh2_rom_m + a); | ||||
|     return Pico32xMem->sh2_rom_m.w[a / 2]; | ||||
|   if (sh2->is_slave  && a < sizeof(Pico32xMem->sh2_rom_s)) | ||||
|     return *(u16 *)(Pico32xMem->sh2_rom_s + a); | ||||
|     return Pico32xMem->sh2_rom_s.w[a / 2]; | ||||
| 
 | ||||
|   if ((a & 0x3fe00) == 0x4200) { | ||||
|     d = Pico32xMem->pal[(a & 0x1ff) / 2]; | ||||
|  | @ -1619,17 +1619,17 @@ static void get_bios(void) | |||
|   // MSH2
 | ||||
|   if (p32x_bios_m != NULL) { | ||||
|     elprintf(EL_STATUS|EL_32X, "32x: using supplied master SH2 BIOS"); | ||||
|     Byteswap(Pico32xMem->sh2_rom_m, p32x_bios_m, sizeof(Pico32xMem->sh2_rom_m)); | ||||
|     Byteswap(&Pico32xMem->sh2_rom_m, p32x_bios_m, sizeof(Pico32xMem->sh2_rom_m)); | ||||
|   } | ||||
|   else { | ||||
|     pl = (u32 *)Pico32xMem->sh2_rom_m; | ||||
|     pl = (u32 *)&Pico32xMem->sh2_rom_m; | ||||
| 
 | ||||
|     // fill exception vector table to our trap address
 | ||||
|     for (i = 0; i < 128; i++) | ||||
|       pl[i] = HWSWAP(0x200); | ||||
| 
 | ||||
|     // startup code
 | ||||
|     memcpy(Pico32xMem->sh2_rom_m + 0x200, msh2_code, sizeof(msh2_code)); | ||||
|     memcpy(&Pico32xMem->sh2_rom_m.b[0x200], msh2_code, sizeof(msh2_code)); | ||||
| 
 | ||||
|     // reset SP
 | ||||
|     pl[1] = pl[3] = HWSWAP(0x6040000); | ||||
|  | @ -1640,17 +1640,17 @@ static void get_bios(void) | |||
|   // SSH2
 | ||||
|   if (p32x_bios_s != NULL) { | ||||
|     elprintf(EL_STATUS|EL_32X, "32x: using supplied slave SH2 BIOS"); | ||||
|     Byteswap(Pico32xMem->sh2_rom_s, p32x_bios_s, sizeof(Pico32xMem->sh2_rom_s)); | ||||
|     Byteswap(&Pico32xMem->sh2_rom_s, p32x_bios_s, sizeof(Pico32xMem->sh2_rom_s)); | ||||
|   } | ||||
|   else { | ||||
|     pl = (u32 *)Pico32xMem->sh2_rom_s; | ||||
|     pl = (u32 *)&Pico32xMem->sh2_rom_s; | ||||
| 
 | ||||
|     // fill exception vector table to our trap address
 | ||||
|     for (i = 0; i < 128; i++) | ||||
|       pl[i] = HWSWAP(0x200); | ||||
| 
 | ||||
|     // startup code
 | ||||
|     memcpy(Pico32xMem->sh2_rom_s + 0x200, ssh2_code, sizeof(ssh2_code)); | ||||
|     memcpy(&Pico32xMem->sh2_rom_s.b[0x200], ssh2_code, sizeof(ssh2_code)); | ||||
| 
 | ||||
|     // reset SP
 | ||||
|     pl[1] = pl[3] = HWSWAP(0x603f800); | ||||
|  |  | |||
|  | @ -43,7 +43,7 @@ PICO_INTERNAL int PicoResetMCD(void) | |||
|   memset(&Pico_mcd->pcm, 0, sizeof(Pico_mcd->pcm)); | ||||
|   memset(&Pico_mcd->m, 0, sizeof(Pico_mcd->m)); | ||||
| 
 | ||||
|   *(unsigned int *)(Pico_mcd->bios + 0x70) = 0xffffffff; // reset hint vector (simplest way to implement reg6)
 | ||||
|   memset(Pico_mcd->bios + 0x70, 0xff, 4); // reset hint vector (simplest way to implement reg6)
 | ||||
|   Pico_mcd->m.state_flags |= 1; // s68k reset pending
 | ||||
|   Pico_mcd->s68k_regs[3] = 1; // 2M word RAM mode with m68k access after reset
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -441,6 +441,7 @@ typedef struct | |||
| 		unsigned char pcm_ram[0x10000]; | ||||
| 		unsigned char pcm_ram_b[0x10][0x1000]; | ||||
| 	}; | ||||
| 	// FIXME: should be short
 | ||||
| 	unsigned char s68k_regs[0x200];			// 110000: GA, not CPU regs
 | ||||
| 	unsigned char bram[0x2000];			// 110200: 8K
 | ||||
| 	struct mcd_misc m;				// 112200: misc
 | ||||
|  | @ -543,8 +544,14 @@ struct Pico32xMem | |||
| #ifdef DRC_SH2 | ||||
|   unsigned short drcblk_da[2][1 << (12 - SH2_DRCBLK_DA_SHIFT)]; | ||||
| #endif | ||||
|   unsigned char  sh2_rom_m[0x800]; | ||||
|   unsigned char  sh2_rom_s[0x400]; | ||||
|   union { | ||||
|     unsigned char  b[0x800]; | ||||
|     unsigned short w[0x800/2]; | ||||
|   } sh2_rom_m; | ||||
|   union { | ||||
|     unsigned char  b[0x400]; | ||||
|     unsigned short w[0x400/2]; | ||||
|   } sh2_rom_s; | ||||
|   unsigned short pal[0x100]; | ||||
|   unsigned short pal_native[0x100];     // converted to native (for renderer)
 | ||||
|   signed short   pwm[2*PWM_BUFF_LEN];   // PWM buffer for current frame
 | ||||
|  |  | |||
|  | @ -290,7 +290,8 @@ static int state_save(void *file) | |||
|     SekPackCpu(buff, 1); | ||||
|     if (Pico_mcd->s68k_regs[3] & 4) // 1M mode?
 | ||||
|       wram_1M_to_2M(Pico_mcd->word_ram2M); | ||||
|     Pico_mcd->m.hint_vector = *(unsigned short *)(Pico_mcd->bios + 0x72); | ||||
|     memcpy(&Pico_mcd->m.hint_vector, Pico_mcd->bios + 0x72, | ||||
|       sizeof(Pico_mcd->m.hint_vector)); | ||||
| 
 | ||||
|     CHECKED_WRITE_BUFF(CHUNK_S68K,     buff); | ||||
|     CHECKED_WRITE_BUFF(CHUNK_PRG_RAM,  Pico_mcd->prg_ram); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 notaz
						notaz