• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \
3; RUN:     -mcpu=pwr9 < %s | FileCheck %s --check-prefix=CHECK-P9
4; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu \
5; RUN:     -mcpu=pwr9 < %s | FileCheck %s --check-prefix=CHECK-P9
6; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \
7; RUN:     -mcpu=pwr9 -mattr=-altivec < %s | FileCheck %s \
8; RUN:     --check-prefix=CHECK-P9-NOALTIVEC
9; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu \
10; RUN:     -mcpu=pwr8 < %s | FileCheck %s --check-prefix=CHECK-P8
11
12define <4 x i32> @test_vextsh2w(<4 x i32> %m) {
13; CHECK-P9-LABEL: test_vextsh2w:
14; CHECK-P9:       # %bb.0: # %entry
15; CHECK-P9-NEXT:    vextsh2w 2, 2
16; CHECK-P9-NEXT:    blr
17;
18; CHECK-P9-NOALTIVEC-LABEL: test_vextsh2w:
19; CHECK-P9-NOALTIVEC:       # %bb.0: # %entry
20; CHECK-P9-NOALTIVEC-NEXT:    extsh 6, 6
21; CHECK-P9-NOALTIVEC-NEXT:    extsh 5, 5
22; CHECK-P9-NOALTIVEC-NEXT:    extsh 4, 4
23; CHECK-P9-NOALTIVEC-NEXT:    extsh 3, 3
24; CHECK-P9-NOALTIVEC-NEXT:    blr
25;
26; CHECK-P8-LABEL: test_vextsh2w:
27; CHECK-P8:       # %bb.0: # %entry
28; CHECK-P8-NEXT:    vspltisw 3, 8
29; CHECK-P8-NEXT:    vadduwm 3, 3, 3
30; CHECK-P8-NEXT:    vslw 2, 2, 3
31; CHECK-P8-NEXT:    vsraw 2, 2, 3
32; CHECK-P8-NEXT:    blr
33entry:
34  %shl = shl <4 x i32> %m, <i32 16, i32 16, i32 16, i32 16>
35  %shr = ashr exact <4 x i32> %shl, <i32 16, i32 16, i32 16, i32 16>
36  ret <4 x i32> %shr
37}
38
39define <4 x i32> @test_vextsb2w(<4 x i32> %m) {
40; CHECK-P9-LABEL: test_vextsb2w:
41; CHECK-P9:       # %bb.0: # %entry
42; CHECK-P9-NEXT:    vextsb2w 2, 2
43; CHECK-P9-NEXT:    blr
44;
45; CHECK-P9-NOALTIVEC-LABEL: test_vextsb2w:
46; CHECK-P9-NOALTIVEC:       # %bb.0: # %entry
47; CHECK-P9-NOALTIVEC-NEXT:    extsb 6, 6
48; CHECK-P9-NOALTIVEC-NEXT:    extsb 5, 5
49; CHECK-P9-NOALTIVEC-NEXT:    extsb 4, 4
50; CHECK-P9-NOALTIVEC-NEXT:    extsb 3, 3
51; CHECK-P9-NOALTIVEC-NEXT:    blr
52;
53; CHECK-P8-LABEL: test_vextsb2w:
54; CHECK-P8:       # %bb.0: # %entry
55; CHECK-P8-NEXT:    vspltisw 3, 12
56; CHECK-P8-NEXT:    vadduwm 3, 3, 3
57; CHECK-P8-NEXT:    vslw 2, 2, 3
58; CHECK-P8-NEXT:    vsraw 2, 2, 3
59; CHECK-P8-NEXT:    blr
60entry:
61  %shl = shl <4 x i32> %m, <i32 24, i32 24, i32 24, i32 24>
62  %shr = ashr exact <4 x i32> %shl, <i32 24, i32 24, i32 24, i32 24>
63  ret <4 x i32> %shr
64}
65
66define <2 x i64> @test_vextsb2d(<2 x i64> %m) {
67; CHECK-P9-LABEL: test_vextsb2d:
68; CHECK-P9:       # %bb.0: # %entry
69; CHECK-P9-NEXT:    vextsb2d 2, 2
70; CHECK-P9-NEXT:    blr
71;
72; CHECK-P9-NOALTIVEC-LABEL: test_vextsb2d:
73; CHECK-P9-NOALTIVEC:       # %bb.0: # %entry
74; CHECK-P9-NOALTIVEC-NEXT:    extsb 3, 3
75; CHECK-P9-NOALTIVEC-NEXT:    extsb 4, 4
76; CHECK-P9-NOALTIVEC-NEXT:    blr
77;
78; CHECK-P8-LABEL: test_vextsb2d:
79; CHECK-P8:       # %bb.0: # %entry
80; CHECK-P8-NEXT:    addis 3, 2, .LCPI2_0@toc@ha
81; CHECK-P8-NEXT:    addi 3, 3, .LCPI2_0@toc@l
82; CHECK-P8-NEXT:    lxvd2x 0, 0, 3
83; CHECK-P8-NEXT:    xxswapd 35, 0
84; CHECK-P8-NEXT:    vsld 2, 2, 3
85; CHECK-P8-NEXT:    vsrad 2, 2, 3
86; CHECK-P8-NEXT:    blr
87entry:
88  %shl = shl <2 x i64> %m, <i64 56, i64 56>
89  %shr = ashr exact <2 x i64> %shl, <i64 56, i64 56>
90  ret <2 x i64> %shr
91}
92
93define <2 x i64> @test_vextsh2d(<2 x i64> %m) {
94; CHECK-P9-LABEL: test_vextsh2d:
95; CHECK-P9:       # %bb.0: # %entry
96; CHECK-P9-NEXT:    vextsh2d 2, 2
97; CHECK-P9-NEXT:    blr
98;
99; CHECK-P9-NOALTIVEC-LABEL: test_vextsh2d:
100; CHECK-P9-NOALTIVEC:       # %bb.0: # %entry
101; CHECK-P9-NOALTIVEC-NEXT:    extsh 3, 3
102; CHECK-P9-NOALTIVEC-NEXT:    extsh 4, 4
103; CHECK-P9-NOALTIVEC-NEXT:    blr
104;
105; CHECK-P8-LABEL: test_vextsh2d:
106; CHECK-P8:       # %bb.0: # %entry
107; CHECK-P8-NEXT:    addis 3, 2, .LCPI3_0@toc@ha
108; CHECK-P8-NEXT:    addi 3, 3, .LCPI3_0@toc@l
109; CHECK-P8-NEXT:    lxvd2x 0, 0, 3
110; CHECK-P8-NEXT:    xxswapd 35, 0
111; CHECK-P8-NEXT:    vsld 2, 2, 3
112; CHECK-P8-NEXT:    vsrad 2, 2, 3
113; CHECK-P8-NEXT:    blr
114entry:
115  %shl = shl <2 x i64> %m, <i64 48, i64 48>
116  %shr = ashr exact <2 x i64> %shl, <i64 48, i64 48>
117  ret <2 x i64> %shr
118}
119
120define <2 x i64> @test_vextsw2d(<2 x i64> %m) {
121; CHECK-P9-LABEL: test_vextsw2d:
122; CHECK-P9:       # %bb.0: # %entry
123; CHECK-P9-NEXT:    vextsw2d 2, 2
124; CHECK-P9-NEXT:    blr
125;
126; CHECK-P9-NOALTIVEC-LABEL: test_vextsw2d:
127; CHECK-P9-NOALTIVEC:       # %bb.0: # %entry
128; CHECK-P9-NOALTIVEC-NEXT:    extsw 3, 3
129; CHECK-P9-NOALTIVEC-NEXT:    extsw 4, 4
130; CHECK-P9-NOALTIVEC-NEXT:    blr
131;
132; CHECK-P8-LABEL: test_vextsw2d:
133; CHECK-P8:       # %bb.0: # %entry
134; CHECK-P8-NEXT:    addis 3, 2, .LCPI4_0@toc@ha
135; CHECK-P8-NEXT:    addi 3, 3, .LCPI4_0@toc@l
136; CHECK-P8-NEXT:    lxvd2x 0, 0, 3
137; CHECK-P8-NEXT:    xxswapd 35, 0
138; CHECK-P8-NEXT:    vsld 2, 2, 3
139; CHECK-P8-NEXT:    vsrad 2, 2, 3
140; CHECK-P8-NEXT:    blr
141entry:
142  %shl = shl <2 x i64> %m, <i64 32, i64 32>
143  %shr = ashr exact <2 x i64> %shl, <i64 32, i64 32>
144  ret <2 x i64> %shr
145}
146
147define <2 x i64> @test_none(<2 x i64> %m) {
148; CHECK-P9-LABEL: test_none:
149; CHECK-P9:       # %bb.0: # %entry
150; CHECK-P9-NEXT:    addis 3, 2, .LCPI5_0@toc@ha
151; CHECK-P9-NEXT:    addi 3, 3, .LCPI5_0@toc@l
152; CHECK-P9-NEXT:    lxvx 35, 0, 3
153; CHECK-P9-NEXT:    vsld 2, 2, 3
154; CHECK-P9-NEXT:    vsrad 2, 2, 3
155; CHECK-P9-NEXT:    blr
156;
157; CHECK-P9-NOALTIVEC-LABEL: test_none:
158; CHECK-P9-NOALTIVEC:       # %bb.0: # %entry
159; CHECK-P9-NOALTIVEC-NEXT:    sldi 3, 3, 16
160; CHECK-P9-NOALTIVEC-NEXT:    sldi 4, 4, 16
161; CHECK-P9-NOALTIVEC-NEXT:    sradi 3, 3, 16
162; CHECK-P9-NOALTIVEC-NEXT:    sradi 4, 4, 16
163; CHECK-P9-NOALTIVEC-NEXT:    blr
164;
165; CHECK-P8-LABEL: test_none:
166; CHECK-P8:       # %bb.0: # %entry
167; CHECK-P8-NEXT:    addis 3, 2, .LCPI5_0@toc@ha
168; CHECK-P8-NEXT:    addi 3, 3, .LCPI5_0@toc@l
169; CHECK-P8-NEXT:    lxvd2x 0, 0, 3
170; CHECK-P8-NEXT:    xxswapd 35, 0
171; CHECK-P8-NEXT:    vsld 2, 2, 3
172; CHECK-P8-NEXT:    vsrad 2, 2, 3
173; CHECK-P8-NEXT:    blr
174entry:
175  %shl = shl <2 x i64> %m, <i64 16, i64 16>
176  %shr = ashr exact <2 x i64> %shl, <i64 16, i64 16>
177  ret <2 x i64> %shr
178}
179