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