Address comment.

This commit is contained in:
LDj3SNuD 2020-10-31 05:43:05 +01:00
parent 961b49e923
commit df99a023ee
3 changed files with 49 additions and 32 deletions

View file

@ -1,3 +1,4 @@
using System;
using System.Runtime.Intrinsics.X86; using System.Runtime.Intrinsics.X86;
namespace ARMeilleure.CodeGen.X86 namespace ARMeilleure.CodeGen.X86
@ -6,23 +7,54 @@ namespace ARMeilleure.CodeGen.X86
{ {
static HardwareCapabilities() static HardwareCapabilities()
{ {
(_, _, int ecx, _) = X86Base.CpuId(0x00000001, 0x00000000); if (!X86Base.IsSupported)
{
throw new Exception();
}
SupportsF16c = ((ecx >> 29) & 1) != 0; (_, _, int ecx, int edx) = X86Base.CpuId(0x00000001, 0x00000000);
FeatureInfoEdx = (FeatureFlagsEdx)edx;
FeatureInfoEcx = (FeatureFlagsEcx)ecx;
} }
public static bool SupportsSse => Sse.IsSupported; [Flags]
public static bool SupportsSse2 => Sse2.IsSupported; public enum FeatureFlagsEdx
public static bool SupportsSse3 => Sse3.IsSupported; {
public static bool SupportsSsse3 => Ssse3.IsSupported; Sse = 1 << 25,
public static bool SupportsSse41 => Sse41.IsSupported; Sse2 = 1 << 26
public static bool SupportsSse42 => Sse42.IsSupported; }
public static bool SupportsPclmulqdq => Pclmulqdq.IsSupported;
public static bool SupportsFma => Fma.IsSupported; [Flags]
public static bool SupportsPopcnt => Popcnt.IsSupported; public enum FeatureFlagsEcx
public static bool SupportsAesni => Aes.IsSupported; {
public static bool SupportsAvx => Avx.IsSupported; Sse3 = 1 << 0,
public static bool SupportsF16c; Pclmulqdq = 1 << 1,
Ssse3 = 1 << 9,
Fma = 1 << 12,
Sse41 = 1 << 19,
Sse42 = 1 << 20,
Popcnt = 1 << 23,
Aes = 1 << 25,
Avx = 1 << 28,
F16c = 1 << 29
}
public static FeatureFlagsEdx FeatureInfoEdx { get; }
public static FeatureFlagsEcx FeatureInfoEcx { get; }
public static bool SupportsSse => FeatureInfoEdx.HasFlag(FeatureFlagsEdx.Sse);
public static bool SupportsSse2 => FeatureInfoEdx.HasFlag(FeatureFlagsEdx.Sse2);
public static bool SupportsSse3 => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Sse3);
public static bool SupportsPclmulqdq => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Pclmulqdq);
public static bool SupportsSsse3 => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Ssse3);
public static bool SupportsFma => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Fma);
public static bool SupportsSse41 => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Sse41);
public static bool SupportsSse42 => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Sse42);
public static bool SupportsPopcnt => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Popcnt);
public static bool SupportsAesni => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Aes);
public static bool SupportsAvx => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.Avx);
public static bool SupportsF16c => FeatureInfoEcx.HasFlag(FeatureFlagsEcx.F16c);
public static bool ForceLegacySse { get; set; } public static bool ForceLegacySse { get; set; }

View file

@ -21,7 +21,7 @@ namespace ARMeilleure.Translation.PTC
{ {
private const string HeaderMagic = "PTChd"; private const string HeaderMagic = "PTChd";
private const int InternalVersion = 1273; //! To be incremented manually for each change to the ARMeilleure project. private const int InternalVersion = 1650; //! To be incremented manually for each change to the ARMeilleure project.
private const string ActualDir = "0"; private const string ActualDir = "0";
private const string BackupDir = "1"; private const string BackupDir = "1";
@ -646,22 +646,7 @@ namespace ARMeilleure.Translation.PTC
private static ulong GetFeatureInfo() private static ulong GetFeatureInfo()
{ {
ulong featureInfo = 0ul; return (ulong)HardwareCapabilities.FeatureInfoEdx << 32 | (uint)HardwareCapabilities.FeatureInfoEcx;
featureInfo |= (HardwareCapabilities.SupportsSse3 ? 1ul : 0ul) << 0;
featureInfo |= (HardwareCapabilities.SupportsPclmulqdq ? 1ul : 0ul) << 1;
featureInfo |= (HardwareCapabilities.SupportsSsse3 ? 1ul : 0ul) << 9;
featureInfo |= (HardwareCapabilities.SupportsFma ? 1ul : 0ul) << 12;
featureInfo |= (HardwareCapabilities.SupportsSse41 ? 1ul : 0ul) << 19;
featureInfo |= (HardwareCapabilities.SupportsSse42 ? 1ul : 0ul) << 20;
featureInfo |= (HardwareCapabilities.SupportsPopcnt ? 1ul : 0ul) << 23;
featureInfo |= (HardwareCapabilities.SupportsAesni ? 1ul : 0ul) << 25;
featureInfo |= (HardwareCapabilities.SupportsAvx ? 1ul : 0ul) << 28;
featureInfo |= (HardwareCapabilities.SupportsF16c ? 1ul : 0ul) << 29;
featureInfo |= (HardwareCapabilities.SupportsSse ? 1ul : 0ul) << 57;
featureInfo |= (HardwareCapabilities.SupportsSse2 ? 1ul : 0ul) << 58;
return featureInfo;
} }
private struct Header private struct Header

View file

@ -2,7 +2,7 @@ version: 1.0.{build}
branches: branches:
only: only:
- master - master
image: Visual Studio 2019 image: Visual Studio 2019 Preview
environment: environment:
appveyor_dotnet_runtime: net5.0 appveyor_dotnet_runtime: net5.0
matrix: matrix: