blob: 4fafc57d8e737fa2e72ca68fcf34c517f2aca62c [file] [log] [blame]
Mauro Carvalho Chehabb693d0b2019-06-12 14:52:38 -03001================
Mark Rutland611a7bc72017-10-11 14:01:03 +01002ARM64 ELF hwcaps
3================
4
5This document describes the usage and semantics of the arm64 ELF hwcaps.
6
7
81. Introduction
9---------------
10
11Some hardware or software features are only available on some CPU
12implementations, and/or with certain kernel configurations, but have no
13architected discovery mechanism available to userspace code at EL0. The
14kernel exposes the presence of these features to userspace through a set
15of flags called hwcaps, exposed in the auxilliary vector.
16
Andrew Murrayaaba0982019-04-09 10:52:40 +010017Userspace software can test for features by acquiring the AT_HWCAP or
18AT_HWCAP2 entry of the auxiliary vector, and testing whether the relevant
Mauro Carvalho Chehabb693d0b2019-06-12 14:52:38 -030019flags are set, e.g.::
Mark Rutland611a7bc72017-10-11 14:01:03 +010020
Mauro Carvalho Chehabb693d0b2019-06-12 14:52:38 -030021 bool floating_point_is_present(void)
22 {
23 unsigned long hwcaps = getauxval(AT_HWCAP);
24 if (hwcaps & HWCAP_FP)
25 return true;
Mark Rutland611a7bc72017-10-11 14:01:03 +010026
Mauro Carvalho Chehabb693d0b2019-06-12 14:52:38 -030027 return false;
28 }
Mark Rutland611a7bc72017-10-11 14:01:03 +010029
30Where software relies on a feature described by a hwcap, it should check
31the relevant hwcap flag to verify that the feature is present before
32attempting to make use of the feature.
33
34Features cannot be probed reliably through other means. When a feature
35is not available, attempting to use it may result in unpredictable
36behaviour, and is not guaranteed to result in any reliable indication
37that the feature is unavailable, such as a SIGILL.
38
39
402. Interpretation of hwcaps
41---------------------------
42
43The majority of hwcaps are intended to indicate the presence of features
44which are described by architected ID registers inaccessible to
45userspace code at EL0. These hwcaps are defined in terms of ID register
46fields, and should be interpreted with reference to the definition of
47these fields in the ARM Architecture Reference Manual (ARM ARM).
48
Mauro Carvalho Chehabb693d0b2019-06-12 14:52:38 -030049Such hwcaps are described below in the form::
Mark Rutland611a7bc72017-10-11 14:01:03 +010050
51 Functionality implied by idreg.field == val.
52
53Such hwcaps indicate the availability of functionality that the ARM ARM
54defines as being present when idreg.field has value val, but do not
55indicate that idreg.field is precisely equal to val, nor do they
56indicate the absence of functionality implied by other values of
57idreg.field.
58
59Other hwcaps may indicate the presence of features which cannot be
60described by ID registers alone. These may be described without
61reference to ID registers, and may refer to other documentation.
62
63
643. The hwcaps exposed in AT_HWCAP
65---------------------------------
66
67HWCAP_FP
Mark Rutland611a7bc72017-10-11 14:01:03 +010068 Functionality implied by ID_AA64PFR0_EL1.FP == 0b0000.
69
70HWCAP_ASIMD
Mark Rutland611a7bc72017-10-11 14:01:03 +010071 Functionality implied by ID_AA64PFR0_EL1.AdvSIMD == 0b0000.
72
73HWCAP_EVTSTRM
Mark Rutland611a7bc72017-10-11 14:01:03 +010074 The generic timer is configured to generate events at a frequency of
75 approximately 100KHz.
76
77HWCAP_AES
Giacomo Travaglini4bfbe5e2018-10-01 15:24:47 +010078 Functionality implied by ID_AA64ISAR0_EL1.AES == 0b0001.
Mark Rutland611a7bc72017-10-11 14:01:03 +010079
80HWCAP_PMULL
Giacomo Travaglini4bfbe5e2018-10-01 15:24:47 +010081 Functionality implied by ID_AA64ISAR0_EL1.AES == 0b0010.
Mark Rutland611a7bc72017-10-11 14:01:03 +010082
83HWCAP_SHA1
Mark Rutland611a7bc72017-10-11 14:01:03 +010084 Functionality implied by ID_AA64ISAR0_EL1.SHA1 == 0b0001.
85
86HWCAP_SHA2
Mark Rutland611a7bc72017-10-11 14:01:03 +010087 Functionality implied by ID_AA64ISAR0_EL1.SHA2 == 0b0001.
88
89HWCAP_CRC32
Mark Rutland611a7bc72017-10-11 14:01:03 +010090 Functionality implied by ID_AA64ISAR0_EL1.CRC32 == 0b0001.
91
92HWCAP_ATOMICS
Mark Rutland611a7bc72017-10-11 14:01:03 +010093 Functionality implied by ID_AA64ISAR0_EL1.Atomic == 0b0010.
94
95HWCAP_FPHP
Mark Rutland611a7bc72017-10-11 14:01:03 +010096 Functionality implied by ID_AA64PFR0_EL1.FP == 0b0001.
97
98HWCAP_ASIMDHP
Mark Rutland611a7bc72017-10-11 14:01:03 +010099 Functionality implied by ID_AA64PFR0_EL1.AdvSIMD == 0b0001.
100
101HWCAP_CPUID
Mark Rutland611a7bc72017-10-11 14:01:03 +0100102 EL0 access to certain ID registers is available, to the extent
Mauro Carvalho Chehabb693d0b2019-06-12 14:52:38 -0300103 described by Documentation/arm64/cpu-feature-registers.rst.
Mark Rutland611a7bc72017-10-11 14:01:03 +0100104
105 These ID registers may imply the availability of features.
106
107HWCAP_ASIMDRDM
Mark Rutland611a7bc72017-10-11 14:01:03 +0100108 Functionality implied by ID_AA64ISAR0_EL1.RDM == 0b0001.
109
110HWCAP_JSCVT
Mark Rutland611a7bc72017-10-11 14:01:03 +0100111 Functionality implied by ID_AA64ISAR1_EL1.JSCVT == 0b0001.
112
113HWCAP_FCMA
Mark Rutland611a7bc72017-10-11 14:01:03 +0100114 Functionality implied by ID_AA64ISAR1_EL1.FCMA == 0b0001.
115
116HWCAP_LRCPC
Mark Rutland611a7bc72017-10-11 14:01:03 +0100117 Functionality implied by ID_AA64ISAR1_EL1.LRCPC == 0b0001.
118
119HWCAP_DCPOP
Mark Rutland611a7bc72017-10-11 14:01:03 +0100120 Functionality implied by ID_AA64ISAR1_EL1.DPB == 0b0001.
121
122HWCAP_SHA3
Mark Rutland611a7bc72017-10-11 14:01:03 +0100123 Functionality implied by ID_AA64ISAR0_EL1.SHA3 == 0b0001.
124
125HWCAP_SM3
Mark Rutland611a7bc72017-10-11 14:01:03 +0100126 Functionality implied by ID_AA64ISAR0_EL1.SM3 == 0b0001.
127
128HWCAP_SM4
Mark Rutland611a7bc72017-10-11 14:01:03 +0100129 Functionality implied by ID_AA64ISAR0_EL1.SM4 == 0b0001.
130
131HWCAP_ASIMDDP
Mark Rutland611a7bc72017-10-11 14:01:03 +0100132 Functionality implied by ID_AA64ISAR0_EL1.DP == 0b0001.
133
134HWCAP_SHA512
Giacomo Travaglini4bfbe5e2018-10-01 15:24:47 +0100135 Functionality implied by ID_AA64ISAR0_EL1.SHA2 == 0b0010.
Dave Martin43994d82017-10-31 15:51:19 +0000136
137HWCAP_SVE
Dave Martin43994d82017-10-31 15:51:19 +0000138 Functionality implied by ID_AA64PFR0_EL1.SVE == 0b0001.
Dongjiu Geng3b3b6812017-12-13 18:13:56 +0800139
Julien Grall3a25e462019-10-03 12:12:09 +0100140HWCAP_ASIMDFHM
141 Functionality implied by ID_AA64ISAR0_EL1.FHM == 0b0001.
142
143HWCAP_DIT
144 Functionality implied by ID_AA64PFR0_EL1.DIT == 0b0001.
145
146HWCAP_USCAT
147 Functionality implied by ID_AA64MMFR2_EL1.AT == 0b0001.
148
149HWCAP_ILRCPC
150 Functionality implied by ID_AA64ISAR1_EL1.LRCPC == 0b0010.
151
152HWCAP_FLAGM
153 Functionality implied by ID_AA64ISAR0_EL1.TS == 0b0001.
154
155HWCAP_SSBS
156 Functionality implied by ID_AA64PFR1_EL1.SSBS == 0b0010.
157
Julien Grall0f6e4c42019-10-03 12:12:10 +0100158HWCAP_SB
159 Functionality implied by ID_AA64ISAR1_EL1.SB == 0b0001.
160
Julien Grall3a25e462019-10-03 12:12:09 +0100161HWCAP_PACA
162 Functionality implied by ID_AA64ISAR1_EL1.APA == 0b0001 or
163 ID_AA64ISAR1_EL1.API == 0b0001, as described by
164 Documentation/arm64/pointer-authentication.rst.
165
166HWCAP_PACG
167 Functionality implied by ID_AA64ISAR1_EL1.GPA == 0b0001 or
168 ID_AA64ISAR1_EL1.GPI == 0b0001, as described by
169 Documentation/arm64/pointer-authentication.rst.
170
171HWCAP2_DCPODP
172
173 Functionality implied by ID_AA64ISAR1_EL1.DPB == 0b0010.
174
Dave Martin06a916f2019-04-18 18:41:38 +0100175HWCAP2_SVE2
176
177 Functionality implied by ID_AA64ZFR0_EL1.SVEVer == 0b0001.
178
179HWCAP2_SVEAES
180
181 Functionality implied by ID_AA64ZFR0_EL1.AES == 0b0001.
182
183HWCAP2_SVEPMULL
184
185 Functionality implied by ID_AA64ZFR0_EL1.AES == 0b0010.
186
187HWCAP2_SVEBITPERM
188
189 Functionality implied by ID_AA64ZFR0_EL1.BitPerm == 0b0001.
190
191HWCAP2_SVESHA3
192
193 Functionality implied by ID_AA64ZFR0_EL1.SHA3 == 0b0001.
194
195HWCAP2_SVESM4
196
197 Functionality implied by ID_AA64ZFR0_EL1.SM4 == 0b0001.
198
Mark Brown12019372019-06-18 19:10:54 +0100199HWCAP2_FLAGM2
200
201 Functionality implied by ID_AA64ISAR0_EL1.TS == 0b0010.
202
Mark Brownca9503f2019-06-18 19:10:55 +0100203HWCAP2_FRINT
204
205 Functionality implied by ID_AA64ISAR1_EL1.FRINTTS == 0b0001.
206
Steven Priced4209d82019-12-16 11:33:37 +0000207HWCAP2_SVEI8MM
208
209 Functionality implied by ID_AA64ZFR0_EL1.I8MM == 0b0001.
210
211HWCAP2_SVEF32MM
212
213 Functionality implied by ID_AA64ZFR0_EL1.F32MM == 0b0001.
214
215HWCAP2_SVEF64MM
216
217 Functionality implied by ID_AA64ZFR0_EL1.F64MM == 0b0001.
218
219HWCAP2_SVEBF16
220
221 Functionality implied by ID_AA64ZFR0_EL1.BF16 == 0b0001.
222
223HWCAP2_I8MM
224
225 Functionality implied by ID_AA64ISAR1_EL1.I8MM == 0b0001.
226
227HWCAP2_BF16
228
229 Functionality implied by ID_AA64ISAR1_EL1.BF16 == 0b0001.
230
231HWCAP2_DGH
232
233 Functionality implied by ID_AA64ISAR1_EL1.DGH == 0b0001.
Andrew Murrayaaba0982019-04-09 10:52:40 +0100234
2354. Unused AT_HWCAP bits
236-----------------------
237
238For interoperation with userspace, the kernel guarantees that bits 62
239and 63 of AT_HWCAP will always be returned as 0.