1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=powerpc64-unknown-aix-xcoff -verify-machineinstrs \
3 ; RUN: -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck \
4 ; RUN: --check-prefix=AIX64 %s
5 ; RUN: llc -mtriple=powerpc-unknown-aix-xcoff -verify-machineinstrs \
6 ; RUN: -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck \
7 ; RUN: --check-prefix=AIX32 %s
8 ; RUN: llc -mtriple=powerpc64le-- -verify-machineinstrs \
9 ; RUN: -ppc-asm-full-reg-names -mcpu=pwr8 < %s | FileCheck --check-prefix=LE %s
11 define dso_local void @test1(ptr %v, i64 %a) local_unnamed_addr #0 {
13 ; AIX64: # %bb.0: # %entry
14 ; AIX64-NEXT: mtvsrd vs34, r4
16 ; AIX64-NEXT: stvx v2, 0, r3
21 ; AIX32: # %bb.0: # %entry
22 ; AIX32-NEXT: stw r5, -4(r1)
23 ; AIX32-NEXT: stw r4, -8(r1)
24 ; AIX32-NEXT: lfd f0, -8(r1)
25 ; AIX32-NEXT: xxlor vs34, f0, f0
27 ; AIX32-NEXT: stvx v2, 0, r3
32 ; LE: # %bb.0: # %entry
33 ; LE-NEXT: mtvsrd vs34, r4
35 ; LE-NEXT: stvx v2, 0, r3
39 tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i64 %a, ptr %v)
43 define dso_local void @test2(ptr %v, i32 signext %a) local_unnamed_addr #0 {
45 ; AIX64: # %bb.0: # %entry
46 ; AIX64-NEXT: clrldi r4, r4, 32
47 ; AIX64-NEXT: mtvsrd vs34, r4
49 ; AIX64-NEXT: stvx v2, 0, r3
54 ; AIX32: # %bb.0: # %entry
55 ; AIX32-NEXT: stw r4, -4(r1)
56 ; AIX32-NEXT: li r4, 0
57 ; AIX32-NEXT: stw r4, -8(r1)
58 ; AIX32-NEXT: lfd f0, -8(r1)
59 ; AIX32-NEXT: xxlor vs34, f0, f0
61 ; AIX32-NEXT: stvx v2, 0, r3
66 ; LE: # %bb.0: # %entry
67 ; LE-NEXT: clrldi r4, r4, 32
68 ; LE-NEXT: mtvsrd vs34, r4
70 ; LE-NEXT: stvx v2, 0, r3
74 tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i32 %a, ptr %v)
78 define dso_local void @test3(ptr %v, i16 signext %a) local_unnamed_addr #0 {
80 ; AIX64: # %bb.0: # %entry
81 ; AIX64-NEXT: clrldi r4, r4, 48
82 ; AIX64-NEXT: mtvsrd vs34, r4
84 ; AIX64-NEXT: stvx v2, 0, r3
89 ; AIX32: # %bb.0: # %entry
90 ; AIX32-NEXT: li r5, 0
91 ; AIX32-NEXT: clrlwi r4, r4, 16
92 ; AIX32-NEXT: stw r5, -8(r1)
93 ; AIX32-NEXT: stw r4, -4(r1)
94 ; AIX32-NEXT: lfd f0, -8(r1)
95 ; AIX32-NEXT: xxlor vs34, f0, f0
97 ; AIX32-NEXT: stvx v2, 0, r3
102 ; LE: # %bb.0: # %entry
103 ; LE-NEXT: clrldi r4, r4, 48
104 ; LE-NEXT: mtvsrd vs34, r4
106 ; LE-NEXT: stvx v2, 0, r3
110 tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i16 %a, ptr %v)
114 define dso_local void @test4(ptr %v, i8 signext %a) local_unnamed_addr #0 {
115 ; AIX64-LABEL: test4:
116 ; AIX64: # %bb.0: # %entry
117 ; AIX64-NEXT: clrldi r4, r4, 56
118 ; AIX64-NEXT: mtvsrd vs34, r4
120 ; AIX64-NEXT: stvx v2, 0, r3
121 ; AIX64-NEXT: #NO_APP
124 ; AIX32-LABEL: test4:
125 ; AIX32: # %bb.0: # %entry
126 ; AIX32-NEXT: li r5, 0
127 ; AIX32-NEXT: clrlwi r4, r4, 24
128 ; AIX32-NEXT: stw r5, -8(r1)
129 ; AIX32-NEXT: stw r4, -4(r1)
130 ; AIX32-NEXT: lfd f0, -8(r1)
131 ; AIX32-NEXT: xxlor vs34, f0, f0
133 ; AIX32-NEXT: stvx v2, 0, r3
134 ; AIX32-NEXT: #NO_APP
138 ; LE: # %bb.0: # %entry
139 ; LE-NEXT: clrldi r4, r4, 56
140 ; LE-NEXT: mtvsrd vs34, r4
142 ; LE-NEXT: stvx v2, 0, r3
146 tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i8 %a, ptr %v)
150 define dso_local void @test6(ptr %v, i32 zeroext %a) local_unnamed_addr #0 {
151 ; AIX64-LABEL: test6:
152 ; AIX64: # %bb.0: # %entry
153 ; AIX64-NEXT: mtvsrd vs34, r4
155 ; AIX64-NEXT: stvx v2, 0, r3
156 ; AIX64-NEXT: #NO_APP
159 ; AIX32-LABEL: test6:
160 ; AIX32: # %bb.0: # %entry
161 ; AIX32-NEXT: stw r4, -4(r1)
162 ; AIX32-NEXT: li r4, 0
163 ; AIX32-NEXT: stw r4, -8(r1)
164 ; AIX32-NEXT: lfd f0, -8(r1)
165 ; AIX32-NEXT: xxlor vs34, f0, f0
167 ; AIX32-NEXT: stvx v2, 0, r3
168 ; AIX32-NEXT: #NO_APP
172 ; LE: # %bb.0: # %entry
173 ; LE-NEXT: mtvsrd vs34, r4
175 ; LE-NEXT: stvx v2, 0, r3
179 tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i32 %a, ptr %v)
183 define dso_local void @test7(ptr %v, i16 zeroext %a) local_unnamed_addr #0 {
184 ; AIX64-LABEL: test7:
185 ; AIX64: # %bb.0: # %entry
186 ; AIX64-NEXT: mtvsrd vs34, r4
188 ; AIX64-NEXT: stvx v2, 0, r3
189 ; AIX64-NEXT: #NO_APP
192 ; AIX32-LABEL: test7:
193 ; AIX32: # %bb.0: # %entry
194 ; AIX32-NEXT: stw r4, -4(r1)
195 ; AIX32-NEXT: li r4, 0
196 ; AIX32-NEXT: stw r4, -8(r1)
197 ; AIX32-NEXT: lfd f0, -8(r1)
198 ; AIX32-NEXT: xxlor vs34, f0, f0
200 ; AIX32-NEXT: stvx v2, 0, r3
201 ; AIX32-NEXT: #NO_APP
205 ; LE: # %bb.0: # %entry
206 ; LE-NEXT: mtvsrd vs34, r4
208 ; LE-NEXT: stvx v2, 0, r3
212 tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i16 %a, ptr %v)
216 define dso_local void @test8(ptr %v, i8 zeroext %a) local_unnamed_addr #0 {
217 ; AIX64-LABEL: test8:
218 ; AIX64: # %bb.0: # %entry
219 ; AIX64-NEXT: mtvsrd vs34, r4
221 ; AIX64-NEXT: stvx v2, 0, r3
222 ; AIX64-NEXT: #NO_APP
225 ; AIX32-LABEL: test8:
226 ; AIX32: # %bb.0: # %entry
227 ; AIX32-NEXT: stw r4, -4(r1)
228 ; AIX32-NEXT: li r4, 0
229 ; AIX32-NEXT: stw r4, -8(r1)
230 ; AIX32-NEXT: lfd f0, -8(r1)
231 ; AIX32-NEXT: xxlor vs34, f0, f0
233 ; AIX32-NEXT: stvx v2, 0, r3
234 ; AIX32-NEXT: #NO_APP
238 ; LE: # %bb.0: # %entry
239 ; LE-NEXT: mtvsrd vs34, r4
241 ; LE-NEXT: stvx v2, 0, r3
245 tail call void asm sideeffect "stvx $0,0,$1", "v,r,~{memory}"(i8 %a, ptr %v)
249 attributes #0 = { nounwind }