mirror of
				https://github.com/Ryujinx/Ryujinx.git
				synced 2025-10-25 17:14:00 -07:00 
			
		
		
		
	Optimize address translation and write tracking on the MMU (#571)
* Implement faster address translation and write tracking on the MMU * Rename MemoryAlloc to MemoryManagement, and other nits * Support multi-level page tables * Fix typo * Reword comment a bit * Support scalar vector loads/stores on the memory fast path, and minor fixes * Add missing cast * Alignment * Fix VirtualFree function signature * Change MemoryProtection enum to uint aswell for consistency
This commit is contained in:
		| @@ -31,8 +31,6 @@ namespace ChocolArm64.Instructions | ||||
|         { | ||||
|             OpCodeMem64 op = (OpCodeMem64)context.CurrOp; | ||||
|  | ||||
|             context.EmitLdarg(TranslatedSub.MemoryArgIdx); | ||||
|  | ||||
|             EmitLoadAddress(context); | ||||
|  | ||||
|             if (signed && op.Extend64) | ||||
| @@ -69,7 +67,6 @@ namespace ChocolArm64.Instructions | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             context.EmitLdarg(TranslatedSub.MemoryArgIdx); | ||||
|             context.EmitLdc_I8(op.Imm); | ||||
|  | ||||
|             if (op.Signed) | ||||
| @@ -116,13 +113,10 @@ namespace ChocolArm64.Instructions | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             context.EmitLdarg(TranslatedSub.MemoryArgIdx); | ||||
|  | ||||
|             EmitLoadAddress(context); | ||||
|  | ||||
|             EmitReadAndStore(op.Rt); | ||||
|  | ||||
|             context.EmitLdarg(TranslatedSub.MemoryArgIdx); | ||||
|             context.EmitLdtmp(); | ||||
|             context.EmitLdc_I8(1 << op.Size); | ||||
|  | ||||
| @@ -137,8 +131,6 @@ namespace ChocolArm64.Instructions | ||||
|         { | ||||
|             OpCodeMem64 op = (OpCodeMem64)context.CurrOp; | ||||
|  | ||||
|             context.EmitLdarg(TranslatedSub.MemoryArgIdx); | ||||
|  | ||||
|             EmitLoadAddress(context); | ||||
|  | ||||
|             if (op is IOpCodeSimd64) | ||||
| @@ -159,8 +151,6 @@ namespace ChocolArm64.Instructions | ||||
|         { | ||||
|             OpCodeMemPair64 op = (OpCodeMemPair64)context.CurrOp; | ||||
|  | ||||
|             context.EmitLdarg(TranslatedSub.MemoryArgIdx); | ||||
|  | ||||
|             EmitLoadAddress(context); | ||||
|  | ||||
|             if (op is IOpCodeSimd64) | ||||
| @@ -174,7 +164,6 @@ namespace ChocolArm64.Instructions | ||||
|  | ||||
|             EmitWriteCall(context, op.Size); | ||||
|  | ||||
|             context.EmitLdarg(TranslatedSub.MemoryArgIdx); | ||||
|             context.EmitLdtmp(); | ||||
|             context.EmitLdc_I8(1 << op.Size); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user