7 This document describes the usage and semantics of the arm64 ELF hwcaps.
13 Some hardware or software features are only available on some CPU
14 implementations, and/or with certain kernel configurations, but have no
15 architected discovery mechanism available to userspace code at EL0. The
16 kernel exposes the presence of these features to userspace through a set
17 of flags called hwcaps, exposed in the auxiliary vector.
19 Userspace software can test for features by acquiring the AT_HWCAP,
20 AT_HWCAP2 or AT_HWCAP3 entry of the auxiliary vector, and testing
21 whether the relevant flags are set, e.g.::
23 bool floating_point_is_present(void)
25 unsigned long hwcaps = getauxval(AT_HWCAP);
26 if (hwcaps & HWCAP_FP)
32 Where software relies on a feature described by a hwcap, it should check
33 the relevant hwcap flag to verify that the feature is present before
34 attempting to make use of the feature.
36 Features cannot be probed reliably through other means. When a feature
37 is not available, attempting to use it may result in unpredictable
38 behaviour, and is not guaranteed to result in any reliable indication
39 that the feature is unavailable, such as a SIGILL.
42 2. Interpretation of hwcaps
43 ---------------------------
45 The majority of hwcaps are intended to indicate the presence of features
46 which are described by architected ID registers inaccessible to
47 userspace code at EL0. These hwcaps are defined in terms of ID register
48 fields, and should be interpreted with reference to the definition of
49 these fields in the ARM Architecture Reference Manual (ARM ARM).
51 Such hwcaps are described below in the form::
53 Functionality implied by idreg.field == val.
55 Such hwcaps indicate the availability of functionality that the ARM ARM
56 defines as being present when idreg.field has value val, but do not
57 indicate that idreg.field is precisely equal to val, nor do they
58 indicate the absence of functionality implied by other values of
61 Other hwcaps may indicate the presence of features which cannot be
62 described by ID registers alone. These may be described without
63 reference to ID registers, and may refer to other documentation.
66 3. The hwcaps exposed in AT_HWCAP
67 ---------------------------------
70 Functionality implied by ID_AA64PFR0_EL1.FP == 0b0000.
73 Functionality implied by ID_AA64PFR0_EL1.AdvSIMD == 0b0000.
76 The generic timer is configured to generate events at a frequency of
80 Functionality implied by ID_AA64ISAR0_EL1.AES == 0b0001.
83 Functionality implied by ID_AA64ISAR0_EL1.AES == 0b0010.
86 Functionality implied by ID_AA64ISAR0_EL1.SHA1 == 0b0001.
89 Functionality implied by ID_AA64ISAR0_EL1.SHA2 == 0b0001.
92 Functionality implied by ID_AA64ISAR0_EL1.CRC32 == 0b0001.
95 Functionality implied by ID_AA64ISAR0_EL1.Atomic == 0b0010.
98 Functionality implied by ID_AA64PFR0_EL1.FP == 0b0001.
101 Functionality implied by ID_AA64PFR0_EL1.AdvSIMD == 0b0001.
104 EL0 access to certain ID registers is available, to the extent
105 described by Documentation/arch/arm64/cpu-feature-registers.rst.
107 These ID registers may imply the availability of features.
110 Functionality implied by ID_AA64ISAR0_EL1.RDM == 0b0001.
113 Functionality implied by ID_AA64ISAR1_EL1.JSCVT == 0b0001.
116 Functionality implied by ID_AA64ISAR1_EL1.FCMA == 0b0001.
119 Functionality implied by ID_AA64ISAR1_EL1.LRCPC == 0b0001.
122 Functionality implied by ID_AA64ISAR1_EL1.DPB == 0b0001.
125 Functionality implied by ID_AA64ISAR0_EL1.SHA3 == 0b0001.
128 Functionality implied by ID_AA64ISAR0_EL1.SM3 == 0b0001.
131 Functionality implied by ID_AA64ISAR0_EL1.SM4 == 0b0001.
134 Functionality implied by ID_AA64ISAR0_EL1.DP == 0b0001.
137 Functionality implied by ID_AA64ISAR0_EL1.SHA2 == 0b0010.
140 Functionality implied by ID_AA64PFR0_EL1.SVE == 0b0001.
143 Functionality implied by ID_AA64ISAR0_EL1.FHM == 0b0001.
146 Functionality implied by ID_AA64PFR0_EL1.DIT == 0b0001.
149 Functionality implied by ID_AA64MMFR2_EL1.AT == 0b0001.
152 Functionality implied by ID_AA64ISAR1_EL1.LRCPC == 0b0010.
155 Functionality implied by ID_AA64ISAR0_EL1.TS == 0b0001.
158 Functionality implied by ID_AA64PFR1_EL1.SSBS == 0b0010.
161 Functionality implied by ID_AA64ISAR1_EL1.SB == 0b0001.
164 Functionality implied by ID_AA64ISAR1_EL1.APA == 0b0001 or
165 ID_AA64ISAR1_EL1.API == 0b0001, as described by
166 Documentation/arch/arm64/pointer-authentication.rst.
169 Functionality implied by ID_AA64ISAR1_EL1.GPA == 0b0001 or
170 ID_AA64ISAR1_EL1.GPI == 0b0001, as described by
171 Documentation/arch/arm64/pointer-authentication.rst.
174 Functionality implied by ID_AA64PFR1_EL1.GCS == 0b1, as
175 described by Documentation/arch/arm64/gcs.rst.
178 Functionality implied by ID_AA64ISAR1_EL1.DPB == 0b0010.
181 Functionality implied by ID_AA64ZFR0_EL1.SVEver == 0b0001.
184 Functionality implied by ID_AA64ZFR0_EL1.AES == 0b0001.
187 Functionality implied by ID_AA64ZFR0_EL1.AES == 0b0010.
190 Functionality implied by ID_AA64ZFR0_EL1.BitPerm == 0b0001.
193 Functionality implied by ID_AA64ZFR0_EL1.SHA3 == 0b0001.
196 Functionality implied by ID_AA64ZFR0_EL1.SM4 == 0b0001.
199 Functionality implied by ID_AA64ISAR0_EL1.TS == 0b0010.
202 Functionality implied by ID_AA64ISAR1_EL1.FRINTTS == 0b0001.
205 Functionality implied by ID_AA64ZFR0_EL1.I8MM == 0b0001.
208 Functionality implied by ID_AA64ZFR0_EL1.F32MM == 0b0001.
211 Functionality implied by ID_AA64ZFR0_EL1.F64MM == 0b0001.
214 Functionality implied by ID_AA64ZFR0_EL1.BF16 == 0b0001.
217 Functionality implied by ID_AA64ISAR1_EL1.I8MM == 0b0001.
220 Functionality implied by ID_AA64ISAR1_EL1.BF16 == 0b0001.
223 Functionality implied by ID_AA64ISAR1_EL1.DGH == 0b0001.
226 Functionality implied by ID_AA64ISAR0_EL1.RNDR == 0b0001.
229 Functionality implied by ID_AA64PFR1_EL1.BT == 0b0001.
232 Functionality implied by ID_AA64PFR1_EL1.MTE == 0b0010, as described
233 by Documentation/arch/arm64/memory-tagging-extension.rst.
236 Functionality implied by ID_AA64MMFR0_EL1.ECV == 0b0001.
239 Functionality implied by ID_AA64MMFR1_EL1.AFP == 0b0001.
242 Functionality implied by ID_AA64ISAR2_EL1.RPRES == 0b0001.
245 Functionality implied by ID_AA64PFR1_EL1.MTE == 0b0011, as described
246 by Documentation/arch/arm64/memory-tagging-extension.rst.
249 Functionality implied by ID_AA64PFR1_EL1.SME == 0b0001, as described
250 by Documentation/arch/arm64/sme.rst.
253 Functionality implied by ID_AA64SMFR0_EL1.I16I64 == 0b1111.
256 Functionality implied by ID_AA64SMFR0_EL1.F64F64 == 0b1.
259 Functionality implied by ID_AA64SMFR0_EL1.I8I32 == 0b1111.
262 Functionality implied by ID_AA64SMFR0_EL1.F16F32 == 0b1.
265 Functionality implied by ID_AA64SMFR0_EL1.B16F32 == 0b1.
268 Functionality implied by ID_AA64SMFR0_EL1.F32F32 == 0b1.
271 Functionality implied by ID_AA64SMFR0_EL1.FA64 == 0b1.
274 Functionality implied by ID_AA64ISAR2_EL1.WFXT == 0b0010.
277 Functionality implied by ID_AA64ISAR1_EL1.BF16 == 0b0010.
280 Functionality implied by ID_AA64ZFR0_EL1.BF16 == 0b0010.
283 Functionality implied by ID_AA64ISAR2_EL1.CSSC == 0b0001.
286 Functionality implied by ID_AA64ISAR2_EL1.RPRFM == 0b0001.
289 Functionality implied by ID_AA64ZFR0_EL1.SVEver == 0b0010.
292 Functionality implied by ID_AA64SMFR0_EL1.SMEver == 0b0001.
295 Functionality implied by ID_AA64SMFR0_EL1.SMEver == 0b0010.
298 Functionality implied by ID_AA64SMFR0_EL1.I16I32 == 0b0101
301 Functionality implied by ID_AA64SMFR0_EL1.BI32I32 == 0b1
304 Functionality implied by ID_AA64SMFR0_EL1.B16B16 == 0b1
307 Functionality implied by ID_AA64SMFR0_EL1.F16F16 == 0b1
310 Functionality implied by ID_AA64ISAR2_EL1.MOPS == 0b0001.
313 Functionality implied by ID_AA64ISAR2_EL1.BC == 0b0001.
316 Functionality implied by ID_AA64ZFR0_EL1.B16B16 == 0b0001.
319 Functionality implied by ID_AA64ISAR1_EL1.LRCPC == 0b0011.
322 Functionality implied by ID_AA64ISAR0_EL1.Atomic == 0b0011.
325 Functionality implied by ID_AA64PFR2_EL1.FMR == 0b0001.
328 Functionality implied by ID_AA64ISAR2_EL1.LUT == 0b0001.
331 Functionality implied by ID_AA64ISAR3_EL1.FAMINMAX == 0b0001.
334 Functionality implied by ID_AA64FPFR0_EL1.F8CVT == 0b1.
337 Functionality implied by ID_AA64FPFR0_EL1.F8FMA == 0b1.
340 Functionality implied by ID_AA64FPFR0_EL1.F8DP4 == 0b1.
343 Functionality implied by ID_AA64FPFR0_EL1.F8DP2 == 0b1.
346 Functionality implied by ID_AA64FPFR0_EL1.F8E4M3 == 0b1.
349 Functionality implied by ID_AA64FPFR0_EL1.F8E5M2 == 0b1.
352 Functionality implied by ID_AA64SMFR0_EL1.LUTv2 == 0b1.
355 Functionality implied by ID_AA64SMFR0_EL1.F8F16 == 0b1.
358 Functionality implied by ID_AA64SMFR0_EL1.F8F32 == 0b1.
361 Functionality implied by ID_AA64SMFR0_EL1.SF8FMA == 0b1.
364 Functionality implied by ID_AA64SMFR0_EL1.SF8DP4 == 0b1.
367 Functionality implied by ID_AA64SMFR0_EL1.SF8DP2 == 0b1.
370 Functionality implied by ID_AA64SMFR0_EL1.SF8DP4 == 0b1.
373 Functionality implied by ID_AA64MMFR3_EL1.S1POE == 0b0001.
375 4. Unused AT_HWCAP bits
376 -----------------------
378 For interoperation with userspace, the kernel guarantees that bits 62
379 and 63 of AT_HWCAP will always be returned as 0.