xref: /llvm-project/llvm/test/CodeGen/PowerPC/spill-vec-pair.ll (revision 5403c59c608c08c8ecd4303763f08eb046eb5e4d)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu -O3 \
3; RUN:   -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \
4; RUN:   -disable-auto-paired-vec-st=false < %s | FileCheck %s
5; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu -O3 \
6; RUN:   -mcpu=pwr10 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \
7; RUN:   -disable-auto-paired-vec-st=false < %s | FileCheck %s \
8; RUN:   --check-prefix=CHECK-BE
9define dso_local void @test(ptr %vpp, ptr %vp2) local_unnamed_addr #0 {
10; CHECK-LABEL: test:
11; CHECK:       # %bb.0: # %entry
12; CHECK-NEXT:    stdu r1, -400(r1)
13; CHECK-NEXT:    stfd f14, 256(r1) # 8-byte Folded Spill
14; CHECK-NEXT:    stfd f15, 264(r1) # 8-byte Folded Spill
15; CHECK-NEXT:    stfd f16, 272(r1) # 8-byte Folded Spill
16; CHECK-NEXT:    stfd f17, 280(r1) # 8-byte Folded Spill
17; CHECK-NEXT:    stfd f18, 288(r1) # 8-byte Folded Spill
18; CHECK-NEXT:    stfd f19, 296(r1) # 8-byte Folded Spill
19; CHECK-NEXT:    stfd f20, 304(r1) # 8-byte Folded Spill
20; CHECK-NEXT:    stfd f21, 312(r1) # 8-byte Folded Spill
21; CHECK-NEXT:    stfd f22, 320(r1) # 8-byte Folded Spill
22; CHECK-NEXT:    stfd f23, 328(r1) # 8-byte Folded Spill
23; CHECK-NEXT:    stfd f24, 336(r1) # 8-byte Folded Spill
24; CHECK-NEXT:    stfd f25, 344(r1) # 8-byte Folded Spill
25; CHECK-NEXT:    stfd f26, 352(r1) # 8-byte Folded Spill
26; CHECK-NEXT:    stfd f27, 360(r1) # 8-byte Folded Spill
27; CHECK-NEXT:    stfd f28, 368(r1) # 8-byte Folded Spill
28; CHECK-NEXT:    stfd f29, 376(r1) # 8-byte Folded Spill
29; CHECK-NEXT:    stfd f30, 384(r1) # 8-byte Folded Spill
30; CHECK-NEXT:    stfd f31, 392(r1) # 8-byte Folded Spill
31; CHECK-NEXT:    stxv v20, 64(r1) # 16-byte Folded Spill
32; CHECK-NEXT:    stxv v21, 80(r1) # 16-byte Folded Spill
33; CHECK-NEXT:    stxv v22, 96(r1) # 16-byte Folded Spill
34; CHECK-NEXT:    stxv v23, 112(r1) # 16-byte Folded Spill
35; CHECK-NEXT:    stxv v24, 128(r1) # 16-byte Folded Spill
36; CHECK-NEXT:    stxv v25, 144(r1) # 16-byte Folded Spill
37; CHECK-NEXT:    stxv v26, 160(r1) # 16-byte Folded Spill
38; CHECK-NEXT:    stxv v27, 176(r1) # 16-byte Folded Spill
39; CHECK-NEXT:    stxv v28, 192(r1) # 16-byte Folded Spill
40; CHECK-NEXT:    stxv v29, 208(r1) # 16-byte Folded Spill
41; CHECK-NEXT:    stxv v30, 224(r1) # 16-byte Folded Spill
42; CHECK-NEXT:    stxv v31, 240(r1) # 16-byte Folded Spill
43; CHECK-NEXT:    lxvp vsp34, 0(r3)
44; CHECK-NEXT:    stxvp vsp34, 32(r1) # 32-byte Folded Spill
45; CHECK-NEXT:    #APP
46; CHECK-NEXT:    nop
47; CHECK-NEXT:    #NO_APP
48; CHECK-NEXT:    lxvp vsp34, 32(r1) # 32-byte Folded Reload
49; CHECK-NEXT:    stxvp vsp34, 0(r4)
50; CHECK-NEXT:    lxv v31, 240(r1) # 16-byte Folded Reload
51; CHECK-NEXT:    lxv v30, 224(r1) # 16-byte Folded Reload
52; CHECK-NEXT:    lxv v29, 208(r1) # 16-byte Folded Reload
53; CHECK-NEXT:    lxv v28, 192(r1) # 16-byte Folded Reload
54; CHECK-NEXT:    lxv v27, 176(r1) # 16-byte Folded Reload
55; CHECK-NEXT:    lxv v26, 160(r1) # 16-byte Folded Reload
56; CHECK-NEXT:    lxv v25, 144(r1) # 16-byte Folded Reload
57; CHECK-NEXT:    lxv v24, 128(r1) # 16-byte Folded Reload
58; CHECK-NEXT:    lxv v23, 112(r1) # 16-byte Folded Reload
59; CHECK-NEXT:    lxv v22, 96(r1) # 16-byte Folded Reload
60; CHECK-NEXT:    lxv v21, 80(r1) # 16-byte Folded Reload
61; CHECK-NEXT:    lxv v20, 64(r1) # 16-byte Folded Reload
62; CHECK-NEXT:    lfd f31, 392(r1) # 8-byte Folded Reload
63; CHECK-NEXT:    lfd f30, 384(r1) # 8-byte Folded Reload
64; CHECK-NEXT:    lfd f29, 376(r1) # 8-byte Folded Reload
65; CHECK-NEXT:    lfd f28, 368(r1) # 8-byte Folded Reload
66; CHECK-NEXT:    lfd f27, 360(r1) # 8-byte Folded Reload
67; CHECK-NEXT:    lfd f26, 352(r1) # 8-byte Folded Reload
68; CHECK-NEXT:    lfd f25, 344(r1) # 8-byte Folded Reload
69; CHECK-NEXT:    lfd f24, 336(r1) # 8-byte Folded Reload
70; CHECK-NEXT:    lfd f23, 328(r1) # 8-byte Folded Reload
71; CHECK-NEXT:    lfd f22, 320(r1) # 8-byte Folded Reload
72; CHECK-NEXT:    lfd f21, 312(r1) # 8-byte Folded Reload
73; CHECK-NEXT:    lfd f20, 304(r1) # 8-byte Folded Reload
74; CHECK-NEXT:    lfd f19, 296(r1) # 8-byte Folded Reload
75; CHECK-NEXT:    lfd f18, 288(r1) # 8-byte Folded Reload
76; CHECK-NEXT:    lfd f17, 280(r1) # 8-byte Folded Reload
77; CHECK-NEXT:    lfd f16, 272(r1) # 8-byte Folded Reload
78; CHECK-NEXT:    lfd f15, 264(r1) # 8-byte Folded Reload
79; CHECK-NEXT:    lfd f14, 256(r1) # 8-byte Folded Reload
80; CHECK-NEXT:    addi r1, r1, 400
81; CHECK-NEXT:    blr
82;
83; CHECK-BE-LABEL: test:
84; CHECK-BE:       # %bb.0: # %entry
85; CHECK-BE-NEXT:    stdu r1, -416(r1)
86; CHECK-BE-NEXT:    stfd f14, 272(r1) # 8-byte Folded Spill
87; CHECK-BE-NEXT:    stfd f15, 280(r1) # 8-byte Folded Spill
88; CHECK-BE-NEXT:    stfd f16, 288(r1) # 8-byte Folded Spill
89; CHECK-BE-NEXT:    stfd f17, 296(r1) # 8-byte Folded Spill
90; CHECK-BE-NEXT:    stfd f18, 304(r1) # 8-byte Folded Spill
91; CHECK-BE-NEXT:    stfd f19, 312(r1) # 8-byte Folded Spill
92; CHECK-BE-NEXT:    stfd f20, 320(r1) # 8-byte Folded Spill
93; CHECK-BE-NEXT:    stfd f21, 328(r1) # 8-byte Folded Spill
94; CHECK-BE-NEXT:    stfd f22, 336(r1) # 8-byte Folded Spill
95; CHECK-BE-NEXT:    stfd f23, 344(r1) # 8-byte Folded Spill
96; CHECK-BE-NEXT:    stfd f24, 352(r1) # 8-byte Folded Spill
97; CHECK-BE-NEXT:    stfd f25, 360(r1) # 8-byte Folded Spill
98; CHECK-BE-NEXT:    stfd f26, 368(r1) # 8-byte Folded Spill
99; CHECK-BE-NEXT:    stfd f27, 376(r1) # 8-byte Folded Spill
100; CHECK-BE-NEXT:    stfd f28, 384(r1) # 8-byte Folded Spill
101; CHECK-BE-NEXT:    stfd f29, 392(r1) # 8-byte Folded Spill
102; CHECK-BE-NEXT:    stfd f30, 400(r1) # 8-byte Folded Spill
103; CHECK-BE-NEXT:    stfd f31, 408(r1) # 8-byte Folded Spill
104; CHECK-BE-NEXT:    stxv v20, 80(r1) # 16-byte Folded Spill
105; CHECK-BE-NEXT:    stxv v21, 96(r1) # 16-byte Folded Spill
106; CHECK-BE-NEXT:    stxv v22, 112(r1) # 16-byte Folded Spill
107; CHECK-BE-NEXT:    stxv v23, 128(r1) # 16-byte Folded Spill
108; CHECK-BE-NEXT:    stxv v24, 144(r1) # 16-byte Folded Spill
109; CHECK-BE-NEXT:    stxv v25, 160(r1) # 16-byte Folded Spill
110; CHECK-BE-NEXT:    stxv v26, 176(r1) # 16-byte Folded Spill
111; CHECK-BE-NEXT:    stxv v27, 192(r1) # 16-byte Folded Spill
112; CHECK-BE-NEXT:    stxv v28, 208(r1) # 16-byte Folded Spill
113; CHECK-BE-NEXT:    stxv v29, 224(r1) # 16-byte Folded Spill
114; CHECK-BE-NEXT:    stxv v30, 240(r1) # 16-byte Folded Spill
115; CHECK-BE-NEXT:    stxv v31, 256(r1) # 16-byte Folded Spill
116; CHECK-BE-NEXT:    lxvp vsp34, 0(r3)
117; CHECK-BE-NEXT:    stxvp vsp34, 48(r1) # 32-byte Folded Spill
118; CHECK-BE-NEXT:    #APP
119; CHECK-BE-NEXT:    nop
120; CHECK-BE-NEXT:    #NO_APP
121; CHECK-BE-NEXT:    lxvp vsp34, 48(r1) # 32-byte Folded Reload
122; CHECK-BE-NEXT:    stxvp vsp34, 0(r4)
123; CHECK-BE-NEXT:    lxv v31, 256(r1) # 16-byte Folded Reload
124; CHECK-BE-NEXT:    lxv v30, 240(r1) # 16-byte Folded Reload
125; CHECK-BE-NEXT:    lxv v29, 224(r1) # 16-byte Folded Reload
126; CHECK-BE-NEXT:    lxv v28, 208(r1) # 16-byte Folded Reload
127; CHECK-BE-NEXT:    lxv v27, 192(r1) # 16-byte Folded Reload
128; CHECK-BE-NEXT:    lxv v26, 176(r1) # 16-byte Folded Reload
129; CHECK-BE-NEXT:    lxv v25, 160(r1) # 16-byte Folded Reload
130; CHECK-BE-NEXT:    lxv v24, 144(r1) # 16-byte Folded Reload
131; CHECK-BE-NEXT:    lxv v23, 128(r1) # 16-byte Folded Reload
132; CHECK-BE-NEXT:    lxv v22, 112(r1) # 16-byte Folded Reload
133; CHECK-BE-NEXT:    lxv v21, 96(r1) # 16-byte Folded Reload
134; CHECK-BE-NEXT:    lxv v20, 80(r1) # 16-byte Folded Reload
135; CHECK-BE-NEXT:    lfd f31, 408(r1) # 8-byte Folded Reload
136; CHECK-BE-NEXT:    lfd f30, 400(r1) # 8-byte Folded Reload
137; CHECK-BE-NEXT:    lfd f29, 392(r1) # 8-byte Folded Reload
138; CHECK-BE-NEXT:    lfd f28, 384(r1) # 8-byte Folded Reload
139; CHECK-BE-NEXT:    lfd f27, 376(r1) # 8-byte Folded Reload
140; CHECK-BE-NEXT:    lfd f26, 368(r1) # 8-byte Folded Reload
141; CHECK-BE-NEXT:    lfd f25, 360(r1) # 8-byte Folded Reload
142; CHECK-BE-NEXT:    lfd f24, 352(r1) # 8-byte Folded Reload
143; CHECK-BE-NEXT:    lfd f23, 344(r1) # 8-byte Folded Reload
144; CHECK-BE-NEXT:    lfd f22, 336(r1) # 8-byte Folded Reload
145; CHECK-BE-NEXT:    lfd f21, 328(r1) # 8-byte Folded Reload
146; CHECK-BE-NEXT:    lfd f20, 320(r1) # 8-byte Folded Reload
147; CHECK-BE-NEXT:    lfd f19, 312(r1) # 8-byte Folded Reload
148; CHECK-BE-NEXT:    lfd f18, 304(r1) # 8-byte Folded Reload
149; CHECK-BE-NEXT:    lfd f17, 296(r1) # 8-byte Folded Reload
150; CHECK-BE-NEXT:    lfd f16, 288(r1) # 8-byte Folded Reload
151; CHECK-BE-NEXT:    lfd f15, 280(r1) # 8-byte Folded Reload
152; CHECK-BE-NEXT:    lfd f14, 272(r1) # 8-byte Folded Reload
153; CHECK-BE-NEXT:    addi r1, r1, 416
154; CHECK-BE-NEXT:    blr
155entry:
156  %0 = tail call <256 x i1> @llvm.ppc.vsx.lxvp(ptr %vpp)
157  tail call void asm sideeffect "nop", "~{memory},~{vs0},~{vs1},~{vs2},~{vs3},~{vs4},~{vs5},~{vs6},~{vs7},~{vs8},~{vs9},~{vs10},~{vs11},~{vs12},~{vs13},~{vs14},~{vs15},~{vs16},~{vs17},~{vs18},~{vs19},~{vs20},~{vs21},~{vs22},~{vs23},~{vs24},~{vs25},~{vs26},~{vs27},~{vs28},~{vs29},~{vs30},~{vs31},~{vs32},~{vs33},~{vs34},~{vs35},~{vs36},~{vs37},~{vs38},~{vs39},~{vs40},~{vs41},~{vs42},~{vs43},~{vs44},~{vs45},~{vs46},~{vs47},~{vs48},~{vs49},~{vs50},~{vs51},~{vs52},~{vs53},~{vs54},~{vs55},~{vs56},~{vs57},~{vs58},~{vs59},~{vs60},~{vs61},~{vs62},~{vs63}"()
158  tail call void @llvm.ppc.vsx.stxvp(<256 x i1> %0, ptr %vp2)
159  ret void
160}
161
162declare <256 x i1> @llvm.ppc.vsx.lxvp(ptr) #1
163
164declare void @llvm.ppc.vsx.stxvp(<256 x i1>, ptr) #2
165
166attributes #0 = { nounwind }
167