xref: /llvm-project/llvm/test/Analysis/DemandedBits/vectors-inseltpoison.ll (revision 38fffa630ee80163dc65e759392ad29798905679)
1; RUN: opt -S -disable-output -passes="print<demanded-bits>" < %s 2>&1 | FileCheck %s
2
3; CHECK-DAG: DemandedBits: 0xff00 for   %x = or <2 x i32> %a, zeroinitializer
4; CHECK-DAG: DemandedBits: 0xff00 for   %y = or <2 x i32> %b, zeroinitializer
5; CHECK-DAG: DemandedBits: 0xff00 for   %z = or <2 x i32> %x, %y
6; CHECK-DAG: DemandedBits: 0xff for   %u = lshr <2 x i32> %z, splat (i32 8)
7; CHECK-DAG: DemandedBits: 0xff for   %r = trunc <2 x i32> %u to <2 x i8>
8define <2 x i8> @test_basic(<2 x i32> %a, <2 x i32> %b) {
9  %x = or <2 x i32> %a, zeroinitializer
10  %y = or <2 x i32> %b, zeroinitializer
11  %z = or <2 x i32> %x, %y
12  %u = lshr <2 x i32> %z, <i32 8, i32 8>
13  %r = trunc <2 x i32> %u to <2 x i8>
14  ret <2 x i8> %r
15}
16
17; Vector-specific instructions
18
19; CHECK-DAG: DemandedBits: 0xff for   %x = or <2 x i32> %a, zeroinitializer
20; CHECK-DAG: DemandedBits: 0xf0 for   %z = extractelement <2 x i32> %x, i32 1
21; CHECK-DAG: DemandedBits: 0xf for   %y = extractelement <2 x i32> %x, i32 0
22; CHECK-DAG: DemandedBits: 0xffffffff for   %u = and i32 %y, 15
23; CHECK-DAG: DemandedBits: 0xffffffff for   %v = and i32 %z, 240
24; CHECK-DAG: DemandedBits: 0xffffffff for   %r = or i32 %u, %v
25define i32 @test_extractelement(<2 x i32> %a) {
26  %x = or <2 x i32> %a, zeroinitializer
27  %y = extractelement <2 x i32> %x, i32 0
28  %z = extractelement <2 x i32> %x, i32 1
29  %u = and i32 %y, 15
30  %v = and i32 %z, 240
31  %r = or i32 %u, %v
32  ret i32 %r
33}
34
35; CHECK-DAG: DemandedBits: 0xff for   %x = or i32 %a, 0
36; CHECK-DAG: DemandedBits: 0xff for   %y = or i32 %b, 0
37; CHECK-DAG: DemandedBits: 0xff for   %z = insertelement <2 x i32> poison, i32 %x, i32 0
38; CHECK-DAG: DemandedBits: 0xff for   %u = insertelement <2 x i32> %z, i32 %y, i32 1
39; CHECK-DAG: DemandedBits: 0xffffffff for   %r = and <2 x i32> %u, <i32 255, i32 127>
40define <2 x i32> @test_insertelement(i32 %a, i32 %b) {
41  %x = or i32 %a, 0
42  %y = or i32 %b, 0
43  %z = insertelement <2 x i32> poison, i32 %x, i32 0
44  %u = insertelement <2 x i32> %z, i32 %y, i32 1
45  %r = and <2 x i32> %u, <i32 255, i32 127>
46  ret <2 x i32> %r
47}
48
49; CHECK-DAG: DemandedBits: 0xff for   %x = or <2 x i32> %a, zeroinitializer
50; CHECK-DAG: DemandedBits: 0xff for   %y = or <2 x i32> %b, zeroinitializer
51; CHECK-DAG: DemandedBits: 0xff for   %z = shufflevector <2 x i32> %x, <2 x i32> %y, <3 x i32> <i32 0, i32 3, i32 1>
52; CHECK-DAG: DemandedBits: 0xffffffff for   %r = and <3 x i32> %z, <i32 255, i32 127, i32 0>
53define <3 x i32> @test_shufflevector(<2 x i32> %a, <2 x i32> %b) {
54  %x = or <2 x i32> %a, zeroinitializer
55  %y = or <2 x i32> %b, zeroinitializer
56  %z = shufflevector <2 x i32> %x, <2 x i32> %y, <3 x i32> <i32 0, i32 3, i32 1>
57  %r = and <3 x i32> %z, <i32 255, i32 127, i32 0>
58  ret <3 x i32> %r
59}
60
61; Shifts with splat shift amounts
62
63; CHECK-DAG: DemandedBits: 0xf for   %x = or <2 x i32> %a, zeroinitializer
64; CHECK-DAG: DemandedBits: 0xf0 for   %y = shl <2 x i32> %x, splat (i32 4)
65; CHECK-DAG: DemandedBits: 0xffffffff for   %r = and <2 x i32> %y, splat (i32 240)
66define <2 x i32> @test_shl(<2 x i32> %a) {
67  %x = or <2 x i32> %a, zeroinitializer
68  %y = shl <2 x i32> %x, <i32 4, i32 4>
69  %r = and <2 x i32> %y, <i32 240, i32 240>
70  ret <2 x i32> %r
71}
72
73; CHECK-DAG: DemandedBits: 0xf00 for   %x = or <2 x i32> %a, zeroinitializer
74; CHECK-DAG: DemandedBits: 0xf0 for   %y = ashr <2 x i32> %x, splat (i32 4)
75; CHECK-DAG: DemandedBits: 0xffffffff for   %r = and <2 x i32> %y, splat (i32 240)
76define <2 x i32> @test_ashr(<2 x i32> %a) {
77  %x = or <2 x i32> %a, zeroinitializer
78  %y = ashr <2 x i32> %x, <i32 4, i32 4>
79  %r = and <2 x i32> %y, <i32 240, i32 240>
80  ret <2 x i32> %r
81}
82
83; CHECK-DAG: DemandedBits: 0xf00 for   %x = or <2 x i32> %a, zeroinitializer
84; CHECK-DAG: DemandedBits: 0xf0 for   %y = lshr <2 x i32> %x, splat (i32 4)
85; CHECK-DAG: DemandedBits: 0xffffffff for   %r = and <2 x i32> %y, splat (i32 240)
86define <2 x i32> @test_lshr(<2 x i32> %a) {
87  %x = or <2 x i32> %a, zeroinitializer
88  %y = lshr <2 x i32> %x, <i32 4, i32 4>
89  %r = and <2 x i32> %y, <i32 240, i32 240>
90  ret <2 x i32> %r
91}
92
93declare <2 x i32> @llvm.fshl.i32(<2 x i32>, <2 x i32>, <2 x i32>)
94declare <2 x i32> @llvm.fshr.i32(<2 x i32>, <2 x i32>, <2 x i32>)
95
96; CHECK-DAG: DemandedBits: 0xf for   %x = or <2 x i32> %a, zeroinitializer
97; CHECK-DAG: DemandedBits: 0xf0000000 for   %y = or <2 x i32> %b, zeroinitializer
98; CHECK-DAG: DemandedBits: 0xff for   %z = call <2 x i32> @llvm.fshl.v2i32(<2 x i32> %x, <2 x i32> %y, <2 x i32> splat (i32 4))
99; CHECK-DAG: DemandedBits: 0xffffffff for   %r = and <2 x i32> %z, splat (i32 255)
100define <2 x i32> @test_fshl(<2 x i32> %a, <2 x i32> %b) {
101  %x = or <2 x i32> %a, zeroinitializer
102  %y = or <2 x i32> %b, zeroinitializer
103  %z = call <2 x i32> @llvm.fshl.i32(<2 x i32> %x, <2 x i32> %y, <2 x i32> <i32 4, i32 4>)
104  %r = and <2 x i32> %z, <i32 255, i32 255>
105  ret <2 x i32> %r
106}
107
108; CHECK-DAG: DemandedBits: 0xf for   %x = or <2 x i32> %a, zeroinitializer
109; CHECK-DAG: DemandedBits: 0xf0000000 for   %y = or <2 x i32> %b, zeroinitializer
110; CHECK-DAG: DemandedBits: 0xff for   %z = call <2 x i32> @llvm.fshr.v2i32(<2 x i32> %x, <2 x i32> %y, <2 x i32> splat (i32 28))
111; CHECK-DAG: DemandedBits: 0xffffffff for   %r = and <2 x i32> %z, splat (i32 255)
112define <2 x i32> @test_fshr(<2 x i32> %a, <2 x i32> %b) {
113  %x = or <2 x i32> %a, zeroinitializer
114  %y = or <2 x i32> %b, zeroinitializer
115  %z = call <2 x i32> @llvm.fshr.i32(<2 x i32> %x, <2 x i32> %y, <2 x i32> <i32 28, i32 28>)
116  %r = and <2 x i32> %z, <i32 255, i32 255>
117  ret <2 x i32> %r
118}
119
120; FP / Int conversion. These have different input / output types.
121
122; CHECK-DAG: DemandedBits: 0xffffffff for   %x = or <2 x i32> %a, zeroinitializer
123define <2 x float> @test_uitofp(<2 x i32> %a) {
124  %x = or <2 x i32> %a, zeroinitializer
125  %r = uitofp <2 x i32> %x to <2 x float>
126  ret <2 x float> %r
127}
128
129; CHECK-DAG: DemandedBits: 0xffffffff for   %y = fptoui <2 x float> %x to <2 x i32>
130define <2 x i32> @test_fptoui(<2 x float> %a) {
131  %x = fadd <2 x float> %a, <float 1.0, float 1.0>
132  %y = fptoui <2 x float> %x to <2 x i32>
133  %r = and <2 x i32> %y, <i32 255, i32 255>
134  ret <2 x i32> %y
135}
136