mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-25 11:56:42 +08:00 
			
		
		
		
	core: arm_dynarmic: Ensure JIT state is saved/restored on page table changes.
- We re-create the JIT here without preserving any state.
This commit is contained in:
		
							parent
							
								
									2e85ee250d
								
							
						
					
					
						commit
						a35717b245
					
				| @ -306,13 +306,18 @@ void ARM_Dynarmic_32::ClearExclusiveState() { | ||||
| 
 | ||||
| void ARM_Dynarmic_32::PageTableChanged(Common::PageTable& page_table, | ||||
|                                        std::size_t new_address_space_size_in_bits) { | ||||
|     ThreadContext32 ctx{}; | ||||
|     SaveContext(ctx); | ||||
| 
 | ||||
|     auto key = std::make_pair(&page_table, new_address_space_size_in_bits); | ||||
|     auto iter = jit_cache.find(key); | ||||
|     if (iter != jit_cache.end()) { | ||||
|         jit = iter->second; | ||||
|         LoadContext(ctx); | ||||
|         return; | ||||
|     } | ||||
|     jit = MakeJit(page_table, new_address_space_size_in_bits); | ||||
|     LoadContext(ctx); | ||||
|     jit_cache.emplace(key, jit); | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -348,13 +348,18 @@ void ARM_Dynarmic_64::ClearExclusiveState() { | ||||
| 
 | ||||
| void ARM_Dynarmic_64::PageTableChanged(Common::PageTable& page_table, | ||||
|                                        std::size_t new_address_space_size_in_bits) { | ||||
|     ThreadContext64 ctx{}; | ||||
|     SaveContext(ctx); | ||||
| 
 | ||||
|     auto key = std::make_pair(&page_table, new_address_space_size_in_bits); | ||||
|     auto iter = jit_cache.find(key); | ||||
|     if (iter != jit_cache.end()) { | ||||
|         jit = iter->second; | ||||
|         LoadContext(ctx); | ||||
|         return; | ||||
|     } | ||||
|     jit = MakeJit(page_table, new_address_space_size_in_bits); | ||||
|     LoadContext(ctx); | ||||
|     jit_cache.emplace(key, jit); | ||||
| } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user