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