1 ; This tests that MC/asm header conversion is smooth and that the
2 ; build attributes are correct
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-a9 -float-abi=soft | FileCheck %s --check-prefix=CORTEX-A9-SOFT
16 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a9 -float-abi=hard | FileCheck %s --check-prefix=CORTEX-A9-HARD
17 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a9-mp | FileCheck %s --check-prefix=CORTEX-A9-MP
18 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a15 | FileCheck %s --check-prefix=CORTEX-A15
19 ; RUN: llc < %s -mtriple=thumbv6m-linux-gnueabi -mcpu=cortex-m0 | FileCheck %s --check-prefix=CORTEX-M0
20 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi -mcpu=cortex-m4 -float-abi=soft | FileCheck %s --check-prefix=CORTEX-M4-SOFT
21 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi -mcpu=cortex-m4 -float-abi=hard | FileCheck %s --check-prefix=CORTEX-M4-HARD
22 ; RUN: llc < %s -mtriple=armv7r-linux-gnueabi -mcpu=cortex-r5 | FileCheck %s --check-prefix=CORTEX-R5
23 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a53 | FileCheck %s --check-prefix=CORTEX-A53
24 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a57 | FileCheck %s --check-prefix=CORTEX-A57
26 ; V6: .eabi_attribute 6, 6
27 ; V6: .eabi_attribute 8, 1
28 ; V6: .eabi_attribute 24, 1
29 ; V6: .eabi_attribute 25, 1
30 ; V6-NOT: .eabi_attribute 27
31 ; V6-NOT: .eabi_attribute 28
32 ; V6-NOT: .eabi_attribute 36
33 ; V6-NOT: .eabi_attribute 42
34 ; V6-NOT: .eabi_attribute 68
36 ; V6M: .eabi_attribute 6, 12
37 ; V6M: .eabi_attribute 7, 77
38 ; V6M: .eabi_attribute 8, 0
39 ; V6M: .eabi_attribute 9, 1
40 ; V6M: .eabi_attribute 24, 1
41 ; V6M: .eabi_attribute 25, 1
42 ; V6M-NOT: .eabi_attribute 27
43 ; V6M-NOT: .eabi_attribute 28
44 ; V6M-NOT: .eabi_attribute 36
45 ; V6M-NOT: .eabi_attribute 42
46 ; V6M-NOT: .eabi_attribute 68
48 ; ARM1156T2F-S: .cpu arm1156t2f-s
49 ; ARM1156T2F-S: .eabi_attribute 6, 8
50 ; ARM1156T2F-S: .eabi_attribute 8, 1
51 ; ARM1156T2F-S: .eabi_attribute 9, 2
52 ; ARM1156T2F-S: .fpu vfpv2
53 ; ARM1156T2F-S: .eabi_attribute 20, 1
54 ; ARM1156T2F-S: .eabi_attribute 21, 1
55 ; ARM1156T2F-S: .eabi_attribute 23, 3
56 ; ARM1156T2F-S: .eabi_attribute 24, 1
57 ; ARM1156T2F-S: .eabi_attribute 25, 1
58 ; ARM1156T2F-S-NOT: .eabi_attribute 27
59 ; ARM1156T2F-S-NOT: .eabi_attribute 28
60 ; ARM1156T2F-S-NOT: .eabi_attribute 36
61 ; ARM1156T2F-S-NOT: .eabi_attribute 42
62 ; ARM1156T2F-S-NOT: .eabi_attribute 68
64 ; V7M: .eabi_attribute 6, 10
65 ; V7M: .eabi_attribute 7, 77
66 ; V7M: .eabi_attribute 8, 0
67 ; V7M: .eabi_attribute 9, 2
68 ; V7M: .eabi_attribute 24, 1
69 ; V7M: .eabi_attribute 25, 1
70 ; V7M-NOT: .eabi_attribute 27
71 ; V7M-NOT: .eabi_attribute 28
72 ; V7M-NOT: .eabi_attribute 36
73 ; V7M-NOT: .eabi_attribute 42
74 ; V7M: .eabi_attribute 44, 0
75 ; V7M-NOT: .eabi_attribute 68
78 ; V7: .eabi_attribute 6, 10
79 ; V7: .eabi_attribute 20, 1
80 ; V7: .eabi_attribute 21, 1
81 ; V7: .eabi_attribute 23, 3
82 ; V7: .eabi_attribute 24, 1
83 ; V7: .eabi_attribute 25, 1
84 ; V7-NOT: .eabi_attribute 27
85 ; V7-NOT: .eabi_attribute 28
86 ; V7-NOT: .eabi_attribute 36
87 ; V7-NOT: .eabi_attribute 42
88 ; V7-NOT: .eabi_attribute 68
91 ; V8: .eabi_attribute 6, 14
93 ; Vt8: .syntax unified
94 ; Vt8: .eabi_attribute 6, 14
96 ; V8-FPARMv8: .syntax unified
97 ; V8-FPARMv8: .eabi_attribute 6, 14
98 ; V8-FPARMv8: .fpu fp-armv8
100 ; V8-NEON: .syntax unified
101 ; V8-NEON: .eabi_attribute 6, 14
103 ; V8-NEON: .eabi_attribute 12, 3
105 ; V8-FPARMv8-NEON: .syntax unified
106 ; V8-FPARMv8-NEON: .eabi_attribute 6, 14
107 ; V8-FPARMv8-NEON: .fpu neon-fp-armv8
108 ; V8-FPARMv8-NEON: .eabi_attribute 12, 3
110 ; V8-FPARMv8-NEON-CRYPTO: .syntax unified
111 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 6, 14
112 ; V8-FPARMv8-NEON-CRYPTO: .fpu crypto-neon-fp-armv8
113 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 12, 3
115 ; CORTEX-A9-SOFT: .cpu cortex-a9
116 ; CORTEX-A9-SOFT: .eabi_attribute 6, 10
117 ; CORTEX-A9-SOFT: .eabi_attribute 7, 65
118 ; CORTEX-A9-SOFT: .eabi_attribute 8, 1
119 ; CORTEX-A9-SOFT: .eabi_attribute 9, 2
120 ; CORTEX-A9-SOFT: .fpu neon
121 ; CORTEX-A9-SOFT: .eabi_attribute 20, 1
122 ; CORTEX-A9-SOFT: .eabi_attribute 21, 1
123 ; CORTEX-A9-SOFT: .eabi_attribute 23, 3
124 ; CORTEX-A9-SOFT: .eabi_attribute 24, 1
125 ; CORTEX-A9-SOFT: .eabi_attribute 25, 1
126 ; CORTEX-A9-SOFT-NOT: .eabi_attribute 27
127 ; CORTEX-A9-SOFT-NOT: .eabi_attribute 28
128 ; CORTEX-A9-SOFT: .eabi_attribute 36, 1
129 ; CORTEX-A9-SOFT-NOT: .eabi_attribute 42
130 ; CORTEX-A9-SOFT: .eabi_attribute 68, 1
132 ; CORTEX-A9-HARD: .cpu cortex-a9
133 ; CORTEX-A9-HARD: .eabi_attribute 6, 10
134 ; CORTEX-A9-HARD: .eabi_attribute 7, 65
135 ; CORTEX-A9-HARD: .eabi_attribute 8, 1
136 ; CORTEX-A9-HARD: .eabi_attribute 9, 2
137 ; CORTEX-A9-HARD: .fpu neon
138 ; CORTEX-A9-HARD: .eabi_attribute 20, 1
139 ; CORTEX-A9-HARD: .eabi_attribute 21, 1
140 ; CORTEX-A9-HARD: .eabi_attribute 23, 3
141 ; CORTEX-A9-HARD: .eabi_attribute 24, 1
142 ; CORTEX-A9-HARD: .eabi_attribute 25, 1
143 ; CORTEX-A9-HARD-NOT: .eabi_attribute 27
144 ; CORTEX-A9-HARD: .eabi_attribute 28, 1
145 ; CORTEX-A9-HARD: .eabi_attribute 36, 1
146 ; CORTEX-A9-HARD-NOT: .eabi_attribute 42
147 ; CORTEX-A9-HARD: .eabi_attribute 68, 1
149 ; CORTEX-A9-MP: .cpu cortex-a9-mp
150 ; CORTEX-A9-MP: .eabi_attribute 6, 10
151 ; CORTEX-A9-MP: .eabi_attribute 7, 65
152 ; CORTEX-A9-MP: .eabi_attribute 8, 1
153 ; CORTEX-A9-MP: .eabi_attribute 9, 2
154 ; CORTEX-A9-MP: .fpu neon
155 ; CORTEX-A9-MP: .eabi_attribute 20, 1
156 ; CORTEX-A9-MP: .eabi_attribute 21, 1
157 ; CORTEX-A9-MP: .eabi_attribute 23, 3
158 ; CORTEX-A9-MP: .eabi_attribute 24, 1
159 ; CORTEX-A9-MP: .eabi_attribute 25, 1
160 ; CORTEX-A9-NOT: .eabi_attribute 27
161 ; CORTEX-A9-NOT: .eabi_attribute 28
162 ; CORTEX-A9-MP: .eabi_attribute 36, 1
163 ; CORTEX-A9-MP: .eabi_attribute 42, 1
164 ; CORTEX-A9-MP: .eabi_attribute 68, 1
166 ; CORTEX-A15: .cpu cortex-a15
167 ; CORTEX-A15: .eabi_attribute 6, 10
168 ; CORTEX-A15: .eabi_attribute 7, 65
169 ; CORTEX-A15: .eabi_attribute 8, 1
170 ; CORTEX-A15: .eabi_attribute 9, 2
171 ; CORTEX-A15: .fpu neon-vfpv4
172 ; CORTEX-A15: .eabi_attribute 20, 1
173 ; CORTEX-A15: .eabi_attribute 21, 1
174 ; CORTEX-A15: .eabi_attribute 23, 3
175 ; CORTEX-A15: .eabi_attribute 24, 1
176 ; CORTEX-A15: .eabi_attribute 25, 1
177 ; CORTEX-A15-NOT: .eabi_attribute 27
178 ; CORTEX-A15-NOT: .eabi_attribute 28
179 ; CORTEX-A15: .eabi_attribute 36, 1
180 ; CORTEX-A15: .eabi_attribute 42, 1
181 ; CORTEX-A15: .eabi_attribute 44, 2
182 ; CORTEX-A15: .eabi_attribute 68, 3
184 ; CORTEX-M0: .cpu cortex-m0
185 ; CORTEX-M0: .eabi_attribute 6, 12
186 ; CORTEX-M0: .eabi_attribute 7, 77
187 ; CORTEX-M0: .eabi_attribute 8, 0
188 ; CORTEX-M0: .eabi_attribute 9, 1
189 ; CORTEX-M0: .eabi_attribute 24, 1
190 ; CORTEX-M0: .eabi_attribute 25, 1
191 ; CORTEX-M0-NOT: .eabi_attribute 27
192 ; CORTEX-M0-NOT: .eabi_attribute 28
193 ; CORTEX-M0-NOT: .eabi_attribute 36
194 ; CORTEX-M0-NOT: .eabi_attribute 42
195 ; CORTEX-M0-NOT: .eabi_attribute 68
197 ; CORTEX-M4-SOFT: .cpu cortex-m4
198 ; CORTEX-M4-SOFT: .eabi_attribute 6, 13
199 ; CORTEX-M4-SOFT: .eabi_attribute 7, 77
200 ; CORTEX-M4-SOFT: .eabi_attribute 8, 0
201 ; CORTEX-M4-SOFT: .eabi_attribute 9, 2
202 ; CORTEX-M4-SOFT: .fpu vfpv4-d16
203 ; CORTEX-M4-SOFT: .eabi_attribute 20, 1
204 ; CORTEX-M4-SOFT: .eabi_attribute 21, 1
205 ; CORTEX-M4-SOFT: .eabi_attribute 23, 3
206 ; CORTEX-M4-SOFT: .eabi_attribute 24, 1
207 ; CORTEX-M4-SOFT: .eabi_attribute 25, 1
208 ; CORTEX-M4-SOFT: .eabi_attribute 27, 1
209 ; CORTEX-M4-SOFT-NOT: .eabi_attribute 28
210 ; CORTEX-M4-SOFT: .eabi_attribute 36, 1
211 ; CORTEX-M4-SOFT-NOT: .eabi_attribute 42
212 ; CORTEX-M4-SOFT: .eabi_attribute 44, 0
213 ; CORTEX-M4-SOFT-NOT: .eabi_attribute 68
215 ; CORTEX-M4-HARD: .cpu cortex-m4
216 ; CORTEX-M4-HARD: .eabi_attribute 6, 13
217 ; CORTEX-M4-HARD: .eabi_attribute 7, 77
218 ; CORTEX-M4-HARD: .eabi_attribute 8, 0
219 ; CORTEX-M4-HARD: .eabi_attribute 9, 2
220 ; CORTEX-M4-HARD: .fpu vfpv4-d16
221 ; CORTEX-M4-HARD: .eabi_attribute 20, 1
222 ; CORTEX-M4-HARD: .eabi_attribute 21, 1
223 ; CORTEX-M4-HARD: .eabi_attribute 23, 3
224 ; CORTEX-M4-HARD: .eabi_attribute 24, 1
225 ; CORTEX-M4-HARD: .eabi_attribute 25, 1
226 ; CORTEX-M4-HARD: .eabi_attribute 27, 1
227 ; CORTEX-M4-HARD: .eabi_attribute 28, 1
228 ; CORTEX-M4-HARD: .eabi_attribute 36, 1
229 ; CORTEX-M4-HARD-NOT: .eabi_attribute 42
230 ; CORTEX-M4-HARD: .eabi_attribute 44, 0
231 ; CORTEX-M4-HRAD-NOT: .eabi_attribute 68
233 ; CORTEX-R5: .cpu cortex-r5
234 ; CORTEX-R5: .eabi_attribute 6, 10
235 ; CORTEX-R5: .eabi_attribute 7, 82
236 ; CORTEX-R5: .eabi_attribute 8, 1
237 ; CORTEX-R5: .eabi_attribute 9, 2
238 ; CORTEX-R5: .fpu vfpv3-d16
239 ; CORTEX-R5: .eabi_attribute 20, 1
240 ; CORTEX-R5: .eabi_attribute 21, 1
241 ; CORTEX-R5: .eabi_attribute 23, 3
242 ; CORTEX-R5: .eabi_attribute 24, 1
243 ; CORTEX-R5: .eabi_attribute 25, 1
244 ; CORTEX-R5: .eabi_attribute 27, 1
245 ; CORTEX-R5-NOT: .eabi_attribute 28
246 ; CORTEX-R5-NOT: .eabi_attribute 36
247 ; CORTEX-R5-NOT: .eabi_attribute 42
248 ; CORTEX-R5: .eabi_attribute 44, 2
249 ; CORTEX-R5-NOT: .eabi_attribute 68
251 ; CORTEX-A53: .cpu cortex-a53
252 ; CORTEX-A53: .eabi_attribute 6, 14
253 ; CORTEX-A53: .eabi_attribute 7, 65
254 ; CORTEX-A53: .eabi_attribute 8, 1
255 ; CORTEX-A53: .eabi_attribute 9, 2
256 ; CORTEX-A53: .fpu crypto-neon-fp-armv8
257 ; CORTEX-A53: .eabi_attribute 12, 3
258 ; CORTEX-A53: .eabi_attribute 24, 1
259 ; CORTEX-A53: .eabi_attribute 25, 1
260 ; CORTEX-A53-NOT: .eabi_attribute 27
261 ; CORTEX-A53-NOT: .eabi_attribute 28
262 ; CORTEX-A53: .eabi_attribute 36, 1
263 ; CORTEX-A53: .eabi_attribute 42, 1
264 ; CORTEX-A53: .eabi_attribute 44, 2
265 ; CORTEX-A53: .eabi_attribute 68, 3
267 ; CORTEX-A57: .cpu cortex-a57
268 ; CORTEX-A57: .eabi_attribute 6, 14
269 ; CORTEX-A57: .eabi_attribute 7, 65
270 ; CORTEX-A57: .eabi_attribute 8, 1
271 ; CORTEX-A57: .eabi_attribute 9, 2
272 ; CORTEX-A57: .fpu crypto-neon-fp-armv8
273 ; CORTEX-A57: .eabi_attribute 12, 3
274 ; CORTEX-A57: .eabi_attribute 24, 1
275 ; CORTEX-A57: .eabi_attribute 25, 1
276 ; CORTEX-A57-NOT: .eabi_attribute 27
277 ; CORTEX-A57-NOT: .eabi_attribute 28
278 ; CORTEX-A57: .eabi_attribute 36, 1
279 ; CORTEX-A57: .eabi_attribute 42, 1
280 ; CORTEX-A57: .eabi_attribute 44, 2
281 ; CORTEX-A57: .eabi_attribute 68, 3
283 define i32 @f(i64 %z) {