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