[ARM] Add Virtualization subtarget feature and more build attributes in this area
[oota-llvm.git] / test / CodeGen / ARM / 2010-09-29-mc-asm-header-test.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-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
25
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 42
33 ; V6-NOT:    .eabi_attribute 68
34
35 ; V6M:  .eabi_attribute 6, 12
36 ; V6M:  .eabi_attribute 7, 77
37 ; V6M:  .eabi_attribute 8, 0
38 ; V6M:  .eabi_attribute 9, 1
39 ; V6M:  .eabi_attribute 24, 1
40 ; V6M:  .eabi_attribute 25, 1
41 ; V6M-NOT:  .eabi_attribute 27
42 ; V6M-NOT:  .eabi_attribute 28
43 ; V6M-NOT:  .eabi_attribute 42
44 ; V6M-NOT:  .eabi_attribute 68
45
46 ; ARM1156T2F-S: .cpu arm1156t2f-s
47 ; ARM1156T2F-S: .eabi_attribute 6, 8
48 ; ARM1156T2F-S: .eabi_attribute 8, 1
49 ; ARM1156T2F-S: .eabi_attribute 9, 2
50 ; ARM1156T2F-S: .fpu vfpv2
51 ; ARM1156T2F-S: .eabi_attribute 20, 1
52 ; ARM1156T2F-S: .eabi_attribute 21, 1
53 ; ARM1156T2F-S: .eabi_attribute 23, 3
54 ; ARM1156T2F-S: .eabi_attribute 24, 1
55 ; ARM1156T2F-S: .eabi_attribute 25, 1
56 ; ARM1156T2F-S-NOT: .eabi_attribute 27
57 ; ARM1156T2F-S-NOT: .eabi_attribute 28
58 ; ARM1156T2F-S-NOT:    .eabi_attribute 42
59 ; ARM1156T2F-S-NOT:    .eabi_attribute 68
60
61 ; V7M:  .eabi_attribute 6, 10
62 ; V7M:  .eabi_attribute 7, 77
63 ; V7M:  .eabi_attribute 8, 0
64 ; V7M:  .eabi_attribute 9, 2
65 ; V7M:  .eabi_attribute 24, 1
66 ; V7M:  .eabi_attribute 25, 1
67 ; V7M-NOT:  .eabi_attribute 27
68 ; V7M-NOT:  .eabi_attribute 28
69 ; V7M-NOT:  .eabi_attribute 42
70 ; V7M:  .eabi_attribute 44, 0
71 ; V7M-NOT:  .eabi_attribute 68
72
73 ; V7:      .syntax unified
74 ; V7: .eabi_attribute 6, 10
75 ; V7: .eabi_attribute 20, 1
76 ; V7: .eabi_attribute 21, 1
77 ; V7: .eabi_attribute 23, 3
78 ; V7: .eabi_attribute 24, 1
79 ; V7: .eabi_attribute 25, 1
80 ; V7-NOT: .eabi_attribute 27
81 ; V7-NOT: .eabi_attribute 28
82 ; V7-NOT:    .eabi_attribute 42
83 ; V7-NOT:    .eabi_attribute 68
84
85 ; V8:      .syntax unified
86 ; V8: .eabi_attribute 6, 14
87
88 ; Vt8:     .syntax unified
89 ; Vt8: .eabi_attribute 6, 14
90
91 ; V8-FPARMv8:      .syntax unified
92 ; V8-FPARMv8: .eabi_attribute 6, 14
93 ; V8-FPARMv8: .fpu fp-armv8
94
95 ; V8-NEON:      .syntax unified
96 ; V8-NEON: .eabi_attribute 6, 14
97 ; V8-NEON: .fpu neon
98 ; V8-NEON: .eabi_attribute 12, 3
99
100 ; V8-FPARMv8-NEON:      .syntax unified
101 ; V8-FPARMv8-NEON: .eabi_attribute 6, 14
102 ; V8-FPARMv8-NEON: .fpu neon-fp-armv8
103 ; V8-FPARMv8-NEON: .eabi_attribute 12, 3
104
105 ; V8-FPARMv8-NEON-CRYPTO:      .syntax unified
106 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 6, 14
107 ; V8-FPARMv8-NEON-CRYPTO: .fpu crypto-neon-fp-armv8
108 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 12, 3
109
110 ; CORTEX-A9-SOFT:  .cpu cortex-a9
111 ; CORTEX-A9-SOFT:  .eabi_attribute 6, 10
112 ; CORTEX-A9-SOFT:  .eabi_attribute 7, 65
113 ; CORTEX-A9-SOFT:  .eabi_attribute 8, 1
114 ; CORTEX-A9-SOFT:  .eabi_attribute 9, 2
115 ; CORTEX-A9-SOFT:  .fpu neon
116 ; CORTEX-A9-SOFT:  .eabi_attribute 20, 1
117 ; CORTEX-A9-SOFT:  .eabi_attribute 21, 1
118 ; CORTEX-A9-SOFT:  .eabi_attribute 23, 3
119 ; CORTEX-A9-SOFT:  .eabi_attribute 24, 1
120 ; CORTEX-A9-SOFT:  .eabi_attribute 25, 1
121 ; CORTEX-A9-SOFT-NOT:  .eabi_attribute 27
122 ; CORTEX-A9-SOFT-NOT:  .eabi_attribute 28
123 ; CORTEX-A9-SOFT-NOT:  .eabi_attribute 42
124 ; CORTEX-A9-SOFT:  .eabi_attribute 68, 1
125
126 ; CORTEX-A9-HARD:  .cpu cortex-a9
127 ; CORTEX-A9-HARD:  .eabi_attribute 6, 10
128 ; CORTEX-A9-HARD:  .eabi_attribute 7, 65
129 ; CORTEX-A9-HARD:  .eabi_attribute 8, 1
130 ; CORTEX-A9-HARD:  .eabi_attribute 9, 2
131 ; CORTEX-A9-HARD:  .fpu neon
132 ; CORTEX-A9-HARD:  .eabi_attribute 20, 1
133 ; CORTEX-A9-HARD:  .eabi_attribute 21, 1
134 ; CORTEX-A9-HARD:  .eabi_attribute 23, 3
135 ; CORTEX-A9-HARD:  .eabi_attribute 24, 1
136 ; CORTEX-A9-HARD:  .eabi_attribute 25, 1
137 ; CORTEX-A9-HARD-NOT:  .eabi_attribute 27
138 ; CORTEX-A9-HARD:  .eabi_attribute 28, 1
139 ; CORTEX-A9-HARD-NOT:  .eabi_attribute 42
140 ; CORTEX-A9-HARD:  .eabi_attribute 68, 1
141
142 ; CORTEX-A9-MP:  .cpu cortex-a9-mp
143 ; CORTEX-A9-MP:  .eabi_attribute 6, 10
144 ; CORTEX-A9-MP:  .eabi_attribute 7, 65
145 ; CORTEX-A9-MP:  .eabi_attribute 8, 1
146 ; CORTEX-A9-MP:  .eabi_attribute 9, 2
147 ; CORTEX-A9-MP:  .fpu neon
148 ; CORTEX-A9-MP:  .eabi_attribute 20, 1
149 ; CORTEX-A9-MP:  .eabi_attribute 21, 1
150 ; CORTEX-A9-MP:  .eabi_attribute 23, 3
151 ; CORTEX-A9-MP:  .eabi_attribute 24, 1
152 ; CORTEX-A9-MP:  .eabi_attribute 25, 1
153 ; CORTEX-A9-NOT:  .eabi_attribute 27
154 ; CORTEX-A9-NOT:  .eabi_attribute 28
155 ; CORTEX-A9-MP:  .eabi_attribute 42, 1
156 ; CORTEX-A9-MP:  .eabi_attribute 68, 1
157
158 ; CORTEX-A15: .cpu cortex-a15
159 ; CORTEX-A15: .eabi_attribute 6, 10
160 ; CORTEX-A15: .eabi_attribute 7, 65
161 ; CORTEX-A15: .eabi_attribute 8, 1
162 ; CORTEX-A15: .eabi_attribute 9, 2
163 ; CORTEX-A15: .fpu neon-vfpv4
164 ; CORTEX-A15: .eabi_attribute 20, 1
165 ; CORTEX-A15: .eabi_attribute 21, 1
166 ; CORTEX-A15: .eabi_attribute 23, 3
167 ; CORTEX-A15: .eabi_attribute 24, 1
168 ; CORTEX-A15: .eabi_attribute 25, 1
169 ; CORTEX-A15: .eabi_attribute 42, 1
170 ; CORTEX-A15: .eabi_attribute 44, 2
171 ; CORTEX-A15-NOT: .eabi_attribute 27
172 ; CORTEX-A15-NOT: .eabi_attribute 28
173 ; CORTEX-A15: .eabi_attribute 68, 3
174
175 ; CORTEX-M0:  .cpu cortex-m0
176 ; CORTEX-M0:  .eabi_attribute 6, 12
177 ; CORTEX-M0:  .eabi_attribute 7, 77
178 ; CORTEX-M0:  .eabi_attribute 8, 0
179 ; CORTEX-M0:  .eabi_attribute 9, 1
180 ; CORTEX-M0:  .eabi_attribute 24, 1
181 ; CORTEX-M0:  .eabi_attribute 25, 1
182 ; CORTEX-M0-NOT:  .eabi_attribute 27
183 ; CORTEX-M0-NOT:  .eabi_attribute 28
184 ; CORTEX-M0-NOT:  .eabi_attribute 42
185 ; CORTEX-M0-NOT:  .eabi_attribute 68
186
187 ; CORTEX-M4-SOFT:  .cpu cortex-m4
188 ; CORTEX-M4-SOFT:  .eabi_attribute 6, 13
189 ; CORTEX-M4-SOFT:  .eabi_attribute 7, 77
190 ; CORTEX-M4-SOFT:  .eabi_attribute 8, 0
191 ; CORTEX-M4-SOFT:  .eabi_attribute 9, 2
192 ; CORTEX-M4-SOFT:  .fpu vfpv4-d16
193 ; CORTEX-M4-SOFT:  .eabi_attribute 20, 1
194 ; CORTEX-M4-SOFT:  .eabi_attribute 21, 1
195 ; CORTEX-M4-SOFT:  .eabi_attribute 23, 3
196 ; CORTEX-M4-SOFT:  .eabi_attribute 24, 1
197 ; CORTEX-M4-SOFT:  .eabi_attribute 25, 1
198 ; CORTEX-M4-SOFT:  .eabi_attribute 27, 1
199 ; CORTEX-M4-SOFT-NOT:  .eabi_attribute 28
200 ; CORTEX-M4-SOFT-NOT:  .eabi_attribute 42
201 ; CORTEX-M4-SOFT:  .eabi_attribute 44, 0
202 ; CORTEX-M4-SOFT-NOT:  .eabi_attribute 68
203
204 ; CORTEX-M4-HARD:  .cpu cortex-m4
205 ; CORTEX-M4-HARD:  .eabi_attribute 6, 13
206 ; CORTEX-M4-HARD:  .eabi_attribute 7, 77
207 ; CORTEX-M4-HARD:  .eabi_attribute 8, 0
208 ; CORTEX-M4-HARD:  .eabi_attribute 9, 2
209 ; CORTEX-M4-HARD:  .fpu vfpv4-d16
210 ; CORTEX-M4-HARD:  .eabi_attribute 20, 1
211 ; CORTEX-M4-HARD:  .eabi_attribute 21, 1
212 ; CORTEX-M4-HARD:  .eabi_attribute 23, 3
213 ; CORTEX-M4-HARD:  .eabi_attribute 24, 1
214 ; CORTEX-M4-HARD:  .eabi_attribute 25, 1
215 ; CORTEX-M4-HARD:  .eabi_attribute 27, 1
216 ; CORTEX-M4-HARD:  .eabi_attribute 28, 1
217 ; CORTEX-M4-HARD-NOT:  .eabi_attribute 42
218 ; CORTEX-M4-HARD:  .eabi_attribute 44, 0
219 ; CORTEX-M4-HRAD-NOT:  .eabi_attribute 68
220
221 ; CORTEX-R5:  .cpu cortex-r5
222 ; CORTEX-R5:  .eabi_attribute 6, 10
223 ; CORTEX-R5:  .eabi_attribute 7, 82
224 ; CORTEX-R5:  .eabi_attribute 8, 1
225 ; CORTEX-R5:  .eabi_attribute 9, 2
226 ; CORTEX-R5:  .fpu vfpv3-d16
227 ; CORTEX-R5:  .eabi_attribute 20, 1
228 ; CORTEX-R5:  .eabi_attribute 21, 1
229 ; CORTEX-R5:  .eabi_attribute 23, 3
230 ; CORTEX-R5:  .eabi_attribute 24, 1
231 ; CORTEX-R5:  .eabi_attribute 25, 1
232 ; CORTEX-R5:  .eabi_attribute 27, 1
233 ; CORTEX-R5-NOT:  .eabi_attribute 28
234 ; CORTEX-R5-NOT:  .eabi_attribute 42
235 ; CORTEX-R5:  .eabi_attribute 44, 2
236 ; CORTEX-R5-NOT:  .eabi_attribute 68
237
238 ; CORTEX-A53:  .cpu cortex-a53
239 ; CORTEX-A53:  .eabi_attribute 6, 14
240 ; CORTEX-A53:  .eabi_attribute 7, 65
241 ; CORTEX-A53:  .eabi_attribute 8, 1
242 ; CORTEX-A53:  .eabi_attribute 9, 2
243 ; CORTEX-A53:  .fpu crypto-neon-fp-armv8
244 ; CORTEX-A53:  .eabi_attribute 12, 3
245 ; CORTEX-A53:  .eabi_attribute 24, 1
246 ; CORTEX-A53:  .eabi_attribute 25, 1
247 ; CORTEX-A53-NOT:  .eabi_attribute 27
248 ; CORTEX-A53-NOT:  .eabi_attribute 28
249 ; CORTEX-A53:  .eabi_attribute 42, 1
250 ; CORTEX-A53:  .eabi_attribute 44, 2
251 ; CORTEX-A53:  .eabi_attribute 68, 3
252
253 ; CORTEX-A57:  .cpu cortex-a57
254 ; CORTEX-A57:  .eabi_attribute 6, 14
255 ; CORTEX-A57:  .eabi_attribute 7, 65
256 ; CORTEX-A57:  .eabi_attribute 8, 1
257 ; CORTEX-A57:  .eabi_attribute 9, 2
258 ; CORTEX-A57:  .fpu crypto-neon-fp-armv8
259 ; CORTEX-A57:  .eabi_attribute 12, 3
260 ; CORTEX-A57:  .eabi_attribute 24, 1
261 ; CORTEX-A57:  .eabi_attribute 25, 1
262 ; CORTEX-A57-NOT:  .eabi_attribute 27
263 ; CORTEX-A57-NOT:  .eabi_attribute 28
264 ; CORTEX-A57:  .eabi_attribute 42, 1
265 ; CORTEX-A57:  .eabi_attribute 44, 2
266 ; CORTEX-A57:  .eabi_attribute 68, 3
267
268 define i32 @f(i64 %z) {
269         ret i32 0
270 }