[arm] Implement eabi_attribute, cpu, and fpu directives.
[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 | FileCheck %s --check-prefix=CORTEX-A9
16 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a15 | FileCheck %s --check-prefix=CORTEX-A15
17 ; RUN: llc < %s -mtriple=thumbv6m-linux-gnueabi -mcpu=cortex-m0 | FileCheck %s --check-prefix=CORTEX-M0
18 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi -mcpu=cortex-m4 | FileCheck %s --check-prefix=CORTEX-M4
19 ; RUN: llc < %s -mtriple=armv7r-linux-gnueabi -mcpu=cortex-r5 | FileCheck %s --check-prefix=CORTEX-R5
20 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a53 | FileCheck %s --check-prefix=CORTEX-A53
21 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a57 | FileCheck %s --check-prefix=CORTEX-A57
22
23 ; V6:   .eabi_attribute 6, 6
24 ; V6:   .eabi_attribute 8, 1
25 ; V6:   .eabi_attribute 24, 1
26 ; V6:   .eabi_attribute 25, 1
27
28 ; V6M:  .eabi_attribute 6, 12
29 ; V6M:  .eabi_attribute 7, 77
30 ; V6M:  .eabi_attribute 8, 0
31 ; V6M:  .eabi_attribute 9, 1
32 ; V6M:  .eabi_attribute 24, 1
33 ; V6M:  .eabi_attribute 25, 1
34
35 ; ARM1156T2F-S: .cpu arm1156t2f-s
36 ; ARM1156T2F-S: .eabi_attribute 6, 8
37 ; ARM1156T2F-S: .eabi_attribute 8, 1
38 ; ARM1156T2F-S: .eabi_attribute 9, 2
39 ; ARM1156T2F-S: .fpu vfpv2
40 ; ARM1156T2F-S: .eabi_attribute 20, 1
41 ; ARM1156T2F-S: .eabi_attribute 21, 1
42 ; ARM1156T2F-S: .eabi_attribute 23, 3
43 ; ARM1156T2F-S: .eabi_attribute 24, 1
44 ; ARM1156T2F-S: .eabi_attribute 25, 1
45
46 ; V7M:  .eabi_attribute 6, 10
47 ; V7M:  .eabi_attribute 7, 77
48 ; V7M:  .eabi_attribute 8, 0
49 ; V7M:  .eabi_attribute 9, 2
50 ; V7M:  .eabi_attribute 24, 1
51 ; V7M:  .eabi_attribute 25, 1
52 ; V7M:  .eabi_attribute 44, 0
53
54 ; V7:      .syntax unified
55 ; V7: .eabi_attribute 6, 10
56 ; V7: .eabi_attribute 20, 1
57 ; V7: .eabi_attribute 21, 1
58 ; V7: .eabi_attribute 23, 3
59 ; V7: .eabi_attribute 24, 1
60 ; V7: .eabi_attribute 25, 1
61
62 ; V8:      .syntax unified
63 ; V8: .eabi_attribute 6, 14
64
65 ; Vt8:     .syntax unified
66 ; Vt8: .eabi_attribute 6, 14
67
68 ; V8-FPARMv8:      .syntax unified
69 ; V8-FPARMv8: .eabi_attribute 6, 14
70 ; V8-FPARMv8: .fpu fp-armv8
71
72 ; V8-NEON:      .syntax unified
73 ; V8-NEON: .eabi_attribute 6, 14
74 ; V8-NEON: .fpu neon
75 ; V8-NEON: .eabi_attribute 12, 3
76
77 ; V8-FPARMv8-NEON:      .syntax unified
78 ; V8-FPARMv8-NEON: .eabi_attribute 6, 14
79 ; V8-FPARMv8-NEON: .fpu neon-fp-armv8
80 ; V8-FPARMv8-NEON: .eabi_attribute 12, 3
81
82 ; V8-FPARMv8-NEON-CRYPTO:      .syntax unified
83 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 6, 14
84 ; V8-FPARMv8-NEON-CRYPTO: .fpu crypto-neon-fp-armv8
85 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 12, 3
86
87 ; CORTEX-A9:  .cpu cortex-a9
88 ; CORTEX-A9:  .eabi_attribute 6, 10
89 ; CORTEX-A9:  .eabi_attribute 7, 65
90 ; CORTEX-A9:  .eabi_attribute 8, 1
91 ; CORTEX-A9:  .eabi_attribute 9, 2
92 ; CORTEX-A9:  .fpu neon
93 ; CORTEX-A9:  .eabi_attribute 20, 1
94 ; CORTEX-A9:  .eabi_attribute 21, 1
95 ; CORTEX-A9:  .eabi_attribute 23, 3
96 ; CORTEX-A9:  .eabi_attribute 24, 1
97 ; CORTEX-A9:  .eabi_attribute 25, 1
98
99 ; CORTEX-A15: .cpu cortex-a15
100 ; CORTEX-A15: .eabi_attribute 6, 10
101 ; CORTEX-A15: .eabi_attribute 7, 65
102 ; CORTEX-A15: .eabi_attribute 8, 1
103 ; CORTEX-A15: .eabi_attribute 9, 2
104 ; CORTEX-A15: .fpu neon-vfpv4
105 ; CORTEX-A15: .eabi_attribute 20, 1
106 ; CORTEX-A15: .eabi_attribute 21, 1
107 ; CORTEX-A15: .eabi_attribute 23, 3
108 ; CORTEX-A15: .eabi_attribute 24, 1
109 ; CORTEX-A15: .eabi_attribute 25, 1
110 ; CORTEX-A15: .eabi_attribute 44, 2
111
112 ; CORTEX-M0:  .cpu cortex-m0
113 ; CORTEX-M0:  .eabi_attribute 6, 12
114 ; CORTEX-M0:  .eabi_attribute 7, 77
115 ; CORTEX-M0:  .eabi_attribute 8, 0
116 ; CORTEX-M0:  .eabi_attribute 9, 1
117 ; CORTEX-M0:  .eabi_attribute 24, 1
118 ; CORTEX-M0:  .eabi_attribute 25, 1
119
120 ; CORTEX-M4:  .cpu cortex-m4
121 ; CORTEX-M4:  .eabi_attribute 6, 13
122 ; CORTEX-M4:  .eabi_attribute 7, 77
123 ; CORTEX-M4:  .eabi_attribute 8, 0
124 ; CORTEX-M4:  .eabi_attribute 9, 2
125 ; CORTEX-M4:  .fpu vfpv4-d16
126 ; CORTEX-M4:  .eabi_attribute 20, 1
127 ; CORTEX-M4:  .eabi_attribute 21, 1
128 ; CORTEX-M4:  .eabi_attribute 23, 3
129 ; CORTEX-M4:  .eabi_attribute 24, 1
130 ; CORTEX-M4:  .eabi_attribute 25, 1
131 ; CORTEX-M4:  .eabi_attribute 44, 0
132
133 ; CORTEX-R5:  .cpu cortex-r5
134 ; CORTEX-R5:  .eabi_attribute 6, 10
135 ; CORTEX-R5:  .eabi_attribute 7, 82
136 ; CORTEX-R5:   .eabi_attribute 8, 1
137 ; CORTEX-R5:  .eabi_attribute 9, 2
138 ; CORTEX-R5:  .fpu vfpv3-d16
139 ; CORTEX-R5:  .eabi_attribute 20, 1
140 ; CORTEX-R5:  .eabi_attribute 21, 1
141 ; CORTEX-R5:  .eabi_attribute 23, 3
142 ; CORTEX-R5:  .eabi_attribute 24, 1
143 ; CORTEX-R5:  .eabi_attribute 25, 1
144 ; CORTEX-R5:  .eabi_attribute 44, 2
145
146 ; CORTEX-A53:  .cpu cortex-a53
147 ; CORTEX-A53:  .eabi_attribute 6, 14
148 ; CORTEX-A53:  .eabi_attribute 7, 65
149 ; CORTEX-A53:  .eabi_attribute 8, 1
150 ; CORTEX-A53:  .eabi_attribute 9, 2
151 ; CORTEX-A53:  .fpu crypto-neon-fp-armv8
152 ; CORTEX-A53:  .eabi_attribute 12, 3
153 ; CORTEX-A53:  .eabi_attribute 24, 1
154 ; CORTEX-A53:  .eabi_attribute 25, 1
155 ; CORTEX-A53:  .eabi_attribute 44, 2
156
157 ; CORTEX-A57:  .cpu cortex-a57
158 ; CORTEX-A57:  .eabi_attribute 6, 14
159 ; CORTEX-A57:  .eabi_attribute 7, 65
160 ; CORTEX-A57:  .eabi_attribute 8, 1
161 ; CORTEX-A57:  .eabi_attribute 9, 2
162 ; CORTEX-A57:  .fpu crypto-neon-fp-armv8
163 ; CORTEX-A57:  .eabi_attribute 12, 3
164 ; CORTEX-A57:  .eabi_attribute 24, 1
165 ; CORTEX-A57:  .eabi_attribute 25, 1
166 ; CORTEX-A57:  .eabi_attribute 44, 2
167
168 define i32 @f(i64 %z) {
169         ret i32 0
170 }