[ARM] Fix Tag_ABI_HardFP_use build attribute
[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-a15 | FileCheck %s --check-prefix=CORTEX-A15
18 ; RUN: llc < %s -mtriple=thumbv6m-linux-gnueabi -mcpu=cortex-m0 | FileCheck %s --check-prefix=CORTEX-M0
19 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi -mcpu=cortex-m4 -float-abi=soft | FileCheck %s --check-prefix=CORTEX-M4-SOFT
20 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi -mcpu=cortex-m4 -float-abi=hard | FileCheck %s --check-prefix=CORTEX-M4-HARD
21 ; RUN: llc < %s -mtriple=armv7r-linux-gnueabi -mcpu=cortex-r5 | FileCheck %s --check-prefix=CORTEX-R5
22 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a53 | FileCheck %s --check-prefix=CORTEX-A53
23 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a57 | FileCheck %s --check-prefix=CORTEX-A57
24
25 ; V6:   .eabi_attribute 6, 6
26 ; V6:   .eabi_attribute 8, 1
27 ; V6:   .eabi_attribute 24, 1
28 ; V6:   .eabi_attribute 25, 1
29 ; V6-NOT:   .eabi_attribute 27
30 ; V6-NOT:   .eabi_attribute 28
31
32 ; V6M:  .eabi_attribute 6, 12
33 ; V6M:  .eabi_attribute 7, 77
34 ; V6M:  .eabi_attribute 8, 0
35 ; V6M:  .eabi_attribute 9, 1
36 ; V6M:  .eabi_attribute 24, 1
37 ; V6M:  .eabi_attribute 25, 1
38 ; V6M-NOT:  .eabi_attribute 27
39 ; V6M-NOT:  .eabi_attribute 28
40
41 ; ARM1156T2F-S: .cpu arm1156t2f-s
42 ; ARM1156T2F-S: .eabi_attribute 6, 8
43 ; ARM1156T2F-S: .eabi_attribute 8, 1
44 ; ARM1156T2F-S: .eabi_attribute 9, 2
45 ; ARM1156T2F-S: .fpu vfpv2
46 ; ARM1156T2F-S: .eabi_attribute 20, 1
47 ; ARM1156T2F-S: .eabi_attribute 21, 1
48 ; ARM1156T2F-S: .eabi_attribute 23, 3
49 ; ARM1156T2F-S: .eabi_attribute 24, 1
50 ; ARM1156T2F-S: .eabi_attribute 25, 1
51 ; ARM1156T2F-S-NOT: .eabi_attribute 27
52 ; ARM1156T2F-S-NOT: .eabi_attribute 28
53
54 ; V7M:  .eabi_attribute 6, 10
55 ; V7M:  .eabi_attribute 7, 77
56 ; V7M:  .eabi_attribute 8, 0
57 ; V7M:  .eabi_attribute 9, 2
58 ; V7M:  .eabi_attribute 24, 1
59 ; V7M:  .eabi_attribute 25, 1
60 ; V7M-NOT:  .eabi_attribute 27
61 ; V7M-NOT:  .eabi_attribute 28
62 ; V7M:  .eabi_attribute 44, 0
63
64 ; V7:      .syntax unified
65 ; V7: .eabi_attribute 6, 10
66 ; V7: .eabi_attribute 20, 1
67 ; V7: .eabi_attribute 21, 1
68 ; V7: .eabi_attribute 23, 3
69 ; V7: .eabi_attribute 24, 1
70 ; V7: .eabi_attribute 25, 1
71 ; V7-NOT: .eabi_attribute 27
72 ; V7-NOT: .eabi_attribute 28
73
74 ; V8:      .syntax unified
75 ; V8: .eabi_attribute 6, 14
76
77 ; Vt8:     .syntax unified
78 ; Vt8: .eabi_attribute 6, 14
79
80 ; V8-FPARMv8:      .syntax unified
81 ; V8-FPARMv8: .eabi_attribute 6, 14
82 ; V8-FPARMv8: .fpu fp-armv8
83
84 ; V8-NEON:      .syntax unified
85 ; V8-NEON: .eabi_attribute 6, 14
86 ; V8-NEON: .fpu neon
87 ; V8-NEON: .eabi_attribute 12, 3
88
89 ; V8-FPARMv8-NEON:      .syntax unified
90 ; V8-FPARMv8-NEON: .eabi_attribute 6, 14
91 ; V8-FPARMv8-NEON: .fpu neon-fp-armv8
92 ; V8-FPARMv8-NEON: .eabi_attribute 12, 3
93
94 ; V8-FPARMv8-NEON-CRYPTO:      .syntax unified
95 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 6, 14
96 ; V8-FPARMv8-NEON-CRYPTO: .fpu crypto-neon-fp-armv8
97 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 12, 3
98
99 ; CORTEX-A9-SOFT:  .cpu cortex-a9
100 ; CORTEX-A9-SOFT:  .eabi_attribute 6, 10
101 ; CORTEX-A9-SOFT:  .eabi_attribute 7, 65
102 ; CORTEX-A9-SOFT:  .eabi_attribute 8, 1
103 ; CORTEX-A9-SOFT:  .eabi_attribute 9, 2
104 ; CORTEX-A9-SOFT:  .fpu neon
105 ; CORTEX-A9-SOFT:  .eabi_attribute 20, 1
106 ; CORTEX-A9-SOFT:  .eabi_attribute 21, 1
107 ; CORTEX-A9-SOFT:  .eabi_attribute 23, 3
108 ; CORTEX-A9-SOFT:  .eabi_attribute 24, 1
109 ; CORTEX-A9-SOFT:  .eabi_attribute 25, 1
110 ; CORTEX-A9-SOFT-NOT:  .eabi_attribute 27
111 ; CORTEX-A9-SOFT-NOT:  .eabi_attribute 28
112
113 ; CORTEX-A9-HARD:  .cpu cortex-a9
114 ; CORTEX-A9-HARD:  .eabi_attribute 6, 10
115 ; CORTEX-A9-HARD:  .eabi_attribute 7, 65
116 ; CORTEX-A9-HARD:  .eabi_attribute 8, 1
117 ; CORTEX-A9-HARD:  .eabi_attribute 9, 2
118 ; CORTEX-A9-HARD:  .fpu neon
119 ; CORTEX-A9-HARD:  .eabi_attribute 20, 1
120 ; CORTEX-A9-HARD:  .eabi_attribute 21, 1
121 ; CORTEX-A9-HARD:  .eabi_attribute 23, 3
122 ; CORTEX-A9-HARD:  .eabi_attribute 24, 1
123 ; CORTEX-A9-HARD:  .eabi_attribute 25, 1
124 ; CORTEX-A9-HARD-NOT:  .eabi_attribute 27
125 ; CORTEX-A9-HARD:  .eabi_attribute 28, 1
126
127 ; CORTEX-A15: .cpu cortex-a15
128 ; CORTEX-A15: .eabi_attribute 6, 10
129 ; CORTEX-A15: .eabi_attribute 7, 65
130 ; CORTEX-A15: .eabi_attribute 8, 1
131 ; CORTEX-A15: .eabi_attribute 9, 2
132 ; CORTEX-A15: .fpu neon-vfpv4
133 ; CORTEX-A15: .eabi_attribute 20, 1
134 ; CORTEX-A15: .eabi_attribute 21, 1
135 ; CORTEX-A15: .eabi_attribute 23, 3
136 ; CORTEX-A15: .eabi_attribute 24, 1
137 ; CORTEX-A15: .eabi_attribute 25, 1
138 ; CORTEX-A15: .eabi_attribute 44, 2
139 ; CORTEX-A15-NOT: .eabi_attribute 27
140 ; CORTEX-A15-NOT: .eabi_attribute 28
141
142 ; CORTEX-M0:  .cpu cortex-m0
143 ; CORTEX-M0:  .eabi_attribute 6, 12
144 ; CORTEX-M0:  .eabi_attribute 7, 77
145 ; CORTEX-M0:  .eabi_attribute 8, 0
146 ; CORTEX-M0:  .eabi_attribute 9, 1
147 ; CORTEX-M0:  .eabi_attribute 24, 1
148 ; CORTEX-M0:  .eabi_attribute 25, 1
149 ; CORTEX-M0-NOT:  .eabi_attribute 27
150 ; CORTEX-M0-NOT:  .eabi_attribute 28
151
152 ; CORTEX-M4-SOFT:  .cpu cortex-m4
153 ; CORTEX-M4-SOFT:  .eabi_attribute 6, 13
154 ; CORTEX-M4-SOFT:  .eabi_attribute 7, 77
155 ; CORTEX-M4-SOFT:  .eabi_attribute 8, 0
156 ; CORTEX-M4-SOFT:  .eabi_attribute 9, 2
157 ; CORTEX-M4-SOFT:  .fpu vfpv4-d16
158 ; CORTEX-M4-SOFT:  .eabi_attribute 20, 1
159 ; CORTEX-M4-SOFT:  .eabi_attribute 21, 1
160 ; CORTEX-M4-SOFT:  .eabi_attribute 23, 3
161 ; CORTEX-M4-SOFT:  .eabi_attribute 24, 1
162 ; CORTEX-M4-SOFT:  .eabi_attribute 25, 1
163 ; CORTEX-M4-SOFT:  .eabi_attribute 27, 1
164 ; CORTEX-M4-SOFT-NOT:  .eabi_attribute 28
165 ; CORTEX-M4-SOFT:  .eabi_attribute 44, 0
166
167 ; CORTEX-M4-HARD:  .cpu cortex-m4
168 ; CORTEX-M4-HARD:  .eabi_attribute 6, 13
169 ; CORTEX-M4-HARD:  .eabi_attribute 7, 77
170 ; CORTEX-M4-HARD:  .eabi_attribute 8, 0
171 ; CORTEX-M4-HARD:  .eabi_attribute 9, 2
172 ; CORTEX-M4-HARD:  .fpu vfpv4-d16
173 ; CORTEX-M4-HARD:  .eabi_attribute 20, 1
174 ; CORTEX-M4-HARD:  .eabi_attribute 21, 1
175 ; CORTEX-M4-HARD:  .eabi_attribute 23, 3
176 ; CORTEX-M4-HARD:  .eabi_attribute 24, 1
177 ; CORTEX-M4-HARD:  .eabi_attribute 25, 1
178 ; CORTEX-M4-HARD:  .eabi_attribute 27, 1
179 ; CORTEX-M4-HARD:  .eabi_attribute 28, 1
180 ; CORTEX-M4-HARD:  .eabi_attribute 44, 0
181
182 ; CORTEX-R5:  .cpu cortex-r5
183 ; CORTEX-R5:  .eabi_attribute 6, 10
184 ; CORTEX-R5:  .eabi_attribute 7, 82
185 ; CORTEX-R5:   .eabi_attribute 8, 1
186 ; CORTEX-R5:  .eabi_attribute 9, 2
187 ; CORTEX-R5:  .fpu vfpv3-d16
188 ; CORTEX-R5:  .eabi_attribute 20, 1
189 ; CORTEX-R5:  .eabi_attribute 21, 1
190 ; CORTEX-R5:  .eabi_attribute 23, 3
191 ; CORTEX-R5:  .eabi_attribute 24, 1
192 ; CORTEX-R5:  .eabi_attribute 25, 1
193 ; CORTEX-R5:  .eabi_attribute 27, 1
194 ; CORTEX-R5-NOT:  .eabi_attribute 28
195 ; CORTEX-R5:  .eabi_attribute 44, 2
196
197 ; CORTEX-A53:  .cpu cortex-a53
198 ; CORTEX-A53:  .eabi_attribute 6, 14
199 ; CORTEX-A53:  .eabi_attribute 7, 65
200 ; CORTEX-A53:  .eabi_attribute 8, 1
201 ; CORTEX-A53:  .eabi_attribute 9, 2
202 ; CORTEX-A53:  .fpu crypto-neon-fp-armv8
203 ; CORTEX-A53:  .eabi_attribute 12, 3
204 ; CORTEX-A53:  .eabi_attribute 24, 1
205 ; CORTEX-A53:  .eabi_attribute 25, 1
206 ; CORTEX-A53-NOT:  .eabi_attribute 27
207 ; CORTEX-A53-NOT:  .eabi_attribute 28
208 ; CORTEX-A53:  .eabi_attribute 44, 2
209
210 ; CORTEX-A57:  .cpu cortex-a57
211 ; CORTEX-A57:  .eabi_attribute 6, 14
212 ; CORTEX-A57:  .eabi_attribute 7, 65
213 ; CORTEX-A57:  .eabi_attribute 8, 1
214 ; CORTEX-A57:  .eabi_attribute 9, 2
215 ; CORTEX-A57:  .fpu crypto-neon-fp-armv8
216 ; CORTEX-A57:  .eabi_attribute 12, 3
217 ; CORTEX-A57:  .eabi_attribute 24, 1
218 ; CORTEX-A57:  .eabi_attribute 25, 1
219 ; CORTEX-A57-NOT:  .eabi_attribute 27
220 ; CORTEX-A57-NOT:  .eabi_attribute 28
221 ; CORTEX-A57:  .eabi_attribute 44, 2
222
223 define i32 @f(i64 %z) {
224         ret i32 0
225 }