23 #if HAVE_GETAUXVAL || HAVE_ELF_AUX_INFO
27 #define HWCAP_AARCH64_CRC32 (1 << 7)
28 #define HWCAP_AARCH64_ASIMDDP (1 << 20)
29 #define HWCAP_AARCH64_SVE (1 << 22)
30 #define HWCAP2_AARCH64_SVE2 (1 << 1)
31 #define HWCAP2_AARCH64_I8MM (1 << 13)
32 #define HWCAP2_AARCH64_SME (1 << 23)
41 if (hwcap & HWCAP_AARCH64_CRC32)
43 if (hwcap & HWCAP_AARCH64_ASIMDDP)
45 if (hwcap & HWCAP_AARCH64_SVE)
47 if (hwcap2 & HWCAP2_AARCH64_SVE2)
49 if (hwcap2 & HWCAP2_AARCH64_I8MM)
51 if (hwcap2 & HWCAP2_AARCH64_SME)
57 #elif defined(__APPLE__) && HAVE_SYSCTLBYNAME
58 #include <sys/sysctl.h>
60 static int have_feature(
const char *feature) {
72 if (have_feature(
"hw.optional.arm.FEAT_DotProd"))
74 if (have_feature(
"hw.optional.arm.FEAT_I8MM"))
76 if (have_feature(
"hw.optional.arm.FEAT_SME"))
78 if (have_feature(
"hw.optional.armv8_crc32"))
84 #elif defined(__OpenBSD__)
85 #include <machine/armreg.h>
86 #include <machine/cpu.h>
87 #include <sys/types.h>
88 #include <sys/sysctl.h>
94 #ifdef CPU_ID_AA64ISAR0
100 mib[0] = CTL_MACHDEP;
101 mib[1] = CPU_ID_AA64ISAR0;
103 if (sysctl(mib, 2, &isar0, &
len,
NULL, 0) != -1) {
104 if (ID_AA64ISAR0_DP(isar0) >= ID_AA64ISAR0_DP_IMPL)
108 mib[0] = CTL_MACHDEP;
109 mib[1] = CPU_ID_AA64ISAR1;
111 if (sysctl(mib, 2, &isar1, &
len,
NULL, 0) != -1) {
112 #ifdef ID_AA64ISAR1_I8MM_IMPL
113 if (ID_AA64ISAR1_I8MM(isar1) >= ID_AA64ISAR1_I8MM_IMPL)
122 #elif defined(_WIN32)
128 #ifdef PF_ARM_V8_CRC32_INSTRUCTIONS_AVAILABLE
129 if (IsProcessorFeaturePresent(PF_ARM_V8_CRC32_INSTRUCTIONS_AVAILABLE))
132 #ifdef PF_ARM_V82_DP_INSTRUCTIONS_AVAILABLE
133 if (IsProcessorFeaturePresent(PF_ARM_V82_DP_INSTRUCTIONS_AVAILABLE))
136 #ifdef PF_ARM_SVE_I8MM_INSTRUCTIONS_AVAILABLE
140 if (IsProcessorFeaturePresent(PF_ARM_SVE_I8MM_INSTRUCTIONS_AVAILABLE))
143 #ifdef PF_ARM_SVE_INSTRUCTIONS_AVAILABLE
144 if (IsProcessorFeaturePresent(PF_ARM_SVE_INSTRUCTIONS_AVAILABLE))
147 #ifdef PF_ARM_SVE2_INSTRUCTIONS_AVAILABLE
148 if (IsProcessorFeaturePresent(PF_ARM_SVE2_INSTRUCTIONS_AVAILABLE))
151 #ifdef PF_ARM_SME_INSTRUCTIONS_AVAILABLE
152 if (IsProcessorFeaturePresent(PF_ARM_SME_INSTRUCTIONS_AVAILABLE))
171 #ifdef __ARM_FEATURE_DOTPROD
174 #ifdef __ARM_FEATURE_MATMUL_INT8
177 #ifdef __ARM_FEATURE_SVE
180 #ifdef __ARM_FEATURE_SVE2
183 #ifdef __ARM_FEATURE_SME