3501fb7ec7c3786403ee419c44f53f54c34f2218
[oota-llvm.git] / test / CodeGen / ARM / 2010-09-29-mc-asm-header-test.ll
1 ; RUN: llc < %s -mtriple=armv6-linux-gnueabi | FileCheck %s --check-prefix=V6
2 ; RUN: llc < %s -mtriple=thumbv6m-linux-gnueabi | FileCheck %s --check-prefix=V6M
3 ; RUN: llc < %s -mtriple=armv6-linux-gnueabi -mcpu=arm1156t2f-s | FileCheck %s --check-prefix=ARM1156T2F-S
4 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi | FileCheck %s --check-prefix=V7M
5 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi | FileCheck %s --check-prefix=V7
6 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi | FileCheck %s --check-prefix=V8
7 ; RUN: llc < %s -mtriple=thumbv8-linux-gnueabi | FileCheck %s --check-prefix=Vt8
8 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mattr=-neon,-crypto | FileCheck %s --check-prefix=V8-FPARMv8
9 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mattr=-fp-armv8,-crypto | FileCheck %s --check-prefix=V8-NEON
10 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mattr=-crypto | FileCheck %s --check-prefix=V8-FPARMv8-NEON
11 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi | FileCheck %s --check-prefix=V8-FPARMv8-NEON-CRYPTO
12 ; RUN: llc < %s -mtriple=armv7-linux-gnueabi -mcpu=cortex-a9 | FileCheck %s --check-prefix=CORTEX-A9
13 ; RUN: llc < %s -mtriple=thumbv6m-linux-gnueabi -mcpu=cortex-m0 | FileCheck %s --check-prefix=CORTEX-M0
14 ; RUN: llc < %s -mtriple=thumbv7m-linux-gnueabi -mcpu=cortex-m4 | FileCheck %s --check-prefix=CORTEX-M4
15 ; RUN: llc < %s -mtriple=armv7r-linux-gnueabi -mcpu=cortex-r5 | FileCheck %s --check-prefix=CORTEX-R5
16 ; RUN: llc < %s -mtriple=armv8-linux-gnueabi -mcpu=cortex-a53 | FileCheck %s --check-prefix=CORTEX-A53
17 ; This tests that MC/asm header conversion is smooth and that build attributes are correct
18 ;
19
20 ; V6:   .eabi_attribute 6, 6
21 ; V6:   .eabi_attribute 8, 1
22 ; V6:   .eabi_attribute 24, 1
23 ; V6:   .eabi_attribute 25, 1
24
25 ; V6M:  .eabi_attribute 6, 12
26 ; V6M:  .eabi_attribute 7, 77
27 ; V6M:  .eabi_attribute 8, 0
28 ; V6M:  .eabi_attribute 9, 1
29 ; V6M:  .eabi_attribute 24, 1
30 ; V6M:  .eabi_attribute 25, 1
31
32 ; ARM1156T2F-S: .cpu arm1156t2f-s
33 ; ARM1156T2F-S: .eabi_attribute 6, 8
34 ; ARM1156T2F-S: .eabi_attribute 8, 1
35 ; ARM1156T2F-S: .eabi_attribute 9, 2
36 ; ARM1156T2F-S: .eabi_attribute 10, 2
37 ; ARM1156T2F-S: .fpu vfpv2
38 ; ARM1156T2F-S: .eabi_attribute 20, 1
39 ; ARM1156T2F-S: .eabi_attribute 21, 1
40 ; ARM1156T2F-S: .eabi_attribute 23, 3
41 ; ARM1156T2F-S: .eabi_attribute 24, 1
42 ; ARM1156T2F-S: .eabi_attribute 25, 1
43
44 ; V7M:  .eabi_attribute 6, 10
45 ; V7M:  .eabi_attribute 7, 77
46 ; V7M:  .eabi_attribute 8, 0
47 ; V7M:  .eabi_attribute 9, 2
48 ; V7M:  .eabi_attribute 24, 1
49 ; V7M:  .eabi_attribute 25, 1
50 ; V7M:  .eabi_attribute 44, 0
51
52 ; V7:      .syntax unified
53 ; V7: .eabi_attribute 6, 10
54 ; V7: .eabi_attribute 20, 1
55 ; V7: .eabi_attribute 21, 1
56 ; V7: .eabi_attribute 23, 3
57 ; V7: .eabi_attribute 24, 1
58 ; V7: .eabi_attribute 25, 1
59
60 ; V8:      .syntax unified
61 ; V8: .eabi_attribute 6, 14
62
63 ; Vt8:     .syntax unified
64 ; Vt8: .eabi_attribute 6, 14
65
66 ; V8-FPARMv8:      .syntax unified
67 ; V8-FPARMv8: .eabi_attribute 6, 14
68 ; V8-FPARMv8: .eabi_attribute 10, 7
69 ; V8-FPARMv8: .fpu fp-armv8
70
71 ; V8-NEON:      .syntax unified
72 ; V8-NEON: .eabi_attribute 6, 14
73 ; V8-NEON: .fpu neon
74 ; V8-NEON: .eabi_attribute 12, 3
75
76 ; V8-FPARMv8-NEON:      .syntax unified
77 ; V8-FPARMv8-NEON: .eabi_attribute 6, 14
78 ; V8-FPARMv8-NEON: .fpu neon-fp-armv8
79 ; V8-FPARMv8-NEON: .eabi_attribute 10, 7
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 10, 7
86 ; V8-FPARMv8-NEON-CRYPTO: .eabi_attribute 12, 3
87
88 ; CORTEX-A9:  .cpu cortex-a9
89 ; CORTEX-A9:  .eabi_attribute 6, 10
90 ; CORTEX-A9:  .eabi_attribute 7, 65
91 ; CORTEX-A9:  .eabi_attribute 8, 1
92 ; CORTEX-A9:  .eabi_attribute 9, 2
93 ; CORTEX-A9:  .fpu neon
94 ; CORTEX-A9:  .eabi_attribute 10, 3
95 ; CORTEX-A9:  .eabi_attribute 12, 1
96 ; CORTEX-A9:  .eabi_attribute 20, 1
97 ; CORTEX-A9:  .eabi_attribute 21, 1
98 ; CORTEX-A9:  .eabi_attribute 23, 3
99 ; CORTEX-A9:  .eabi_attribute 24, 1
100 ; CORTEX-A9:  .eabi_attribute 25, 1
101
102 ; CORTEX-M0:  .cpu cortex-m0
103 ; CORTEX-M0:  .eabi_attribute 6, 12
104 ; CORTEX-M0:  .eabi_attribute 7, 77
105 ; CORTEX-M0:  .eabi_attribute 8, 0
106 ; CORTEX-M0:  .eabi_attribute 9, 1
107 ; CORTEX-M0:  .eabi_attribute 24, 1
108 ; CORTEX-M0:  .eabi_attribute 25, 1
109
110 ; CORTEX-M4:  .cpu cortex-m4
111 ; CORTEX-M4:  .eabi_attribute 6, 13
112 ; CORTEX-M4:  .eabi_attribute 7, 77
113 ; CORTEX-M4:  .eabi_attribute 8, 0
114 ; CORTEX-M4:  .eabi_attribute 9, 2
115 ; CORTEX-M4:  .eabi_attribute 10, 6
116 ; CORTEX-M4:  .fpu vfpv4
117 ; CORTEX-M4:  .eabi_attribute 20, 1
118 ; CORTEX-M4:  .eabi_attribute 21, 1
119 ; CORTEX-M4:  .eabi_attribute 23, 3
120 ; CORTEX-M4:  .eabi_attribute 24, 1
121 ; CORTEX-M4:  .eabi_attribute 25, 1
122 ; CORTEX-M4:  .eabi_attribute 44, 0
123
124 ; CORTEX-R5:  .cpu cortex-r5
125 ; CORTEX-R5:  .eabi_attribute 6, 10
126 ; CORTEX-R5:  .eabi_attribute 7, 82
127 ; CORTEX-R5:   .eabi_attribute 8, 1
128 ; CORTEX-R5:  .eabi_attribute 9, 2
129 ; CORTEX-R5:  .eabi_attribute 10, 4
130 ; CORTEX-R5:  .fpu vfpv3
131 ; CORTEX-R5:  .eabi_attribute 20, 1
132 ; CORTEX-R5:  .eabi_attribute 21, 1
133 ; CORTEX-R5:  .eabi_attribute 23, 3
134 ; CORTEX-R5:  .eabi_attribute 24, 1
135 ; CORTEX-R5:  .eabi_attribute 25, 1
136 ; CORTEX-R5:  .eabi_attribute 44, 2
137
138 ; CORTEX-A53:  .cpu cortex-a53
139 ; CORTEX-A53:  .eabi_attribute 6, 14
140 ; CORTEX-A53:  .eabi_attribute 7, 65
141 ; CORTEX-A53:  .eabi_attribute 8, 1
142 ; CORTEX-A53:  .eabi_attribute 9, 2
143 ; CORTEX-A53:  .fpu crypto-neon-fp-armv8
144 ; CORTEX-A53:  .eabi_attribute 10, 7
145 ; CORTEX-A53:  .eabi_attribute 12, 3
146 ; CORTEX-A53:  .eabi_attribute 24, 1
147 ; CORTEX-A53:  .eabi_attribute 25, 1
148 ; CORTEX-A53:  .eabi_attribute 44, 2
149
150 define i32 @f(i64 %z) {
151         ret i32 0
152 }