aboutsummaryrefslogtreecommitdiff
path: root/ChocolArm64/Instructions/InstEmitHash.cs
diff options
context:
space:
mode:
authorLDj3SNuD <35856442+LDj3SNuD@users.noreply.github.com>2019-10-31 19:09:03 +0100
committerAc_K <Acoustik666@gmail.com>2019-10-31 19:09:03 +0100
commiteee639d6ba544fa5dd9352426d55e91bc54e157d (patch)
tree1df440ca57d8c1725e84f403fbeecddb8e508a3a /ChocolArm64/Instructions/InstEmitHash.cs
parent35443bac5a16ced668d84e0a22c21ca9076b3924 (diff)
.NET Core 3.0 is here! (#784)
* .NET Core 3.0 is here! * Remove IMemoryManager.cs and its references. * Add T Math/F.FusedMultiplyAdd(T, T, T). Nits. * Nit. * Update appveyor.yml * Revert "Resolve Visual Studio build issues" This reverts commit 1772128ce0fc058e6280001aace3a77a7a96897b. * Update SvcTable.cs
Diffstat (limited to 'ChocolArm64/Instructions/InstEmitHash.cs')
-rw-r--r--ChocolArm64/Instructions/InstEmitHash.cs115
1 files changed, 0 insertions, 115 deletions
diff --git a/ChocolArm64/Instructions/InstEmitHash.cs b/ChocolArm64/Instructions/InstEmitHash.cs
deleted file mode 100644
index 7e21a886..00000000
--- a/ChocolArm64/Instructions/InstEmitHash.cs
+++ /dev/null
@@ -1,115 +0,0 @@
-using ChocolArm64.Decoders;
-using ChocolArm64.State;
-using ChocolArm64.Translation;
-using System;
-using System.Reflection.Emit;
-using System.Runtime.Intrinsics.X86;
-
-namespace ChocolArm64.Instructions
-{
- static partial class InstEmit
- {
- public static void Crc32b(ILEmitterCtx context)
- {
- EmitCrc32(context, nameof(SoftFallback.Crc32B));
- }
-
- public static void Crc32h(ILEmitterCtx context)
- {
- EmitCrc32(context, nameof(SoftFallback.Crc32H));
- }
-
- public static void Crc32w(ILEmitterCtx context)
- {
- EmitCrc32(context, nameof(SoftFallback.Crc32W));
- }
-
- public static void Crc32x(ILEmitterCtx context)
- {
- EmitCrc32(context, nameof(SoftFallback.Crc32X));
- }
-
- public static void Crc32cb(ILEmitterCtx context)
- {
- if (Optimizations.UseSse42)
- {
- EmitSse42Crc32(context, typeof(uint), typeof(byte));
- }
- else
- {
- EmitCrc32(context, nameof(SoftFallback.Crc32Cb));
- }
- }
-
- public static void Crc32ch(ILEmitterCtx context)
- {
- if (Optimizations.UseSse42)
- {
- EmitSse42Crc32(context, typeof(uint), typeof(ushort));
- }
- else
- {
- EmitCrc32(context, nameof(SoftFallback.Crc32Ch));
- }
- }
-
- public static void Crc32cw(ILEmitterCtx context)
- {
- if (Optimizations.UseSse42)
- {
- EmitSse42Crc32(context, typeof(uint), typeof(uint));
- }
- else
- {
- EmitCrc32(context, nameof(SoftFallback.Crc32Cw));
- }
- }
-
- public static void Crc32cx(ILEmitterCtx context)
- {
- if (Optimizations.UseSse42)
- {
- EmitSse42Crc32(context, typeof(ulong), typeof(ulong));
- }
- else
- {
- EmitCrc32(context, nameof(SoftFallback.Crc32Cx));
- }
- }
-
- private static void EmitSse42Crc32(ILEmitterCtx context, Type tCrc, Type tData)
- {
- OpCodeAluRs64 op = (OpCodeAluRs64)context.CurrOp;
-
- context.EmitLdintzr(op.Rn);
- context.EmitLdintzr(op.Rm);
-
- context.EmitCall(typeof(Sse42).GetMethod(nameof(Sse42.Crc32), new Type[] { tCrc, tData }));
-
- context.EmitStintzr(op.Rd);
- }
-
- private static void EmitCrc32(ILEmitterCtx context, string name)
- {
- OpCodeAluRs64 op = (OpCodeAluRs64)context.CurrOp;
-
- context.EmitLdintzr(op.Rn);
-
- if (op.RegisterSize != RegisterSize.Int32)
- {
- context.Emit(OpCodes.Conv_U4);
- }
-
- context.EmitLdintzr(op.Rm);
-
- SoftFallback.EmitCall(context, name);
-
- if (op.RegisterSize != RegisterSize.Int32)
- {
- context.Emit(OpCodes.Conv_U8);
- }
-
- context.EmitStintzr(op.Rd);
- }
- }
-}