Must not produce Tag_CPU_arch_profile for pre-ARMv7 cores (e.g. cortex-m0)
[oota-llvm.git] / test / CodeGen / ARM / build-attributes.ll
1 ; This tests that MC/asm header conversion is smooth and that the
2 ; build attributes are correct
3
4 ; RUN: llc < %s -mtriple=armv6-linux-gnueabi | FileCheck %s --check-prefix=V6
5 ; RUN: llc < %s -mtriple=thumbv6m-linux-gnueabi | FileCheck %s --check-prefix=V6M
6 ; RUN: llc < %s -mtriple=armv6-linux-gnueabi -mcpu=arm1156t2f-s | FileCheck %s --check-prefix=ARM1156T2F-S
7 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi | FileCheck %s --check-prefix=V7M
8 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi | FileCheck %s --check-prefix=V7
9 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi | FileCheck %s --check-prefix=V8
10 ; RUN: llc < %s -mtriple=thumbv8-linux-gnueabi | FileCheck %s --check-prefix=Vt8
11 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mattr=-neon,-crypto | FileCheck %s --check-prefix=V8-FPARMv8
12 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mattr=-fp-armv8,-crypto | FileCheck %s --check-prefix=V8-NEON
13 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mattr=-crypto | FileCheck %s --check-prefix=V8-FPARMv8-NEON
14 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi | FileCheck %s --check-prefix=V8-FPARMv8-NEON-CRYPTO
15 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a5 | FileCheck %s --check-prefix=CORTEX-A5-DEFAULT
16 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a5 -mattr=-neon,+d16 | FileCheck %s --check-prefix=CORTEX-A5-NONEON
17 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a5 -mattr=-vfp2 | FileCheck %s --check-prefix=CORTEX-A5-NOFPU
18 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a9 -float-abi=soft | FileCheck %s --check-prefix=CORTEX-A9-SOFT
19 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a9 -float-abi=hard | FileCheck %s --check-prefix=CORTEX-A9-HARD
20 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a12 | FileCheck %s --check-prefix=CORTEX-A12-DEFAULT
21 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a12 -mattr=-vfp2 | FileCheck %s --check-prefix=CORTEX-A12-NOFPU
22 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a9-mp | FileCheck %s --check-prefix=CORTEX-A9-MP
23 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a15 | FileCheck %s --check-prefix=CORTEX-A15
24 ; RUN: llc < %s -mtriple=thumbv6m-linux-gnueabi -mcpu=cortex-m0 | FileCheck %s --check-prefix=CORTEX-M0
25 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi -mcpu=cortex-m4 -float-abi=soft | FileCheck %s --check-prefix=CORTEX-M4-SOFT
26 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi -mcpu=cortex-m4 -float-abi=hard | FileCheck %s --check-prefix=CORTEX-M4-HARD
27 ; RUN: llc < %s -mtriple=armv7r-linux-gnueabi -mcpu=cortex-r5 | FileCheck %s --check-prefix=CORTEX-R5
28 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a53 | FileCheck %s --check-prefix=CORTEX-A53
29 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a57 | FileCheck %s --check-prefix=CORTEX-A57
30 ; RUN: llc < %s -mtriple=armv7-none-linux-gnueabi -mcpu=cortex-a7 | FileCheck %s  --check-prefix=CORTEX-A7-CHECK
31 ; RUN: llc < %s -mtriple=armv7-none-linux-gnueabi -mcpu=cortex-a7 -mattr=-vfp2,-vfp3,-vfp4,-neon | FileCheck %s --check-prefix=CORTEX-A7-NOFPU
32 ; RUN: llc < %s -mtriple=armv7-none-linux-gnueabi -mcpu=cortex-a7 -mattr=+vfp4,-neon | FileCheck %s --check-prefix=CORTEX-A7-FPUV4
33 ; RUN: llc < %s -mtriple=armv7-none-linux-gnueabi -mcpu=cortex-a7 -mattr=+vfp4,,+d16,-neon | FileCheck %s --check-prefix=CORTEX-A7-FPUV4
34
35 ; V6:   .eabi_attribute 6, 6
36 ; V6:   .eabi_attribute 8, 1
37 ; V6:   .eabi_attribute 24, 1
38 ; V6:   .eabi_attribute 25, 1
39 ; V6-NOT:   .eabi_attribute 27
40 ; V6-NOT:   .eabi_attribute 28
41 ; V6-NOT:    .eabi_attribute 36
42 ; V6-NOT:    .eabi_attribute 42
43 ; V6-NOT:    .eabi_attribute 68
44
45 ; V6M:  .eabi_attribute 6, 12
46 ; V6M-NOT:  .eabi_attribute 7
47 ; V6M:  .eabi_attribute 8, 0
48 ; V6M:  .eabi_attribute 9, 1
49 ; V6M:  .eabi_attribute 24, 1
50 ; V6M:  .eabi_attribute 25, 1
51 ; V6M-NOT:  .eabi_attribute 27
52 ; V6M-NOT:  .eabi_attribute 28
53 ; V6M-NOT:  .eabi_attribute 36
54 ; V6M-NOT:  .eabi_attribute 42
55 ; V6M-NOT:  .eabi_attribute 68
56
57 ; ARM1156T2F-S: .cpu arm1156t2f-s
58 ; ARM1156T2F-S: .eabi_attribute 6, 8
59 ; ARM1156T2F-S: .eabi_attribute 8, 1
60 ; ARM1156T2F-S: .eabi_attribute 9, 2
61 ; ARM1156T2F-S: .fpu vfpv2
62 ; ARM1156T2F-S: .eabi_attribute 20, 1
63 ; ARM1156T2F-S: .eabi_attribute 21, 1
64 ; ARM1156T2F-S: .eabi_attribute 23, 3
65 ; ARM1156T2F-S: .eabi_attribute 24, 1
66 ; ARM1156T2F-S: .eabi_attribute 25, 1
67 ; ARM1156T2F-S-NOT: .eabi_attribute 27
68 ; ARM1156T2F-S-NOT: .eabi_attribute 28
69 ; ARM1156T2F-S-NOT: .eabi_attribute 36
70 ; ARM1156T2F-S-NOT:    .eabi_attribute 42
71 ; ARM1156T2F-S-NOT:    .eabi_attribute 68
72
73 ; V7M:  .eabi_attribute 6, 10
74 ; V7M:  .eabi_attribute 7, 77
75 ; V7M:  .eabi_attribute 8, 0
76 ; V7M:  .eabi_attribute 9, 2
77 ; V7M:  .eabi_attribute 24, 1
78 ; V7M:  .eabi_attribute 25, 1
79 ; V7M-NOT:  .eabi_attribute 27
80 ; V7M-NOT:  .eabi_attribute 28
81 ; V7M-NOT:  .eabi_attribute 36
82 ; V7M-NOT:  .eabi_attribute 42
83 ; V7M:  .eabi_attribute 44, 0
84 ; V7M-NOT:  .eabi_attribute 68
85
86 ; V7:      .syntax unified
87 ; V7: .eabi_attribute 6, 10
88 ; V7: .eabi_attribute 20, 1
89 ; V7: .eabi_attribute 21, 1
90 ; V7: .eabi_attribute 23, 3
91 ; V7: .eabi_attribute 24, 1
92 ; V7: .eabi_attribute 25, 1
93 ; V7-NOT: .eabi_attribute 27
94 ; V7-NOT: .eabi_attribute 28
95 ; V7-NOT: .eabi_attribute 36
96 ; V7-NOT:    .eabi_attribute 42
97 ; V7-NOT:    .eabi_attribute 68
98
99 ; V8:      .syntax unified
100 ; V8: .eabi_attribute 6, 14
101
102 ; Vt8:     .syntax unified
103 ; Vt8: .eabi_attribute 6, 14
104
105 ; V8-FPARMv8:      .syntax unified
106 ; V8-FPARMv8: .eabi_attribute 6, 14
107 ; V8-FPARMv8: .fpu fp-armv8
108
109 ; V8-NEON:      .syntax unified
110 ; V8-NEON: .eabi_attribute 6, 14
111 ; V8-NEON: .fpu neon
112 ; V8-NEON: .eabi_attribute 12, 3
113
114 ; V8-FPARMv8-NEON:      .syntax unified
115 ; V8-FPARMv8-NEON: .eabi_attribute 6, 14
116 ; V8-FPARMv8-NEON: .fpu neon-fp-armv8
117 ; V8-FPARMv8-NEON: .eabi_attribute 12, 3
118
119 ; V8-FPARMv8-NEON-CRYPTO:      .syntax unified
120 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 6, 14
121 ; V8-FPARMv8-NEON-CRYPTO: .fpu crypto-neon-fp-armv8
122 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 12, 3
123
124 ; Tag_CPU_arch  'ARMv7'
125 ; CORTEX-A7-CHECK: .eabi_attribute      6, 10
126 ; CORTEX-A7-NOFPU: .eabi_attribute      6, 10
127 ; CORTEX-A7-FPUV4: .eabi_attribute      6, 10
128
129 ; Tag_CPU_arch_profile 'A'
130 ; CORTEX-A7-CHECK: .eabi_attribute      7, 65
131 ; CORTEX-A7-NOFPU: .eabi_attribute      7, 65
132 ; CORTEX-A7-FPUV4: .eabi_attribute      7, 65
133
134 ; Tag_ARM_ISA_use
135 ; CORTEX-A7-CHECK: .eabi_attribute      8, 1
136 ; CORTEX-A7-NOFPU: .eabi_attribute      8, 1
137 ; CORTEX-A7-FPUV4: .eabi_attribute      8, 1
138
139 ; Tag_THUMB_ISA_use
140 ; CORTEX-A7-CHECK: .eabi_attribute      9, 2
141 ; CORTEX-A7-NOFPU: .eabi_attribute      9, 2
142 ; CORTEX-A7-FPUV4: .eabi_attribute      9, 2
143
144 ; CORTEX-A7-CHECK: .fpu neon-vfpv4
145 ; CORTEX-A7-NOFPU-NOT: .fpu
146 ; CORTEX-A7-FPUV4: .fpu vfpv4
147
148 ; Tag_ABI_FP_denormal
149 ; CORTEX-A7-CHECK: .eabi_attribute      20, 1
150 ; CORTEX-A7-NOFPU: .eabi_attribute      20, 1
151 ; CORTEX-A7-FPUV4: .eabi_attribute      20, 1
152
153 ; Tag_ABI_FP_exceptions
154 ; CORTEX-A7-CHECK: .eabi_attribute      21, 1
155 ; CORTEX-A7-NOFPU: .eabi_attribute      21, 1
156 ; CORTEX-A7-FPUV4: .eabi_attribute      21, 1
157
158 ; Tag_ABI_FP_number_model
159 ; CORTEX-A7-CHECK: .eabi_attribute      23, 3
160 ; CORTEX-A7-NOFPU: .eabi_attribute      23, 3
161 ; CORTEX-A7-FPUV4: .eabi_attribute      23, 3
162
163 ; Tag_ABI_align_needed
164 ; CORTEX-A7-CHECK: .eabi_attribute      24, 1
165 ; CORTEX-A7-NOFPU: .eabi_attribute      24, 1
166 ; CORTEX-A7-FPUV4: .eabi_attribute      24, 1
167
168 ; Tag_ABI_align8_preserved
169 ; CORTEX-A7-CHECK: .eabi_attribute      25, 1
170 ; CORTEX-A7-NOFPU: .eabi_attribute      25, 1
171 ; CORTEX-A7-FPUV4: .eabi_attribute      25, 1
172
173 ; Tag_FP_HP_extension
174 ; CORTEX-A7-CHECK: .eabi_attribute      36, 1
175 ; CORTEX-A7-NOFPU: .eabi_attribute      36, 1
176 ; CORTEX-A7-FPUV4: .eabi_attribute      36, 1
177
178 ; Tag_MPextension_use
179 ; CORTEX-A7-CHECK: .eabi_attribute      42, 1
180 ; CORTEX-A7-NOFPU: .eabi_attribute      42, 1
181 ; CORTEX-A7-FPUV4: .eabi_attribute      42, 1
182
183 ; Tag_DIV_use
184 ; CORTEX-A7-CHECK: .eabi_attribute      44, 2
185 ; CORTEX-A7-NOFPU: .eabi_attribute      44, 2
186 ; CORTEX-A7-FPUV4: .eabi_attribute      44, 2
187
188 ; Tag_Virtualization_use
189 ; CORTEX-A7-CHECK: .eabi_attribute      68, 3
190 ; CORTEX-A7-NOFPU: .eabi_attribute      68, 3
191 ; CORTEX-A7-FPUV4: .eabi_attribute      68, 3
192
193 ; CORTEX-A5-DEFAULT:        .cpu    cortex-a5
194 ; CORTEX-A5-DEFAULT:        .eabi_attribute 6, 10
195 ; CORTEX-A5-DEFAULT:        .eabi_attribute 7, 65
196 ; CORTEX-A5-DEFAULT:        .eabi_attribute 8, 1
197 ; CORTEX-A5-DEFAULT:        .eabi_attribute 9, 2
198 ; CORTEX-A5-DEFAULT:        .fpu    neon-vfpv4
199 ; CORTEX-A5-DEFAULT:        .eabi_attribute 20, 1
200 ; CORTEX-A5-DEFAULT:        .eabi_attribute 21, 1
201 ; CORTEX-A5-DEFAULT:        .eabi_attribute 23, 3
202 ; CORTEX-A5-DEFAULT:        .eabi_attribute 24, 1
203 ; CORTEX-A5-DEFAULT:        .eabi_attribute 25, 1
204 ; CORTEX-A5-DEFAULT:        .eabi_attribute 42, 1
205 ; CORTEX-A5-DEFAULT:        .eabi_attribute 68, 1
206
207 ; CORTEX-A5-NONEON:        .cpu    cortex-a5
208 ; CORTEX-A5-NONEON:        .eabi_attribute 6, 10
209 ; CORTEX-A5-NONEON:        .eabi_attribute 7, 65
210 ; CORTEX-A5-NONEON:        .eabi_attribute 8, 1
211 ; CORTEX-A5-NONEON:        .eabi_attribute 9, 2
212 ; CORTEX-A5-NONEON:        .fpu    vfpv4-d16
213 ; CORTEX-A5-NONEON:        .eabi_attribute 20, 1
214 ; CORTEX-A5-NONEON:        .eabi_attribute 21, 1
215 ; CORTEX-A5-NONEON:        .eabi_attribute 23, 3
216 ; CORTEX-A5-NONEON:        .eabi_attribute 24, 1
217 ; CORTEX-A5-NONEON:        .eabi_attribute 25, 1
218 ; CORTEX-A5-NONEON:        .eabi_attribute 42, 1
219 ; CORTEX-A5-NONEON:        .eabi_attribute 68, 1
220
221 ; CORTEX-A5-NOFPU:        .cpu    cortex-a5
222 ; CORTEX-A5-NOFPU:        .eabi_attribute 6, 10
223 ; CORTEX-A5-NOFPU:        .eabi_attribute 7, 65
224 ; CORTEX-A5-NOFPU:        .eabi_attribute 8, 1
225 ; CORTEX-A5-NOFPU:        .eabi_attribute 9, 2
226 ; CORTEX-A5-NOFPU-NOT:    .fpu
227 ; CORTEX-A5-NOFPU:        .eabi_attribute 20, 1
228 ; CORTEX-A5-NOFPU:        .eabi_attribute 21, 1
229 ; CORTEX-A5-NOFPU:        .eabi_attribute 23, 3
230 ; CORTEX-A5-NOFPU:        .eabi_attribute 24, 1
231 ; CORTEX-A5-NOFPU:        .eabi_attribute 25, 1
232 ; CORTEX-A5-NOFPU:        .eabi_attribute 42, 1
233 ; CORTEX-A5-NOFPU:        .eabi_attribute 68, 1
234
235 ; CORTEX-A9-SOFT:  .cpu cortex-a9
236 ; CORTEX-A9-SOFT:  .eabi_attribute 6, 10
237 ; CORTEX-A9-SOFT:  .eabi_attribute 7, 65
238 ; CORTEX-A9-SOFT:  .eabi_attribute 8, 1
239 ; CORTEX-A9-SOFT:  .eabi_attribute 9, 2
240 ; CORTEX-A9-SOFT:  .fpu neon
241 ; CORTEX-A9-SOFT:  .eabi_attribute 20, 1
242 ; CORTEX-A9-SOFT:  .eabi_attribute 21, 1
243 ; CORTEX-A9-SOFT:  .eabi_attribute 23, 3
244 ; CORTEX-A9-SOFT:  .eabi_attribute 24, 1
245 ; CORTEX-A9-SOFT:  .eabi_attribute 25, 1
246 ; CORTEX-A9-SOFT-NOT:  .eabi_attribute 27
247 ; CORTEX-A9-SOFT-NOT:  .eabi_attribute 28
248 ; CORTEX-A9-SOFT:  .eabi_attribute 36, 1
249 ; CORTEX-A9-SOFT-NOT:  .eabi_attribute 42
250 ; CORTEX-A9-SOFT:  .eabi_attribute 68, 1
251
252 ; CORTEX-A9-HARD:  .cpu cortex-a9
253 ; CORTEX-A9-HARD:  .eabi_attribute 6, 10
254 ; CORTEX-A9-HARD:  .eabi_attribute 7, 65
255 ; CORTEX-A9-HARD:  .eabi_attribute 8, 1
256 ; CORTEX-A9-HARD:  .eabi_attribute 9, 2
257 ; CORTEX-A9-HARD:  .fpu neon
258 ; CORTEX-A9-HARD:  .eabi_attribute 20, 1
259 ; CORTEX-A9-HARD:  .eabi_attribute 21, 1
260 ; CORTEX-A9-HARD:  .eabi_attribute 23, 3
261 ; CORTEX-A9-HARD:  .eabi_attribute 24, 1
262 ; CORTEX-A9-HARD:  .eabi_attribute 25, 1
263 ; CORTEX-A9-HARD-NOT:  .eabi_attribute 27
264 ; CORTEX-A9-HARD:  .eabi_attribute 28, 1
265 ; CORTEX-A9-HARD:  .eabi_attribute 36, 1
266 ; CORTEX-A9-HARD-NOT:  .eabi_attribute 42
267 ; CORTEX-A9-HARD:  .eabi_attribute 68, 1
268
269 ; CORTEX-A9-MP:  .cpu cortex-a9-mp
270 ; CORTEX-A9-MP:  .eabi_attribute 6, 10
271 ; CORTEX-A9-MP:  .eabi_attribute 7, 65
272 ; CORTEX-A9-MP:  .eabi_attribute 8, 1
273 ; CORTEX-A9-MP:  .eabi_attribute 9, 2
274 ; CORTEX-A9-MP:  .fpu neon
275 ; CORTEX-A9-MP:  .eabi_attribute 20, 1
276 ; CORTEX-A9-MP:  .eabi_attribute 21, 1
277 ; CORTEX-A9-MP:  .eabi_attribute 23, 3
278 ; CORTEX-A9-MP:  .eabi_attribute 24, 1
279 ; CORTEX-A9-MP:  .eabi_attribute 25, 1
280 ; CORTEX-A9-NOT:  .eabi_attribute 27
281 ; CORTEX-A9-NOT:  .eabi_attribute 28
282 ; CORTEX-A9-MP:  .eabi_attribute 36, 1
283 ; CORTEX-A9-MP:  .eabi_attribute 42, 1
284 ; CORTEX-A9-MP:  .eabi_attribute 68, 1
285
286 ; CORTEX-A12-DEFAULT:  .cpu cortex-a12
287 ; CORTEX-A12-DEFAULT:  .eabi_attribute 6, 10
288 ; CORTEX-A12-DEFAULT:  .eabi_attribute 7, 65
289 ; CORTEX-A12-DEFAULT:  .eabi_attribute 8, 1
290 ; CORTEX-A12-DEFAULT:  .eabi_attribute 9, 2
291 ; CORTEX-A12-DEFAULT:  .fpu neon-vfpv4
292 ; CORTEX-A12-DEFAULT:  .eabi_attribute 20, 1
293 ; CORTEX-A12-DEFAULT:  .eabi_attribute 21, 1
294 ; CORTEX-A12-DEFAULT:  .eabi_attribute 23, 3
295 ; CORTEX-A12-DEFAULT:  .eabi_attribute 24, 1
296 ; CORTEX-A12-DEFAULT:  .eabi_attribute 25, 1
297 ; CORTEX-A12-DEFAULT:  .eabi_attribute 42, 1
298 ; CORTEX-A12-DEFAULT:  .eabi_attribute 44, 2
299 ; CORTEX-A12-DEFAULT:  .eabi_attribute 68, 3
300
301 ; CORTEX-A12-NOFPU:  .cpu cortex-a12
302 ; CORTEX-A12-NOFPU:  .eabi_attribute 6, 10
303 ; CORTEX-A12-NOFPU:  .eabi_attribute 7, 65
304 ; CORTEX-A12-NOFPU:  .eabi_attribute 8, 1
305 ; CORTEX-A12-NOFPU:  .eabi_attribute 9, 2
306 ; CORTEX-A12-NOFPU-NOT:  .fpu
307 ; CORTEX-A12-NOFPU:  .eabi_attribute 20, 1
308 ; CORTEX-A12-NOFPU:  .eabi_attribute 21, 1
309 ; CORTEX-A12-NOFPU:  .eabi_attribute 23, 3
310 ; CORTEX-A12-NOFPU:  .eabi_attribute 24, 1
311 ; CORTEX-A12-NOFPU:  .eabi_attribute 25, 1
312 ; CORTEX-A12-NOFPU:  .eabi_attribute 42, 1
313 ; CORTEX-A12-NOFPU:  .eabi_attribute 44, 2
314 ; CORTEX-A12-NOFPU:  .eabi_attribute 68, 3
315
316 ; CORTEX-A15: .cpu cortex-a15
317 ; CORTEX-A15: .eabi_attribute 6, 10
318 ; CORTEX-A15: .eabi_attribute 7, 65
319 ; CORTEX-A15: .eabi_attribute 8, 1
320 ; CORTEX-A15: .eabi_attribute 9, 2
321 ; CORTEX-A15: .fpu neon-vfpv4
322 ; CORTEX-A15: .eabi_attribute 20, 1
323 ; CORTEX-A15: .eabi_attribute 21, 1
324 ; CORTEX-A15: .eabi_attribute 23, 3
325 ; CORTEX-A15: .eabi_attribute 24, 1
326 ; CORTEX-A15: .eabi_attribute 25, 1
327 ; CORTEX-A15-NOT: .eabi_attribute 27
328 ; CORTEX-A15-NOT: .eabi_attribute 28
329 ; CORTEX-A15: .eabi_attribute 36, 1
330 ; CORTEX-A15: .eabi_attribute 42, 1
331 ; CORTEX-A15: .eabi_attribute 44, 2
332 ; CORTEX-A15: .eabi_attribute 68, 3
333
334 ; CORTEX-M0:  .cpu cortex-m0
335 ; CORTEX-M0:  .eabi_attribute 6, 12
336 ; CORTEX-M0-NOT:  .eabi_attribute 7
337 ; CORTEX-M0:  .eabi_attribute 8, 0
338 ; CORTEX-M0:  .eabi_attribute 9, 1
339 ; CORTEX-M0:  .eabi_attribute 24, 1
340 ; CORTEX-M0:  .eabi_attribute 25, 1
341 ; CORTEX-M0-NOT:  .eabi_attribute 27
342 ; CORTEX-M0-NOT:  .eabi_attribute 28
343 ; CORTEX-M0-NOT:  .eabi_attribute 36
344 ; CORTEX-M0-NOT:  .eabi_attribute 42
345 ; CORTEX-M0-NOT:  .eabi_attribute 68
346
347 ; CORTEX-M4-SOFT:  .cpu cortex-m4
348 ; CORTEX-M4-SOFT:  .eabi_attribute 6, 13
349 ; CORTEX-M4-SOFT:  .eabi_attribute 7, 77
350 ; CORTEX-M4-SOFT:  .eabi_attribute 8, 0
351 ; CORTEX-M4-SOFT:  .eabi_attribute 9, 2
352 ; CORTEX-M4-SOFT:  .fpu vfpv4-d16
353 ; CORTEX-M4-SOFT:  .eabi_attribute 20, 1
354 ; CORTEX-M4-SOFT:  .eabi_attribute 21, 1
355 ; CORTEX-M4-SOFT:  .eabi_attribute 23, 3
356 ; CORTEX-M4-SOFT:  .eabi_attribute 24, 1
357 ; CORTEX-M4-SOFT:  .eabi_attribute 25, 1
358 ; CORTEX-M4-SOFT:  .eabi_attribute 27, 1
359 ; CORTEX-M4-SOFT-NOT:  .eabi_attribute 28
360 ; CORTEX-M4-SOFT:  .eabi_attribute 36, 1
361 ; CORTEX-M4-SOFT-NOT:  .eabi_attribute 42
362 ; CORTEX-M4-SOFT:  .eabi_attribute 44, 0
363 ; CORTEX-M4-SOFT-NOT:  .eabi_attribute 68
364
365 ; CORTEX-M4-HARD:  .cpu cortex-m4
366 ; CORTEX-M4-HARD:  .eabi_attribute 6, 13
367 ; CORTEX-M4-HARD:  .eabi_attribute 7, 77
368 ; CORTEX-M4-HARD:  .eabi_attribute 8, 0
369 ; CORTEX-M4-HARD:  .eabi_attribute 9, 2
370 ; CORTEX-M4-HARD:  .fpu vfpv4-d16
371 ; CORTEX-M4-HARD:  .eabi_attribute 20, 1
372 ; CORTEX-M4-HARD:  .eabi_attribute 21, 1
373 ; CORTEX-M4-HARD:  .eabi_attribute 23, 3
374 ; CORTEX-M4-HARD:  .eabi_attribute 24, 1
375 ; CORTEX-M4-HARD:  .eabi_attribute 25, 1
376 ; CORTEX-M4-HARD:  .eabi_attribute 27, 1
377 ; CORTEX-M4-HARD:  .eabi_attribute 28, 1
378 ; CORTEX-M4-HARD:  .eabi_attribute 36, 1
379 ; CORTEX-M4-HARD-NOT:  .eabi_attribute 42
380 ; CORTEX-M4-HARD:  .eabi_attribute 44, 0
381 ; CORTEX-M4-HRAD-NOT:  .eabi_attribute 68
382
383 ; CORTEX-R5:  .cpu cortex-r5
384 ; CORTEX-R5:  .eabi_attribute 6, 10
385 ; CORTEX-R5:  .eabi_attribute 7, 82
386 ; CORTEX-R5:  .eabi_attribute 8, 1
387 ; CORTEX-R5:  .eabi_attribute 9, 2
388 ; CORTEX-R5:  .fpu vfpv3-d16
389 ; CORTEX-R5:  .eabi_attribute 20, 1
390 ; CORTEX-R5:  .eabi_attribute 21, 1
391 ; CORTEX-R5:  .eabi_attribute 23, 3
392 ; CORTEX-R5:  .eabi_attribute 24, 1
393 ; CORTEX-R5:  .eabi_attribute 25, 1
394 ; CORTEX-R5:  .eabi_attribute 27, 1
395 ; CORTEX-R5-NOT:  .eabi_attribute 28
396 ; CORTEX-R5-NOT:  .eabi_attribute 36
397 ; CORTEX-R5-NOT:  .eabi_attribute 42
398 ; CORTEX-R5:  .eabi_attribute 44, 2
399 ; CORTEX-R5-NOT:  .eabi_attribute 68
400
401 ; CORTEX-A53:  .cpu cortex-a53
402 ; CORTEX-A53:  .eabi_attribute 6, 14
403 ; CORTEX-A53:  .eabi_attribute 7, 65
404 ; CORTEX-A53:  .eabi_attribute 8, 1
405 ; CORTEX-A53:  .eabi_attribute 9, 2
406 ; CORTEX-A53:  .fpu crypto-neon-fp-armv8
407 ; CORTEX-A53:  .eabi_attribute 12, 3
408 ; CORTEX-A53:  .eabi_attribute 24, 1
409 ; CORTEX-A53:  .eabi_attribute 25, 1
410 ; CORTEX-A53-NOT:  .eabi_attribute 27
411 ; CORTEX-A53-NOT:  .eabi_attribute 28
412 ; CORTEX-A53:  .eabi_attribute 36, 1
413 ; CORTEX-A53:  .eabi_attribute 42, 1
414 ; CORTEX-A53:  .eabi_attribute 44, 2
415 ; CORTEX-A53:  .eabi_attribute 68, 3
416
417 ; CORTEX-A57:  .cpu cortex-a57
418 ; CORTEX-A57:  .eabi_attribute 6, 14
419 ; CORTEX-A57:  .eabi_attribute 7, 65
420 ; CORTEX-A57:  .eabi_attribute 8, 1
421 ; CORTEX-A57:  .eabi_attribute 9, 2
422 ; CORTEX-A57:  .fpu crypto-neon-fp-armv8
423 ; CORTEX-A57:  .eabi_attribute 12, 3
424 ; CORTEX-A57:  .eabi_attribute 24, 1
425 ; CORTEX-A57:  .eabi_attribute 25, 1
426 ; CORTEX-A57-NOT:  .eabi_attribute 27
427 ; CORTEX-A57-NOT:  .eabi_attribute 28
428 ; CORTEX-A57:  .eabi_attribute 36, 1
429 ; CORTEX-A57:  .eabi_attribute 42, 1
430 ; CORTEX-A57:  .eabi_attribute 44, 2
431 ; CORTEX-A57:  .eabi_attribute 68, 3
432
433 define i32 @f(i64 %z) {
434         ret i32 0
435 }