aboutsummaryrefslogtreecommitdiff
path: root/ChocolArm64/Translation/ILOpCodeLoad.cs
diff options
context:
space:
mode:
authorgdkchan <gab.dark.100@gmail.com>2019-04-26 01:55:12 -0300
committerjduncanator <1518948+jduncanator@users.noreply.github.com>2019-04-26 14:55:12 +1000
commit8a7d99cdeae2355511d4eb43aefb76d0d886bcf8 (patch)
tree655d33f4db5dc3eb21c9c4ff5867b1179913585a /ChocolArm64/Translation/ILOpCodeLoad.cs
parent2b8eac1bcec6d4870776b4f302d9dd7794223642 (diff)
Refactoring and optimization on CPU translation (#661)
* Refactoring and optimization on CPU translation * Remove now unused property * Rename ilBlock -> block (local) * Change equality comparison on RegisterMask for consistency Co-Authored-By: gdkchan <gab.dark.100@gmail.com> * Add back the aggressive inlining attribute to the Synchronize method * Implement IEquatable on the Register struct * Fix identation
Diffstat (limited to 'ChocolArm64/Translation/ILOpCodeLoad.cs')
-rw-r--r--ChocolArm64/Translation/ILOpCodeLoad.cs46
1 files changed, 0 insertions, 46 deletions
diff --git a/ChocolArm64/Translation/ILOpCodeLoad.cs b/ChocolArm64/Translation/ILOpCodeLoad.cs
deleted file mode 100644
index 0d11eeaa..00000000
--- a/ChocolArm64/Translation/ILOpCodeLoad.cs
+++ /dev/null
@@ -1,46 +0,0 @@
-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);
- }
- }
- }
-} \ No newline at end of file