 e21ebbf666
			
		
	
	
		e21ebbf666
		
	
	
	
	
		
			
			* Add optimizations related to caller/callee saved registers, thread synchronization and disable tier 0 * Refactoring * Add a config entry to enable or disable the reg load/store opt. * Remove unnecessary register state stores for calls when the callee is know * Rename IoType to VarType * Enable tier 0 while fixing some perf issues related to tier 0 * Small tweak -- Compile before adding to the cache, to avoid lags * Add required config entry
		
			
				
	
	
		
			46 lines
		
	
	
		
			No EOL
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			No EOL
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using ChocolArm64.State;
 | |
| using System.Reflection.Emit;
 | |
| 
 | |
| namespace ChocolArm64.Translation
 | |
| {
 | |
|     struct ILOpCodeLoad : IILEmit
 | |
|     {
 | |
|         public int Index { get; }
 | |
| 
 | |
|         public VarType VarType { get; }
 | |
| 
 | |
|         public RegisterSize RegisterSize { get; }
 | |
| 
 | |
|         public ILOpCodeLoad(int index, VarType varType, RegisterSize registerSize = 0)
 | |
|         {
 | |
|             Index        = index;
 | |
|             VarType      = varType;
 | |
|             RegisterSize = registerSize;
 | |
|         }
 | |
| 
 | |
|         public void Emit(ILMethodBuilder context)
 | |
|         {
 | |
|             switch (VarType)
 | |
|             {
 | |
|                 case VarType.Arg: context.Generator.EmitLdarg(Index); break;
 | |
| 
 | |
|                 case VarType.Flag:   EmitLdloc(context, Index, RegisterType.Flag);   break;
 | |
|                 case VarType.Int:    EmitLdloc(context, Index, RegisterType.Int);    break;
 | |
|                 case VarType.Vector: EmitLdloc(context, Index, RegisterType.Vector); break;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         private void EmitLdloc(ILMethodBuilder context, int index, RegisterType registerType)
 | |
|         {
 | |
|             Register reg = new Register(index, registerType);
 | |
| 
 | |
|             context.Generator.EmitLdloc(context.GetLocalIndex(reg));
 | |
| 
 | |
|             if (registerType == RegisterType.Int &&
 | |
|                 RegisterSize == RegisterSize.Int32)
 | |
|             {
 | |
|                 context.Generator.Emit(OpCodes.Conv_U4);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| } |