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