Merge pull request #111 from davidgfnet/master
Remove BIOS reserved translation area
This commit is contained in:
		
						commit
						3dfdaaa8d9
					
				
					 8 changed files with 5 additions and 128 deletions
				
			
		|  | @ -440,8 +440,6 @@ _execute_swi_##mode:                                                          ;\ | ||||||
|   orr r0, r0, #0x13                       /* set to supervisor mode        */;\
 |   orr r0, r0, #0x13                       /* set to supervisor mode        */;\
 | ||||||
|   str r0, [reg_base, #REG_CPSR]           /* update cpsr                   */;\ |   str r0, [reg_base, #REG_CPSR]           /* update cpsr                   */;\ | ||||||
|                                                                              ;\
 |                                                                              ;\
 | ||||||
|   call_c_function(bios_region_read_allow)                                    ;\
 |  | ||||||
|                                                                              ;\
 |  | ||||||
|   mov r0, #MODE_SUPERVISOR                                                   ;\ |   mov r0, #MODE_SUPERVISOR                                                   ;\ | ||||||
|                                                                              ;\
 |                                                                              ;\
 | ||||||
|   store_registers_##mode()                /* store regs for mode           */;\ |   store_registers_##mode()                /* store regs for mode           */;\ | ||||||
|  |  | ||||||
							
								
								
									
										2
									
								
								cpu.c
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								cpu.c
									
										
									
									
									
								
							|  | @ -1639,8 +1639,6 @@ void raise_interrupt(irq_type irq_raised) | ||||||
|     reg[REG_CPSR] = 0xD2; |     reg[REG_CPSR] = 0xD2; | ||||||
|     reg[REG_PC] = 0x00000018; |     reg[REG_PC] = 0x00000018; | ||||||
| 
 | 
 | ||||||
|     bios_region_read_allow(); |  | ||||||
| 
 |  | ||||||
|     set_cpu_mode(MODE_IRQ); |     set_cpu_mode(MODE_IRQ); | ||||||
|     reg[CPU_HALT_STATE] = CPU_ACTIVE; |     reg[CPU_HALT_STATE] = CPU_ACTIVE; | ||||||
|     reg[CHANGED_PC_STATUS] = 1; |     reg[CHANGED_PC_STATUS] = 1; | ||||||
|  |  | ||||||
							
								
								
									
										10
									
								
								cpu.h
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								cpu.h
									
										
									
									
									
								
							|  | @ -90,7 +90,6 @@ typedef enum | ||||||
| { | { | ||||||
|   TRANSLATION_REGION_RAM, |   TRANSLATION_REGION_RAM, | ||||||
|   TRANSLATION_REGION_ROM, |   TRANSLATION_REGION_ROM, | ||||||
|   TRANSLATION_REGION_BIOS |  | ||||||
| } translation_region_type; | } translation_region_type; | ||||||
| 
 | 
 | ||||||
| extern u32 instruction_count; | extern u32 instruction_count; | ||||||
|  | @ -124,12 +123,10 @@ s32 translate_block_thumb(u32 pc, translation_region_type translation_region, | ||||||
| #if defined(PSP) | #if defined(PSP) | ||||||
|   #define ROM_TRANSLATION_CACHE_SIZE (1024 * 512 * 4) |   #define ROM_TRANSLATION_CACHE_SIZE (1024 * 512 * 4) | ||||||
|   #define RAM_TRANSLATION_CACHE_SIZE (1024 * 384) |   #define RAM_TRANSLATION_CACHE_SIZE (1024 * 384) | ||||||
|   #define BIOS_TRANSLATION_CACHE_SIZE (1024 * 128) |  | ||||||
|   #define TRANSLATION_CACHE_LIMIT_THRESHOLD (1024) |   #define TRANSLATION_CACHE_LIMIT_THRESHOLD (1024) | ||||||
| #else | #else | ||||||
|   #define ROM_TRANSLATION_CACHE_SIZE (1024 * 512 * 4 * 5) |   #define ROM_TRANSLATION_CACHE_SIZE (1024 * 512 * 4 * 5) | ||||||
|   #define RAM_TRANSLATION_CACHE_SIZE (1024 * 384 * 2) |   #define RAM_TRANSLATION_CACHE_SIZE (1024 * 384 * 2) | ||||||
|   #define BIOS_TRANSLATION_CACHE_SIZE (1024 * 128 * 2) |  | ||||||
|   #define TRANSLATION_CACHE_LIMIT_THRESHOLD (1024 * 32) |   #define TRANSLATION_CACHE_LIMIT_THRESHOLD (1024 * 32) | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | @ -138,28 +135,22 @@ s32 translate_block_thumb(u32 pc, translation_region_type translation_region, | ||||||
| #if defined(HAVE_MMAP) | #if defined(HAVE_MMAP) | ||||||
| extern u8* rom_translation_cache; | extern u8* rom_translation_cache; | ||||||
| extern u8* ram_translation_cache; | extern u8* ram_translation_cache; | ||||||
| extern u8* bios_translation_cache; |  | ||||||
| #elif defined(_3DS) | #elif defined(_3DS) | ||||||
| #define rom_translation_cache ((u8*)0x02000000 - ROM_TRANSLATION_CACHE_SIZE) | #define rom_translation_cache ((u8*)0x02000000 - ROM_TRANSLATION_CACHE_SIZE) | ||||||
| #define ram_translation_cache (rom_translation_cache - RAM_TRANSLATION_CACHE_SIZE) | #define ram_translation_cache (rom_translation_cache - RAM_TRANSLATION_CACHE_SIZE) | ||||||
| #define bios_translation_cache (ram_translation_cache - BIOS_TRANSLATION_CACHE_SIZE) |  | ||||||
| extern u8* rom_translation_cache_ptr; | extern u8* rom_translation_cache_ptr; | ||||||
| extern u8* ram_translation_cache_ptr; | extern u8* ram_translation_cache_ptr; | ||||||
| extern u8* bios_translation_cache_ptr; |  | ||||||
| #elif defined(VITA) | #elif defined(VITA) | ||||||
| extern u8* rom_translation_cache; | extern u8* rom_translation_cache; | ||||||
| extern u8* ram_translation_cache; | extern u8* ram_translation_cache; | ||||||
| extern u8* bios_translation_cache; |  | ||||||
| extern int sceBlock; | extern int sceBlock; | ||||||
| #else | #else | ||||||
| extern u8 rom_translation_cache[ROM_TRANSLATION_CACHE_SIZE]; | extern u8 rom_translation_cache[ROM_TRANSLATION_CACHE_SIZE]; | ||||||
| extern u8 ram_translation_cache[RAM_TRANSLATION_CACHE_SIZE]; | extern u8 ram_translation_cache[RAM_TRANSLATION_CACHE_SIZE]; | ||||||
| extern u8 bios_translation_cache[BIOS_TRANSLATION_CACHE_SIZE]; |  | ||||||
| extern u32 stub_arena[STUB_ARENA_SIZE]; | extern u32 stub_arena[STUB_ARENA_SIZE]; | ||||||
| #endif | #endif | ||||||
| extern u8 *rom_translation_ptr; | extern u8 *rom_translation_ptr; | ||||||
| extern u8 *ram_translation_ptr; | extern u8 *ram_translation_ptr; | ||||||
| extern u8 *bios_translation_ptr; |  | ||||||
| 
 | 
 | ||||||
| #define MAX_TRANSLATION_GATES 8 | #define MAX_TRANSLATION_GATES 8 | ||||||
| 
 | 
 | ||||||
|  | @ -182,7 +173,6 @@ extern u32 *rom_branch_hash[ROM_BRANCH_HASH_SIZE]; | ||||||
| 
 | 
 | ||||||
| void flush_translation_cache_rom(void); | void flush_translation_cache_rom(void); | ||||||
| void flush_translation_cache_ram(void); | void flush_translation_cache_ram(void); | ||||||
| void flush_translation_cache_bios(void); |  | ||||||
| void dump_translation_cache(void); | void dump_translation_cache(void); | ||||||
| 
 | 
 | ||||||
| extern u32 reg_mode[7][7]; | extern u32 reg_mode[7][7]; | ||||||
|  |  | ||||||
|  | @ -29,30 +29,23 @@ | ||||||
| 
 | 
 | ||||||
| u8 *last_rom_translation_ptr = NULL; | u8 *last_rom_translation_ptr = NULL; | ||||||
| u8 *last_ram_translation_ptr = NULL; | u8 *last_ram_translation_ptr = NULL; | ||||||
| u8 *last_bios_translation_ptr = NULL; |  | ||||||
| 
 | 
 | ||||||
| #if defined(HAVE_MMAP) | #if defined(HAVE_MMAP) | ||||||
| u8* rom_translation_cache; | u8* rom_translation_cache; | ||||||
| u8* ram_translation_cache; | u8* ram_translation_cache; | ||||||
| u8* bios_translation_cache; |  | ||||||
| u8 *rom_translation_ptr; | u8 *rom_translation_ptr; | ||||||
| u8 *ram_translation_ptr; | u8 *ram_translation_ptr; | ||||||
| u8 *bios_translation_ptr; |  | ||||||
| #elif defined(VITA) | #elif defined(VITA) | ||||||
| u8* rom_translation_cache; | u8* rom_translation_cache; | ||||||
| u8* ram_translation_cache; | u8* ram_translation_cache; | ||||||
| u8* bios_translation_cache; |  | ||||||
| u8 *rom_translation_ptr; | u8 *rom_translation_ptr; | ||||||
| u8 *ram_translation_ptr; | u8 *ram_translation_ptr; | ||||||
| u8 *bios_translation_ptr; |  | ||||||
| int sceBlock; | int sceBlock; | ||||||
| #elif defined(_3DS)  | #elif defined(_3DS)  | ||||||
| u8* rom_translation_cache_ptr; | u8* rom_translation_cache_ptr; | ||||||
| u8* ram_translation_cache_ptr; | u8* ram_translation_cache_ptr; | ||||||
| u8* bios_translation_cache_ptr; |  | ||||||
| u8 *rom_translation_ptr = rom_translation_cache; | u8 *rom_translation_ptr = rom_translation_cache; | ||||||
| u8 *ram_translation_ptr = ram_translation_cache; | u8 *ram_translation_ptr = ram_translation_cache; | ||||||
| u8 *bios_translation_ptr = bios_translation_cache; |  | ||||||
| #else | #else | ||||||
| 
 | 
 | ||||||
| #ifdef __ANDROID__ | #ifdef __ANDROID__ | ||||||
|  | @ -72,10 +65,6 @@ u8 ram_translation_cache[RAM_TRANSLATION_CACHE_SIZE] | ||||||
| 		__attribute__ ((aligned(4),section(".jit"))); | 		__attribute__ ((aligned(4),section(".jit"))); | ||||||
| u8 *ram_translation_ptr = ram_translation_cache; | u8 *ram_translation_ptr = ram_translation_cache; | ||||||
| 
 | 
 | ||||||
| u8 bios_translation_cache[BIOS_TRANSLATION_CACHE_SIZE] |  | ||||||
| 		__attribute__ ((aligned(4),section(".jit"))); |  | ||||||
| u8 *bios_translation_ptr = bios_translation_cache; |  | ||||||
| 
 |  | ||||||
| __asm__(".section .text"); | __asm__(".section .text"); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | @ -277,10 +266,6 @@ void translate_icache_sync() { | ||||||
|         platform_cache_sync(last_ram_translation_ptr, ram_translation_ptr); |         platform_cache_sync(last_ram_translation_ptr, ram_translation_ptr); | ||||||
|         last_ram_translation_ptr = ram_translation_ptr; |         last_ram_translation_ptr = ram_translation_ptr; | ||||||
|     } |     } | ||||||
|     if (last_bios_translation_ptr < bios_translation_ptr) { |  | ||||||
|         platform_cache_sync(last_bios_translation_ptr, bios_translation_ptr); |  | ||||||
|         last_bios_translation_ptr = bios_translation_ptr; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* End of Cache invalidation */ | /* End of Cache invalidation */ | ||||||
|  | @ -2703,9 +2688,6 @@ void translate_icache_sync() { | ||||||
| u8 *ram_block_ptrs[1024 * 64]; | u8 *ram_block_ptrs[1024 * 64]; | ||||||
| u32 ram_block_tag_top = 0x0101; | u32 ram_block_tag_top = 0x0101; | ||||||
| 
 | 
 | ||||||
| u8 *bios_block_ptrs[1024 * 8]; |  | ||||||
| u32 bios_block_tag_top = 0x0101; |  | ||||||
| 
 |  | ||||||
| // This function will return a pointer to a translated block of code. If it
 | // This function will return a pointer to a translated block of code. If it
 | ||||||
| // doesn't exist it will translate it, if it does it will pass it back.
 | // doesn't exist it will translate it, if it does it will pass it back.
 | ||||||
| 
 | 
 | ||||||
|  | @ -2735,7 +2717,6 @@ u32 bios_block_tag_top = 0x0101; | ||||||
| 
 | 
 | ||||||
| #define ram_translation_region  TRANSLATION_REGION_RAM | #define ram_translation_region  TRANSLATION_REGION_RAM | ||||||
| #define rom_translation_region  TRANSLATION_REGION_ROM | #define rom_translation_region  TRANSLATION_REGION_ROM | ||||||
| #define bios_translation_region TRANSLATION_REGION_BIOS |  | ||||||
| 
 | 
 | ||||||
| #define block_lookup_translate_arm(mem_type, smc_enable)                      \ | #define block_lookup_translate_arm(mem_type, smc_enable)                      \ | ||||||
|   translation_result = translate_block_arm(pc, mem_type##_translation_region, \ |   translation_result = translate_block_arm(pc, mem_type##_translation_region, \ | ||||||
|  | @ -2831,28 +2812,17 @@ u8 function_cc *block_lookup_address_##type(u32 pc)                           \ | ||||||
|                                                                               \ |                                                                               \ | ||||||
|   switch(pc >> 24)                                                            \ |   switch(pc >> 24)                                                            \ | ||||||
|   {                                                                           \ |   {                                                                           \ | ||||||
|     case 0x0:                                                                 \ |  | ||||||
|       bios_region_read_allow();                                               \ |  | ||||||
|       location = (u16 *)(bios_rom + pc + 0x4000);                             \ |  | ||||||
|       block_lookup_translate(type, bios, 0);                                  \ |  | ||||||
|       if(translation_recursion_level == 0)                                    \ |  | ||||||
|         bios_region_read_allow();                                             \ |  | ||||||
|       break;                                                                  \ |  | ||||||
|                                                                               \ |  | ||||||
|     case 0x2:                                                                 \ |     case 0x2:                                                                 \ | ||||||
|       location = (u16 *)(ewram + (pc & 0x7FFF) + ((pc & 0x38000) * 2));       \ |       location = (u16 *)(ewram + (pc & 0x7FFF) + ((pc & 0x38000) * 2));       \ | ||||||
|       block_lookup_translate(type, ram, 1);                                   \ |       block_lookup_translate(type, ram, 1);                                   \ | ||||||
|       if(translation_recursion_level == 0)                                    \ |  | ||||||
|         bios_region_read_protect();                                           \ |  | ||||||
|       break;                                                                  \ |       break;                                                                  \ | ||||||
|                                                                               \ |                                                                               \ | ||||||
|     case 0x3:                                                                 \ |     case 0x3:                                                                 \ | ||||||
|       location = (u16 *)(iwram + (pc & 0x7FFF));                              \ |       location = (u16 *)(iwram + (pc & 0x7FFF));                              \ | ||||||
|       block_lookup_translate(type, ram, 1);                                   \ |       block_lookup_translate(type, ram, 1);                                   \ | ||||||
|       if(translation_recursion_level == 0)                                    \ |  | ||||||
|         bios_region_read_protect();                                           \ |  | ||||||
|       break;                                                                  \ |       break;                                                                  \ | ||||||
|                                                                               \ |                                                                               \ | ||||||
|  |     case 0x0:                                                                 \ | ||||||
|     case 0x8 ... 0xD:                                                         \ |     case 0x8 ... 0xD:                                                         \ | ||||||
|     {                                                                         \ |     {                                                                         \ | ||||||
|       u32 hash_target = ((pc * 2654435761U) >> 16) &                          \ |       u32 hash_target = ((pc * 2654435761U) >> 16) &                          \ | ||||||
|  | @ -2876,7 +2846,7 @@ u8 function_cc *block_lookup_address_##type(u32 pc)                           \ | ||||||
|                                                                               \ |                                                                               \ | ||||||
|         redo:                                                                 \ |         redo:                                                                 \ | ||||||
|                                                                               \ |                                                                               \ | ||||||
|         translation_recursion_level++;																				\ |         translation_recursion_level++;                                        \ | ||||||
|         ((u32 *)rom_translation_ptr)[0] = pc;                                 \ |         ((u32 *)rom_translation_ptr)[0] = pc;                                 \ | ||||||
|         ((u32 **)rom_translation_ptr)[1] = NULL;                              \ |         ((u32 **)rom_translation_ptr)[1] = NULL;                              \ | ||||||
|         *block_ptr_address = (u32 *)rom_translation_ptr;                      \ |         *block_ptr_address = (u32 *)rom_translation_ptr;                      \ | ||||||
|  | @ -2898,8 +2868,6 @@ u8 function_cc *block_lookup_address_##type(u32 pc)                           \ | ||||||
|         if(translation_recursion_level == 0)                                  \ |         if(translation_recursion_level == 0)                                  \ | ||||||
|           translate_icache_sync();                                            \ |           translate_icache_sync();                                            \ | ||||||
|       }                                                                       \ |       }                                                                       \ | ||||||
|       if(translation_recursion_level == 0)                                    \ |  | ||||||
|         bios_region_read_protect();                                           \ |  | ||||||
|       break;                                                                  \ |       break;                                                                  \ | ||||||
|     }                                                                         \ |     }                                                                         \ | ||||||
|                                                                               \ |                                                                               \ | ||||||
|  | @ -3310,12 +3278,6 @@ s32 translate_block_arm(u32 pc, translation_region_type | ||||||
|        rom_translation_cache + ROM_TRANSLATION_CACHE_SIZE - |        rom_translation_cache + ROM_TRANSLATION_CACHE_SIZE - | ||||||
|        TRANSLATION_CACHE_LIMIT_THRESHOLD; |        TRANSLATION_CACHE_LIMIT_THRESHOLD; | ||||||
|       break; |       break; | ||||||
| 
 |  | ||||||
|     case TRANSLATION_REGION_BIOS: |  | ||||||
|       translation_ptr = bios_translation_ptr; |  | ||||||
|       translation_cache_limit = bios_translation_cache + |  | ||||||
|        BIOS_TRANSLATION_CACHE_SIZE; |  | ||||||
|       break; |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   generate_block_prologue(); |   generate_block_prologue(); | ||||||
|  | @ -3378,10 +3340,6 @@ s32 translate_block_arm(u32 pc, translation_region_type | ||||||
|         case TRANSLATION_REGION_ROM: |         case TRANSLATION_REGION_ROM: | ||||||
|           flush_translation_cache_rom(); |           flush_translation_cache_rom(); | ||||||
|           break; |           break; | ||||||
| 
 |  | ||||||
|         case TRANSLATION_REGION_BIOS: |  | ||||||
|           flush_translation_cache_bios(); |  | ||||||
|           break; |  | ||||||
|       } |       } | ||||||
|       return -1; |       return -1; | ||||||
|     } |     } | ||||||
|  | @ -3449,10 +3407,6 @@ s32 translate_block_arm(u32 pc, translation_region_type | ||||||
|     case TRANSLATION_REGION_ROM: |     case TRANSLATION_REGION_ROM: | ||||||
|       rom_translation_ptr = translation_ptr; |       rom_translation_ptr = translation_ptr; | ||||||
|       break; |       break; | ||||||
| 
 |  | ||||||
|     case TRANSLATION_REGION_BIOS: |  | ||||||
|       bios_translation_ptr = translation_ptr; |  | ||||||
|       break; |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   for(i = 0; i < external_block_exit_position; i++) |   for(i = 0; i < external_block_exit_position; i++) | ||||||
|  | @ -3526,12 +3480,6 @@ s32 translate_block_thumb(u32 pc, translation_region_type | ||||||
|        rom_translation_cache + ROM_TRANSLATION_CACHE_SIZE - |        rom_translation_cache + ROM_TRANSLATION_CACHE_SIZE - | ||||||
|        TRANSLATION_CACHE_LIMIT_THRESHOLD; |        TRANSLATION_CACHE_LIMIT_THRESHOLD; | ||||||
|       break; |       break; | ||||||
| 
 |  | ||||||
|     case TRANSLATION_REGION_BIOS: |  | ||||||
|       translation_ptr = bios_translation_ptr; |  | ||||||
|       translation_cache_limit = bios_translation_cache + |  | ||||||
|        BIOS_TRANSLATION_CACHE_SIZE; |  | ||||||
|       break; |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   generate_block_prologue(); |   generate_block_prologue(); | ||||||
|  | @ -3594,10 +3542,6 @@ s32 translate_block_thumb(u32 pc, translation_region_type | ||||||
|         case TRANSLATION_REGION_ROM: |         case TRANSLATION_REGION_ROM: | ||||||
|           flush_translation_cache_rom(); |           flush_translation_cache_rom(); | ||||||
|           break; |           break; | ||||||
| 
 |  | ||||||
|         case TRANSLATION_REGION_BIOS: |  | ||||||
|           flush_translation_cache_bios(); |  | ||||||
|           break; |  | ||||||
|       } |       } | ||||||
|       return -1; |       return -1; | ||||||
|     } |     } | ||||||
|  | @ -3665,10 +3609,6 @@ s32 translate_block_thumb(u32 pc, translation_region_type | ||||||
|     case TRANSLATION_REGION_ROM: |     case TRANSLATION_REGION_ROM: | ||||||
|       rom_translation_ptr = translation_ptr; |       rom_translation_ptr = translation_ptr; | ||||||
|       break; |       break; | ||||||
| 
 |  | ||||||
|     case TRANSLATION_REGION_BIOS: |  | ||||||
|       bios_translation_ptr = translation_ptr; |  | ||||||
|       break; |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   for(i = 0; i < external_block_exit_position; i++) |   for(i = 0; i < external_block_exit_position; i++) | ||||||
|  | @ -3746,16 +3686,6 @@ void flush_translation_cache_rom(void) | ||||||
|   memset(rom_branch_hash, 0, sizeof(rom_branch_hash)); |   memset(rom_branch_hash, 0, sizeof(rom_branch_hash)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void flush_translation_cache_bios(void) |  | ||||||
| { |  | ||||||
|   bios_block_tag_top = 0x0101; |  | ||||||
| 
 |  | ||||||
|   last_bios_translation_ptr = bios_translation_cache; |  | ||||||
|   bios_translation_ptr = bios_translation_cache; |  | ||||||
| 
 |  | ||||||
|   memset(bios_rom + 0x4000, 0, 0x4000); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #define cache_dump_prefix "" | #define cache_dump_prefix "" | ||||||
| 
 | 
 | ||||||
| void dump_translation_cache(void) | void dump_translation_cache(void) | ||||||
|  | @ -3769,11 +3699,6 @@ void dump_translation_cache(void) | ||||||
|   fwrite(rom_translation_cache, 1, |   fwrite(rom_translation_cache, 1, | ||||||
|    rom_translation_ptr - rom_translation_cache, fd); |    rom_translation_ptr - rom_translation_cache, fd); | ||||||
|   fclose(fd); |   fclose(fd); | ||||||
| 
 |  | ||||||
|   fd = fopen(cache_dump_prefix "bios_cache.bin", "wb"); |  | ||||||
|   fwrite(bios_translation_cache, 1, |  | ||||||
|    bios_translation_ptr - bios_translation_cache, fd); |  | ||||||
|   fclose(fd); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										15
									
								
								gba_memory.c
									
										
									
									
									
								
							
							
						
						
									
										15
									
								
								gba_memory.c
									
										
									
									
									
								
							|  | @ -310,8 +310,7 @@ u16 io_registers[1024 * 16]; | ||||||
| u8 ewram[1024 * 256 * 2]; | u8 ewram[1024 * 256 * 2]; | ||||||
| u8 iwram[1024 * 32 * 2]; | u8 iwram[1024 * 32 * 2]; | ||||||
| u8 vram[1024 * 96]; | u8 vram[1024 * 96]; | ||||||
| 
 | u8 bios_rom[1024 * 16]; | ||||||
| u8 bios_rom[1024 * 16 * 2]; |  | ||||||
| u32 bios_read_protect; | u32 bios_read_protect; | ||||||
| 
 | 
 | ||||||
| // Up to 128kb, store SRAM, flash ROM, or EEPROM here.
 | // Up to 128kb, store SRAM, flash ROM, or EEPROM here.
 | ||||||
|  | @ -3373,17 +3372,6 @@ void memory_term(void) | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void bios_region_read_allow(void) |  | ||||||
| { |  | ||||||
|   memory_map_read[0] = bios_rom; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void bios_region_read_protect(void) |  | ||||||
| { |  | ||||||
|   memory_map_read[0] = NULL; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| #define savestate_block(type)   \ | #define savestate_block(type)   \ | ||||||
|   cpu_##type##_savestate();     \ |   cpu_##type##_savestate();     \ | ||||||
|   input_##type##_savestate();   \ |   input_##type##_savestate();   \ | ||||||
|  | @ -3409,7 +3397,6 @@ void gba_load_state(const void* src) | ||||||
|    { |    { | ||||||
|       flush_translation_cache_ram(); |       flush_translation_cache_ram(); | ||||||
|       flush_translation_cache_rom(); |       flush_translation_cache_rom(); | ||||||
|       flush_translation_cache_bios(); |  | ||||||
|    } |    } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -192,8 +192,6 @@ void update_backup(void); | ||||||
| void init_memory(void); | void init_memory(void); | ||||||
| void init_gamepak_buffer(void); | void init_gamepak_buffer(void); | ||||||
| void memory_term(void); | void memory_term(void); | ||||||
| void bios_region_read_allow(void); |  | ||||||
| void bios_region_read_protect(void); |  | ||||||
| u8 *load_gamepak_page(u32 physical_index); | u8 *load_gamepak_page(u32 physical_index); | ||||||
| 
 | 
 | ||||||
| extern u8 *gamepak_rom; | extern u8 *gamepak_rom; | ||||||
|  | @ -209,8 +207,8 @@ extern u16 oam_ram[512]; | ||||||
| extern u16 palette_ram_converted[512]; | extern u16 palette_ram_converted[512]; | ||||||
| extern u16 io_registers[1024 * 16]; | extern u16 io_registers[1024 * 16]; | ||||||
| extern u8 vram[1024 * 96]; | extern u8 vram[1024 * 96]; | ||||||
|  | extern u8 bios_rom[1024 * 16]; | ||||||
| // Double buffer used for SMC detection
 | // Double buffer used for SMC detection
 | ||||||
| extern u8 bios_rom[1024 * 16 * 2]; |  | ||||||
| extern u8 ewram[1024 * 256 * 2]; | extern u8 ewram[1024 * 256 * 2]; | ||||||
| extern u8 iwram[1024 * 32 * 2]; | extern u8 iwram[1024 * 32 * 2]; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										20
									
								
								libretro.c
									
										
									
									
									
								
							
							
						
						
									
										20
									
								
								libretro.c
									
										
									
									
									
								
							|  | @ -22,8 +22,7 @@ static inline int align(int x, int n) { | ||||||
| #define MB_ALIGN(x) align(x, 20) | #define MB_ALIGN(x) align(x, 20) | ||||||
| 
 | 
 | ||||||
| int _newlib_vm_size_user = ROM_TRANSLATION_CACHE_SIZE + | int _newlib_vm_size_user = ROM_TRANSLATION_CACHE_SIZE + | ||||||
|                            RAM_TRANSLATION_CACHE_SIZE +  |                            RAM_TRANSLATION_CACHE_SIZE;  | ||||||
|                            BIOS_TRANSLATION_CACHE_SIZE; |  | ||||||
| 
 | 
 | ||||||
| int getVMBlock(); | int getVMBlock(); | ||||||
| 
 | 
 | ||||||
|  | @ -417,7 +416,6 @@ void retro_init(void) | ||||||
|        |        | ||||||
|       rom_translation_cache_ptr  = memalign(0x1000, ROM_TRANSLATION_CACHE_SIZE); |       rom_translation_cache_ptr  = memalign(0x1000, ROM_TRANSLATION_CACHE_SIZE); | ||||||
|       ram_translation_cache_ptr  = memalign(0x1000, RAM_TRANSLATION_CACHE_SIZE); |       ram_translation_cache_ptr  = memalign(0x1000, RAM_TRANSLATION_CACHE_SIZE); | ||||||
|       bios_translation_cache_ptr = memalign(0x1000, BIOS_TRANSLATION_CACHE_SIZE); |  | ||||||
| 
 | 
 | ||||||
|       svcDuplicateHandle(¤tHandle, 0xFFFF8001); |       svcDuplicateHandle(¤tHandle, 0xFFFF8001); | ||||||
|       svcControlProcessMemory(currentHandle, |       svcControlProcessMemory(currentHandle, | ||||||
|  | @ -426,13 +424,9 @@ void retro_init(void) | ||||||
|       svcControlProcessMemory(currentHandle, |       svcControlProcessMemory(currentHandle, | ||||||
|                               ram_translation_cache, ram_translation_cache_ptr, |                               ram_translation_cache, ram_translation_cache_ptr, | ||||||
|                               RAM_TRANSLATION_CACHE_SIZE, MEMOP_MAP, 0b111); |                               RAM_TRANSLATION_CACHE_SIZE, MEMOP_MAP, 0b111); | ||||||
|       svcControlProcessMemory(currentHandle, |  | ||||||
|                               bios_translation_cache, bios_translation_cache_ptr, |  | ||||||
|                               BIOS_TRANSLATION_CACHE_SIZE, MEMOP_MAP, 0b111); |  | ||||||
|       svcCloseHandle(currentHandle); |       svcCloseHandle(currentHandle); | ||||||
|       rom_translation_ptr = rom_translation_cache; |       rom_translation_ptr = rom_translation_cache; | ||||||
|       ram_translation_ptr = ram_translation_cache; |       ram_translation_ptr = ram_translation_cache; | ||||||
|       bios_translation_ptr = bios_translation_cache; |  | ||||||
|       ctr_flush_invalidate_cache(); |       ctr_flush_invalidate_cache(); | ||||||
|       translation_caches_inited = 1; |       translation_caches_inited = 1; | ||||||
|    } |    } | ||||||
|  | @ -458,10 +452,8 @@ void retro_init(void) | ||||||
| 
 | 
 | ||||||
|       rom_translation_cache  = (u8*)currentHandle; |       rom_translation_cache  = (u8*)currentHandle; | ||||||
|       ram_translation_cache  = rom_translation_cache + ROM_TRANSLATION_CACHE_SIZE; |       ram_translation_cache  = rom_translation_cache + ROM_TRANSLATION_CACHE_SIZE; | ||||||
|       bios_translation_cache = ram_translation_cache + RAM_TRANSLATION_CACHE_SIZE; |  | ||||||
|       rom_translation_ptr = rom_translation_cache; |       rom_translation_ptr = rom_translation_cache; | ||||||
|       ram_translation_ptr = ram_translation_cache; |       ram_translation_ptr = ram_translation_cache; | ||||||
|       bios_translation_ptr = bios_translation_cache; |  | ||||||
|       sceKernelOpenVMDomain(); |       sceKernelOpenVMDomain(); | ||||||
|       translation_caches_inited = 1; |       translation_caches_inited = 1; | ||||||
| } | } | ||||||
|  | @ -498,7 +490,6 @@ void retro_deinit(void) | ||||||
| #if defined(HAVE_MMAP) && defined(HAVE_DYNAREC) | #if defined(HAVE_MMAP) && defined(HAVE_DYNAREC) | ||||||
|    munmap(rom_translation_cache, ROM_TRANSLATION_CACHE_SIZE); |    munmap(rom_translation_cache, ROM_TRANSLATION_CACHE_SIZE); | ||||||
|    munmap(ram_translation_cache, RAM_TRANSLATION_CACHE_SIZE); |    munmap(ram_translation_cache, RAM_TRANSLATION_CACHE_SIZE); | ||||||
|    munmap(bios_translation_cache, BIOS_TRANSLATION_CACHE_SIZE); |  | ||||||
| #endif | #endif | ||||||
| #if defined(_3DS) && defined(HAVE_DYNAREC) | #if defined(_3DS) && defined(HAVE_DYNAREC) | ||||||
| 
 | 
 | ||||||
|  | @ -512,13 +503,9 @@ void retro_deinit(void) | ||||||
|       svcControlProcessMemory(currentHandle, |       svcControlProcessMemory(currentHandle, | ||||||
|                               ram_translation_cache, ram_translation_cache_ptr, |                               ram_translation_cache, ram_translation_cache_ptr, | ||||||
|                               RAM_TRANSLATION_CACHE_SIZE, MEMOP_UNMAP, 0b111); |                               RAM_TRANSLATION_CACHE_SIZE, MEMOP_UNMAP, 0b111); | ||||||
|       svcControlProcessMemory(currentHandle, |  | ||||||
|                               bios_translation_cache, bios_translation_cache_ptr, |  | ||||||
|                               BIOS_TRANSLATION_CACHE_SIZE, MEMOP_UNMAP, 0b111); |  | ||||||
|       svcCloseHandle(currentHandle); |       svcCloseHandle(currentHandle); | ||||||
|       free(rom_translation_cache_ptr); |       free(rom_translation_cache_ptr); | ||||||
|       free(ram_translation_cache_ptr); |       free(ram_translation_cache_ptr); | ||||||
|       free(bios_translation_cache_ptr); |  | ||||||
|       translation_caches_inited = 0; |       translation_caches_inited = 0; | ||||||
|    } |    } | ||||||
| #endif | #endif | ||||||
|  | @ -801,22 +788,17 @@ bool retro_load_game(const struct retro_game_info* info) | ||||||
|                                 PROT_READ | PROT_WRITE | PROT_EXEC, MAP_ANON | MAP_PRIVATE, -1, 0); |                                 PROT_READ | PROT_WRITE | PROT_EXEC, MAP_ANON | MAP_PRIVATE, -1, 0); | ||||||
|    ram_translation_cache = mmap(NULL, RAM_TRANSLATION_CACHE_SIZE, |    ram_translation_cache = mmap(NULL, RAM_TRANSLATION_CACHE_SIZE, | ||||||
|                                 PROT_READ | PROT_WRITE | PROT_EXEC, MAP_ANON | MAP_PRIVATE, -1, 0); |                                 PROT_READ | PROT_WRITE | PROT_EXEC, MAP_ANON | MAP_PRIVATE, -1, 0); | ||||||
|    bios_translation_cache = mmap(NULL, BIOS_TRANSLATION_CACHE_SIZE, |  | ||||||
|                                  PROT_READ | PROT_WRITE | PROT_EXEC, MAP_ANON | MAP_PRIVATE, -1, 0); |  | ||||||
| 
 | 
 | ||||||
|    rom_translation_ptr = rom_translation_cache; |    rom_translation_ptr = rom_translation_cache; | ||||||
|    ram_translation_ptr = ram_translation_cache; |    ram_translation_ptr = ram_translation_cache; | ||||||
|    bios_translation_ptr = bios_translation_cache; |  | ||||||
| #elif defined(_3DS) | #elif defined(_3DS) | ||||||
|    dynarec_enable = __ctr_svchax; |    dynarec_enable = __ctr_svchax; | ||||||
|    rom_translation_ptr = rom_translation_cache; |    rom_translation_ptr = rom_translation_cache; | ||||||
|    ram_translation_ptr = ram_translation_cache; |    ram_translation_ptr = ram_translation_cache; | ||||||
|    bios_translation_ptr = bios_translation_cache; |  | ||||||
| #elif defined(PSP) || defined(VITA) | #elif defined(PSP) || defined(VITA) | ||||||
|    dynarec_enable = 1; |    dynarec_enable = 1; | ||||||
|    rom_translation_ptr = rom_translation_cache; |    rom_translation_ptr = rom_translation_cache; | ||||||
|    ram_translation_ptr = ram_translation_cache; |    ram_translation_ptr = ram_translation_cache; | ||||||
|    bios_translation_ptr = bios_translation_cache; |  | ||||||
| #endif | #endif | ||||||
|    } |    } | ||||||
|    else |    else | ||||||
|  |  | ||||||
							
								
								
									
										1
									
								
								main.c
									
										
									
									
									
								
							
							
						
						
									
										1
									
								
								main.c
									
										
									
									
									
								
							|  | @ -116,7 +116,6 @@ void init_main(void) | ||||||
| #ifdef HAVE_DYNAREC | #ifdef HAVE_DYNAREC | ||||||
|   flush_translation_cache_rom(); |   flush_translation_cache_rom(); | ||||||
|   flush_translation_cache_ram(); |   flush_translation_cache_ram(); | ||||||
|   flush_translation_cache_bios(); |  | ||||||
|   init_emitter(); |   init_emitter(); | ||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue