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)
33 #define HWCAP2_AARCH64_SME_I16I64 (1 << 24)
34 #define HWCAP2_AARCH64_SME2 (1ULL << 37)
43 if (hwcap & HWCAP_AARCH64_CRC32)
45 if (hwcap & HWCAP_AARCH64_ASIMDDP)
47 if (hwcap & HWCAP_AARCH64_SVE)
49 if (hwcap2 & HWCAP2_AARCH64_SVE2)
51 if (hwcap2 & HWCAP2_AARCH64_I8MM)
53 if (hwcap2 & HWCAP2_AARCH64_SME)
55 if (hwcap2 & HWCAP2_AARCH64_SME_I16I64)
57 if (hwcap2 & HWCAP2_AARCH64_SME2)
63 #elif defined(__APPLE__) && HAVE_SYSCTLBYNAME
64 #include <sys/sysctl.h>
66 static int have_feature(
const char *feature) {
78 if (have_feature(
"hw.optional.arm.FEAT_DotProd"))
80 if (have_feature(
"hw.optional.arm.FEAT_I8MM"))
82 if (have_feature(
"hw.optional.arm.FEAT_SME"))
84 if (have_feature(
"hw.optional.arm.FEAT_SME_I16I64"))
86 if (have_feature(
"hw.optional.armv8_crc32"))
88 if (have_feature(
"hw.optional.arm.FEAT_SME2"))
94 #elif defined(__OpenBSD__)
95 #include <machine/armreg.h>
96 #include <machine/cpu.h>
97 #include <sys/types.h>
98 #include <sys/sysctl.h>
104 #ifdef CPU_ID_AA64ISAR0
110 mib[0] = CTL_MACHDEP;
111 mib[1] = CPU_ID_AA64ISAR0;
113 if (sysctl(mib, 2, &isar0, &
len,
NULL, 0) != -1) {
114 if (ID_AA64ISAR0_DP(isar0) >= ID_AA64ISAR0_DP_IMPL)
116 if (ID_AA64ISAR0_CRC32(isar0) >= ID_AA64ISAR0_CRC32_BASE)
120 mib[0] = CTL_MACHDEP;
121 mib[1] = CPU_ID_AA64ISAR1;
123 if (sysctl(mib, 2, &isar1, &
len,
NULL, 0) != -1) {
124 #ifdef ID_AA64ISAR1_I8MM_IMPL
125 if (ID_AA64ISAR1_I8MM(isar1) >= ID_AA64ISAR1_I8MM_IMPL)
134 #elif defined(_WIN32)
140 #ifdef PF_ARM_V8_CRC32_INSTRUCTIONS_AVAILABLE
141 if (IsProcessorFeaturePresent(PF_ARM_V8_CRC32_INSTRUCTIONS_AVAILABLE))
144 #ifdef PF_ARM_V82_DP_INSTRUCTIONS_AVAILABLE
145 if (IsProcessorFeaturePresent(PF_ARM_V82_DP_INSTRUCTIONS_AVAILABLE))
148 #ifdef PF_ARM_V82_I8MM_INSTRUCTIONS_AVAILABLE
149 if (IsProcessorFeaturePresent(PF_ARM_V82_I8MM_INSTRUCTIONS_AVAILABLE))
152 #ifdef PF_ARM_SVE_INSTRUCTIONS_AVAILABLE
153 if (IsProcessorFeaturePresent(PF_ARM_SVE_INSTRUCTIONS_AVAILABLE))
156 #ifdef PF_ARM_SVE2_INSTRUCTIONS_AVAILABLE
157 if (IsProcessorFeaturePresent(PF_ARM_SVE2_INSTRUCTIONS_AVAILABLE))
160 #ifdef PF_ARM_SME_INSTRUCTIONS_AVAILABLE
161 if (IsProcessorFeaturePresent(PF_ARM_SME_INSTRUCTIONS_AVAILABLE))
164 #ifdef PF_ARM_SME_I16I64_INSTRUCTIONS_AVAILABLE
165 if (IsProcessorFeaturePresent(PF_ARM_SME_I16I64_INSTRUCTIONS_AVAILABLE))
168 #ifdef PF_ARM_SME2_INSTRUCTIONS_AVAILABLE
169 if (IsProcessorFeaturePresent(PF_ARM_SME2_INSTRUCTIONS_AVAILABLE))
188 #ifdef __ARM_FEATURE_DOTPROD
191 #ifdef __ARM_FEATURE_MATMUL_INT8
194 #ifdef __ARM_FEATURE_SVE
197 #ifdef __ARM_FEATURE_SVE2
200 #ifdef __ARM_FEATURE_SME
203 #ifdef __ARM_FEATURE_CRC32
206 #ifdef __ARM_FEATURE_SME_I16I64
209 #ifdef __ARM_FEATURE_SME2