annotate test/Transforms/InstCombine/apint-shift.ll @ 147:c2174574ed3a

LLVM 10
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Wed, 14 Aug 2019 16:55:33 +0900
parents 803732b1fca8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 ; RUN: opt < %s -instcombine -S | FileCheck %s
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
4 define i55 @test6(i55 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
5 ; CHECK-LABEL: @test6(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
6 ; CHECK-NEXT: [[C:%.*]] = mul i55 [[A:%.*]], 6
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
7 ; CHECK-NEXT: ret i55 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
8 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
9 %B = shl i55 %A, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
10 %C = mul i55 %B, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
11 ret i55 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
14 ; (X * C2) << C1 --> X * (C2 << C1)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
15
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
16 define i55 @test6a(i55 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
17 ; CHECK-LABEL: @test6a(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
18 ; CHECK-NEXT: [[C:%.*]] = mul i55 [[A:%.*]], 6
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
19 ; CHECK-NEXT: ret i55 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
20 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
21 %B = mul i55 %A, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
22 %C = shl i55 %B, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
23 ret i55 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
26 ; (X * C2) << C1 --> X * (C2 << C1)
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
27
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
28 define <2 x i55> @test6a_vec(<2 x i55> %A) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
29 ; CHECK-LABEL: @test6a_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
30 ; CHECK-NEXT: [[C:%.*]] = mul <2 x i55> [[A:%.*]], <i55 6, i55 48>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
31 ; CHECK-NEXT: ret <2 x i55> [[C]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
32 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
33 %B = mul <2 x i55> %A, <i55 3, i55 12>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
34 %C = shl <2 x i55> %B, <i55 1, i55 2>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
35 ret <2 x i55> %C
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
36 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
37
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
38 define i29 @test7(i8 %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
39 ; CHECK-LABEL: @test7(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
40 ; CHECK-NEXT: ret i29 -1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
41 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
42 %A = zext i8 %X to i29
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
43 %B = ashr i29 -1, %A
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
44 ret i29 %B
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
47 define i7 @test8(i7 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
48 ; CHECK-LABEL: @test8(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
49 ; CHECK-NEXT: ret i7 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
50 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
51 %B = shl i7 %A, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
52 %C = shl i7 %B, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
53 ret i7 %C
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
54 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
55
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
56 define i17 @test9(i17 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
57 ; CHECK-LABEL: @test9(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
58 ; CHECK-NEXT: [[B:%.*]] = and i17 [[A:%.*]], 1
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
59 ; CHECK-NEXT: ret i17 [[B]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
60 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
61 %B = shl i17 %A, 16
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
62 %C = lshr i17 %B, 16
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
63 ret i17 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
66 ; shl (lshr X, C), C --> and X, C'
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
67
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
68 define i19 @test10(i19 %X) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
69 ; CHECK-LABEL: @test10(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
70 ; CHECK-NEXT: [[SH1:%.*]] = and i19 [[X:%.*]], -262144
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
71 ; CHECK-NEXT: ret i19 [[SH1]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
72 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
73 %sh1 = lshr i19 %X, 18
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
74 %sh2 = shl i19 %sh1, 18
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
75 ret i19 %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
76 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
77
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
78 ; Two right shifts in the same direction:
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
79 ; lshr (lshr X, C1), C2 --> lshr X, C1 + C2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
80
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
81 define <2 x i19> @lshr_lshr_splat_vec(<2 x i19> %X) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
82 ; CHECK-LABEL: @lshr_lshr_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
83 ; CHECK-NEXT: [[SH1:%.*]] = lshr <2 x i19> [[X:%.*]], <i19 5, i19 5>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
84 ; CHECK-NEXT: ret <2 x i19> [[SH1]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
85 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
86 %sh1 = lshr <2 x i19> %X, <i19 3, i19 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
87 %sh2 = lshr <2 x i19> %sh1, <i19 2, i19 2>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
88 ret <2 x i19> %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
89 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
90
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
91 define i9 @multiuse_lshr_lshr(i9 %x) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
92 ; CHECK-LABEL: @multiuse_lshr_lshr(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
93 ; CHECK-NEXT: [[SH1:%.*]] = lshr i9 [[X:%.*]], 2
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
94 ; CHECK-NEXT: [[SH2:%.*]] = lshr i9 [[X]], 5
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
95 ; CHECK-NEXT: [[MUL:%.*]] = mul i9 [[SH1]], [[SH2]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
96 ; CHECK-NEXT: ret i9 [[MUL]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
97 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
98 %sh1 = lshr i9 %x, 2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
99 %sh2 = lshr i9 %sh1, 3
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
100 %mul = mul i9 %sh1, %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
101 ret i9 %mul
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
102 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
103
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
104 define <2 x i9> @multiuse_lshr_lshr_splat(<2 x i9> %x) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
105 ; CHECK-LABEL: @multiuse_lshr_lshr_splat(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
106 ; CHECK-NEXT: [[SH1:%.*]] = lshr <2 x i9> [[X:%.*]], <i9 2, i9 2>
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
107 ; CHECK-NEXT: [[SH2:%.*]] = lshr <2 x i9> [[X]], <i9 5, i9 5>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
108 ; CHECK-NEXT: [[MUL:%.*]] = mul <2 x i9> [[SH1]], [[SH2]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
109 ; CHECK-NEXT: ret <2 x i9> [[MUL]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
110 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
111 %sh1 = lshr <2 x i9> %x, <i9 2, i9 2>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
112 %sh2 = lshr <2 x i9> %sh1, <i9 3, i9 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
113 %mul = mul <2 x i9> %sh1, %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
114 ret <2 x i9> %mul
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
115 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
116
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
117 ; Two left shifts in the same direction:
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
118 ; shl (shl X, C1), C2 --> shl X, C1 + C2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
119
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
120 define <2 x i19> @shl_shl_splat_vec(<2 x i19> %X) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
121 ; CHECK-LABEL: @shl_shl_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
122 ; CHECK-NEXT: [[SH1:%.*]] = shl <2 x i19> [[X:%.*]], <i19 5, i19 5>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
123 ; CHECK-NEXT: ret <2 x i19> [[SH1]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
124 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
125 %sh1 = shl <2 x i19> %X, <i19 3, i19 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
126 %sh2 = shl <2 x i19> %sh1, <i19 2, i19 2>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
127 ret <2 x i19> %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
128 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
129
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
130 define i42 @multiuse_shl_shl(i42 %x) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
131 ; CHECK-LABEL: @multiuse_shl_shl(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
132 ; CHECK-NEXT: [[SH1:%.*]] = shl i42 [[X:%.*]], 8
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
133 ; CHECK-NEXT: [[SH2:%.*]] = shl i42 [[X]], 17
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
134 ; CHECK-NEXT: [[MUL:%.*]] = mul i42 [[SH1]], [[SH2]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
135 ; CHECK-NEXT: ret i42 [[MUL]]
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
136 ;
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
137 %sh1 = shl i42 %x, 8
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
138 %sh2 = shl i42 %sh1, 9
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
139 %mul = mul i42 %sh1, %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
140 ret i42 %mul
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
141 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
142
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
143 define <2 x i42> @multiuse_shl_shl_splat(<2 x i42> %x) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
144 ; CHECK-LABEL: @multiuse_shl_shl_splat(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
145 ; CHECK-NEXT: [[SH1:%.*]] = shl <2 x i42> [[X:%.*]], <i42 8, i42 8>
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
146 ; CHECK-NEXT: [[SH2:%.*]] = shl <2 x i42> [[X]], <i42 17, i42 17>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
147 ; CHECK-NEXT: [[MUL:%.*]] = mul <2 x i42> [[SH1]], [[SH2]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
148 ; CHECK-NEXT: ret <2 x i42> [[MUL]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
149 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
150 %sh1 = shl <2 x i42> %x, <i42 8, i42 8>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
151 %sh2 = shl <2 x i42> %sh1, <i42 9, i42 9>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
152 %mul = mul <2 x i42> %sh1, %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
153 ret <2 x i42> %mul
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
154 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
155
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
156 ; Equal shift amounts in opposite directions become bitwise 'and':
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
157 ; lshr (shl X, C), C --> and X, C'
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
158
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
159 define <2 x i19> @eq_shl_lshr_splat_vec(<2 x i19> %X) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
160 ; CHECK-LABEL: @eq_shl_lshr_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
161 ; CHECK-NEXT: [[SH1:%.*]] = and <2 x i19> [[X:%.*]], <i19 65535, i19 65535>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
162 ; CHECK-NEXT: ret <2 x i19> [[SH1]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
163 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
164 %sh1 = shl <2 x i19> %X, <i19 3, i19 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
165 %sh2 = lshr <2 x i19> %sh1, <i19 3, i19 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
166 ret <2 x i19> %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
167 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
168
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
169 ; Equal shift amounts in opposite directions become bitwise 'and':
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
170 ; shl (lshr X, C), C --> and X, C'
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
171
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
172 define <2 x i19> @eq_lshr_shl_splat_vec(<2 x i19> %X) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
173 ; CHECK-LABEL: @eq_lshr_shl_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
174 ; CHECK-NEXT: [[SH1:%.*]] = and <2 x i19> [[X:%.*]], <i19 -8, i19 -8>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
175 ; CHECK-NEXT: ret <2 x i19> [[SH1]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
176 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
177 %sh1 = lshr <2 x i19> %X, <i19 3, i19 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
178 %sh2 = shl <2 x i19> %sh1, <i19 3, i19 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
179 ret <2 x i19> %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
180 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
181
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
182 ; In general, we would need an 'and' for this transform, but the masked-off bits are known zero.
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
183 ; shl (lshr X, C1), C2 --> lshr X, C1 - C2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
184
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
185 define <2 x i7> @lshr_shl_splat_vec(<2 x i7> %X) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
186 ; CHECK-LABEL: @lshr_shl_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
187 ; CHECK-NEXT: [[MUL:%.*]] = mul <2 x i7> [[X:%.*]], <i7 -8, i7 -8>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
188 ; CHECK-NEXT: [[SH1:%.*]] = lshr exact <2 x i7> [[MUL]], <i7 1, i7 1>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
189 ; CHECK-NEXT: ret <2 x i7> [[SH1]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
190 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
191 %mul = mul <2 x i7> %X, <i7 -8, i7 -8>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
192 %sh1 = lshr exact <2 x i7> %mul, <i7 3, i7 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
193 %sh2 = shl nuw nsw <2 x i7> %sh1, <i7 2, i7 2>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
194 ret <2 x i7> %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
195 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
196
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
197 ; In general, we would need an 'and' for this transform, but the masked-off bits are known zero.
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
198 ; lshr (shl X, C1), C2 --> shl X, C1 - C2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
199
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
200 define <2 x i7> @shl_lshr_splat_vec(<2 x i7> %X) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
201 ; CHECK-LABEL: @shl_lshr_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
202 ; CHECK-NEXT: [[DIV:%.*]] = udiv <2 x i7> [[X:%.*]], <i7 9, i7 9>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
203 ; CHECK-NEXT: [[SH1:%.*]] = shl nuw nsw <2 x i7> [[DIV]], <i7 1, i7 1>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
204 ; CHECK-NEXT: ret <2 x i7> [[SH1]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
205 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
206 %div = udiv <2 x i7> %X, <i7 9, i7 9>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
207 %sh1 = shl nuw <2 x i7> %div, <i7 3, i7 3>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
208 %sh2 = lshr exact <2 x i7> %sh1, <i7 2, i7 2>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
209 ret <2 x i7> %sh2
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
210 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
211
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
212 ; Don't hide the shl from scalar evolution. DAGCombine will get it.
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
213
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
214 define i23 @test11(i23 %x) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
215 ; CHECK-LABEL: @test11(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
216 ; CHECK-NEXT: [[A:%.*]] = mul i23 [[X:%.*]], 3
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
217 ; CHECK-NEXT: [[B:%.*]] = lshr i23 [[A]], 11
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
218 ; CHECK-NEXT: [[C:%.*]] = shl i23 [[B]], 12
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
219 ; CHECK-NEXT: ret i23 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
220 ;
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
221 %a = mul i23 %x, 3
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
222 %b = lshr i23 %a, 11
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
223 %c = shl i23 %b, 12
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
224 ret i23 %c
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
226
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
227 ; shl (ashr X, C), C --> and X, C'
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
228
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
229 define i47 @test12(i47 %X) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
230 ; CHECK-LABEL: @test12(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
231 ; CHECK-NEXT: [[TMP1:%.*]] = and i47 [[X:%.*]], -256
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
232 ; CHECK-NEXT: ret i47 [[TMP1]]
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
233 ;
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
234 %sh1 = ashr i47 %X, 8
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
235 %sh2 = shl i47 %sh1, 8
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
236 ret i47 %sh2
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
237 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
238
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
239 define <2 x i47> @test12_splat_vec(<2 x i47> %X) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
240 ; CHECK-LABEL: @test12_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
241 ; CHECK-NEXT: [[TMP1:%.*]] = and <2 x i47> [[X:%.*]], <i47 -256, i47 -256>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
242 ; CHECK-NEXT: ret <2 x i47> [[TMP1]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
243 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
244 %sh1 = ashr <2 x i47> %X, <i47 8, i47 8>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
245 %sh2 = shl <2 x i47> %sh1, <i47 8, i47 8>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
246 ret <2 x i47> %sh2
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
247 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
248
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
249 ; Don't hide the shl from scalar evolution. DAGCombine will get it.
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
250
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
251 define i18 @test13(i18 %x) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
252 ; CHECK-LABEL: @test13(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
253 ; CHECK-NEXT: [[A:%.*]] = mul i18 [[X:%.*]], 3
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
254 ; CHECK-NEXT: [[TMP1:%.*]] = lshr i18 [[A]], 8
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
255 ; CHECK-NEXT: [[C:%.*]] = shl i18 [[TMP1]], 9
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
256 ; CHECK-NEXT: ret i18 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
257 ;
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
258 %a = mul i18 %x, 3
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
259 %b = ashr i18 %a, 8
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
260 %c = shl i18 %b, 9
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
261 ret i18 %c
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
262 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
263
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
264 define i35 @test14(i35 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
265 ; CHECK-LABEL: @test14(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
266 ; CHECK-NEXT: [[B:%.*]] = and i35 [[A:%.*]], -19760
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
267 ; CHECK-NEXT: [[C:%.*]] = or i35 [[B]], 19744
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
268 ; CHECK-NEXT: ret i35 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
269 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
270 %B = lshr i35 %A, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
271 %C = or i35 %B, 1234
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
272 %D = shl i35 %C, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
273 ret i35 %D
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
274 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
275
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
276 define i79 @test14a(i79 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
277 ; CHECK-LABEL: @test14a(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
278 ; CHECK-NEXT: [[C:%.*]] = and i79 [[A:%.*]], 77
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
279 ; CHECK-NEXT: ret i79 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
280 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
281 %B = shl i79 %A, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
282 %C = and i79 %B, 1234
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
283 %D = lshr i79 %C, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
284 ret i79 %D
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
285 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
286
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
287 define i45 @test15(i1 %C) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
288 ; CHECK-LABEL: @test15(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
289 ; CHECK-NEXT: [[A:%.*]] = select i1 [[C:%.*]], i45 12, i45 4
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
290 ; CHECK-NEXT: ret i45 [[A]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
291 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
292 %A = select i1 %C, i45 3, i45 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
293 %V = shl i45 %A, 2
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
294 ret i45 %V
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
295 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
296
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
297 define i53 @test15a(i1 %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
298 ; CHECK-LABEL: @test15a(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
299 ; CHECK-NEXT: [[V:%.*]] = select i1 [[X:%.*]], i53 512, i53 128
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
300 ; CHECK-NEXT: ret i53 [[V]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
301 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
302 %A = select i1 %X, i8 3, i8 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
303 %B = zext i8 %A to i53
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
304 %V = shl i53 64, %B
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
305 ret i53 %V
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
306 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
307
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
308 define i1 @test16(i84 %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
309 ; CHECK-LABEL: @test16(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
310 ; CHECK-NEXT: [[AND:%.*]] = and i84 [[X:%.*]], 16
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
311 ; CHECK-NEXT: [[CMP:%.*]] = icmp ne i84 [[AND]], 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
312 ; CHECK-NEXT: ret i1 [[CMP]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
313 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
314 %shr = ashr i84 %X, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
315 %and = and i84 %shr, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
316 %cmp = icmp ne i84 %and, 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
317 ret i1 %cmp
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
318 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
319
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
320 define <2 x i1> @test16vec(<2 x i84> %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
321 ; CHECK-LABEL: @test16vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
322 ; CHECK-NEXT: [[TMP1:%.*]] = and <2 x i84> [[X:%.*]], <i84 16, i84 16>
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
323 ; CHECK-NEXT: [[CMP:%.*]] = icmp ne <2 x i84> [[TMP1]], zeroinitializer
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
324 ; CHECK-NEXT: ret <2 x i1> [[CMP]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
325 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
326 %shr = ashr <2 x i84> %X, <i84 4, i84 4>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
327 %and = and <2 x i84> %shr, <i84 1, i84 1>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
328 %cmp = icmp ne <2 x i84> %and, zeroinitializer
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
329 ret <2 x i1> %cmp
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
330 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
331
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
332 define i1 @test17(i106 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
333 ; CHECK-LABEL: @test17(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
334 ; CHECK-NEXT: [[B_MASK:%.*]] = and i106 [[A:%.*]], -8
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
335 ; CHECK-NEXT: [[C:%.*]] = icmp eq i106 [[B_MASK]], 9872
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
336 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
337 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
338 %B = lshr i106 %A, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
339 %C = icmp eq i106 %B, 1234
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
340 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
341 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
342
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
343 define <2 x i1> @test17vec(<2 x i106> %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
344 ; CHECK-LABEL: @test17vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
345 ; CHECK-NEXT: [[B_MASK:%.*]] = and <2 x i106> [[A:%.*]], <i106 -8, i106 -8>
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
346 ; CHECK-NEXT: [[C:%.*]] = icmp eq <2 x i106> [[B_MASK]], <i106 9872, i106 9872>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
347 ; CHECK-NEXT: ret <2 x i1> [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
348 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
349 %B = lshr <2 x i106> %A, <i106 3, i106 3>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
350 %C = icmp eq <2 x i106> %B, <i106 1234, i106 1234>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
351 ret <2 x i1> %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
352 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
353
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
354 define i1 @test18(i11 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
355 ; CHECK-LABEL: @test18(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
356 ; CHECK-NEXT: ret i1 false
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
357 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
358 %B = lshr i11 %A, 10
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
359 %C = icmp eq i11 %B, 123
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
360 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
361 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
362
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
363 define i1 @test19(i37 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
364 ; CHECK-LABEL: @test19(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
365 ; CHECK-NEXT: [[C:%.*]] = icmp ult i37 [[A:%.*]], 4
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
366 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
367 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
368 %B = ashr i37 %A, 2
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
369 %C = icmp eq i37 %B, 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
370 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
371 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
372
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
373 define <2 x i1> @test19vec(<2 x i37> %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
374 ; CHECK-LABEL: @test19vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
375 ; CHECK-NEXT: [[C:%.*]] = icmp ult <2 x i37> [[A:%.*]], <i37 4, i37 4>
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
376 ; CHECK-NEXT: ret <2 x i1> [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
377 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
378 %B = ashr <2 x i37> %A, <i37 2, i37 2>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
379 %C = icmp eq <2 x i37> %B, zeroinitializer
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
380 ret <2 x i1> %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
381 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
382
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
383 define i1 @test19a(i39 %A) {
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
384 ; CHECK-LABEL: @test19a(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
385 ; CHECK-NEXT: [[C:%.*]] = icmp ugt i39 [[A:%.*]], -5
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
386 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
387 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
388 %B = ashr i39 %A, 2
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
389 %C = icmp eq i39 %B, -1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
390 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
391 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
392
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
393 define <2 x i1> @test19a_vec(<2 x i39> %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
394 ; CHECK-LABEL: @test19a_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
395 ; CHECK-NEXT: [[C:%.*]] = icmp ugt <2 x i39> [[A:%.*]], <i39 -5, i39 -5>
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
396 ; CHECK-NEXT: ret <2 x i1> [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
397 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
398 %B = ashr <2 x i39> %A, <i39 2, i39 2>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
399 %C = icmp eq <2 x i39> %B, <i39 -1, i39 -1>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
400 ret <2 x i1> %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
401 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
402
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
403 define i1 @test20(i13 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
404 ; CHECK-LABEL: @test20(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
405 ; CHECK-NEXT: ret i1 false
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
406 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
407 %B = ashr i13 %A, 12
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
408 %C = icmp eq i13 %B, 123
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
409 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
410 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
411
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
412 define i1 @test21(i12 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
413 ; CHECK-LABEL: @test21(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
414 ; CHECK-NEXT: [[B_MASK:%.*]] = and i12 [[A:%.*]], 63
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
415 ; CHECK-NEXT: [[C:%.*]] = icmp eq i12 [[B_MASK]], 62
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
416 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
417 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
418 %B = shl i12 %A, 6
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
419 %C = icmp eq i12 %B, -128
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
420 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
421 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
422
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
423 define i1 @test22(i14 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
424 ; CHECK-LABEL: @test22(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
425 ; CHECK-NEXT: [[B_MASK:%.*]] = and i14 [[A:%.*]], 127
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
426 ; CHECK-NEXT: [[C:%.*]] = icmp eq i14 [[B_MASK]], 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
427 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
428 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
429 %B = shl i14 %A, 7
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
430 %C = icmp eq i14 %B, 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
431 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
432 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
433
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
434 define i11 @test23(i44 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
435 ; CHECK-LABEL: @test23(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
436 ; CHECK-NEXT: [[D:%.*]] = trunc i44 [[A:%.*]] to i11
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
437 ; CHECK-NEXT: ret i11 [[D]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
438 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
439 %B = shl i44 %A, 33
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
440 %C = ashr i44 %B, 33
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
441 %D = trunc i44 %C to i11
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
442 ret i11 %D
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
443 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
444
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
445 ; Fold lshr (shl X, C), C -> and X, C' regardless of the number of uses of the shl.
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
446
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
447 define i44 @shl_lshr_eq_amt_multi_use(i44 %A) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
448 ; CHECK-LABEL: @shl_lshr_eq_amt_multi_use(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
449 ; CHECK-NEXT: [[B:%.*]] = shl i44 [[A:%.*]], 33
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
450 ; CHECK-NEXT: [[C:%.*]] = and i44 [[A]], 2047
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
451 ; CHECK-NEXT: [[D:%.*]] = or i44 [[B]], [[C]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
452 ; CHECK-NEXT: ret i44 [[D]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
453 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
454 %B = shl i44 %A, 33
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
455 %C = lshr i44 %B, 33
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
456 %D = add i44 %B, %C
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
457 ret i44 %D
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
458 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
459
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
460 ; Fold vector lshr (shl X, C), C -> and X, C' regardless of the number of uses of the shl.
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
461
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
462 define <2 x i44> @shl_lshr_eq_amt_multi_use_splat_vec(<2 x i44> %A) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
463 ; CHECK-LABEL: @shl_lshr_eq_amt_multi_use_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
464 ; CHECK-NEXT: [[B:%.*]] = shl <2 x i44> [[A:%.*]], <i44 33, i44 33>
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
465 ; CHECK-NEXT: [[C:%.*]] = and <2 x i44> [[A]], <i44 2047, i44 2047>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
466 ; CHECK-NEXT: [[D:%.*]] = or <2 x i44> [[B]], [[C]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
467 ; CHECK-NEXT: ret <2 x i44> [[D]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
468 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
469 %B = shl <2 x i44> %A, <i44 33, i44 33>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
470 %C = lshr <2 x i44> %B, <i44 33, i44 33>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
471 %D = add <2 x i44> %B, %C
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
472 ret <2 x i44> %D
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
473 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
474
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
475 ; Fold shl (lshr X, C), C -> and X, C' regardless of the number of uses of the lshr.
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
476
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
477 define i43 @lshr_shl_eq_amt_multi_use(i43 %A) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
478 ; CHECK-LABEL: @lshr_shl_eq_amt_multi_use(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
479 ; CHECK-NEXT: [[B:%.*]] = lshr i43 [[A:%.*]], 23
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
480 ; CHECK-NEXT: [[C:%.*]] = and i43 [[A]], -8388608
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
481 ; CHECK-NEXT: [[D:%.*]] = mul i43 [[B]], [[C]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
482 ; CHECK-NEXT: ret i43 [[D]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
483 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
484 %B = lshr i43 %A, 23
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
485 %C = shl i43 %B, 23
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
486 %D = mul i43 %B, %C
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
487 ret i43 %D
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
488 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
489
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
490 ; Fold vector shl (lshr X, C), C -> and X, C' regardless of the number of uses of the lshr.
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
491
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
492 define <2 x i43> @lshr_shl_eq_amt_multi_use_splat_vec(<2 x i43> %A) {
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
493 ; CHECK-LABEL: @lshr_shl_eq_amt_multi_use_splat_vec(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
494 ; CHECK-NEXT: [[B:%.*]] = lshr <2 x i43> [[A:%.*]], <i43 23, i43 23>
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
495 ; CHECK-NEXT: [[C:%.*]] = and <2 x i43> [[A]], <i43 -8388608, i43 -8388608>
121
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
496 ; CHECK-NEXT: [[D:%.*]] = mul <2 x i43> [[B]], [[C]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
497 ; CHECK-NEXT: ret <2 x i43> [[D]]
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
498 ;
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
499 %B = lshr <2 x i43> %A, <i43 23, i43 23>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
500 %C = shl <2 x i43> %B, <i43 23, i43 23>
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
501 %D = mul <2 x i43> %B, %C
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
502 ret <2 x i43> %D
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
503 }
803732b1fca8 LLVM 5.0
kono
parents: 120
diff changeset
504
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
505 define i37 @test25(i37 %tmp.2, i37 %AA) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
506 ; CHECK-LABEL: @test25(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
507 ; CHECK-NEXT: [[TMP_3:%.*]] = and i37 [[TMP_2:%.*]], -131072
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
508 ; CHECK-NEXT: [[X2:%.*]] = add i37 [[TMP_3]], [[AA:%.*]]
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
509 ; CHECK-NEXT: [[TMP_6:%.*]] = and i37 [[X2]], -131072
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
510 ; CHECK-NEXT: ret i37 [[TMP_6]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
511 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
512 %x = lshr i37 %AA, 17
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
513 %tmp.3 = lshr i37 %tmp.2, 17
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
514 %tmp.5 = add i37 %tmp.3, %x
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
515 %tmp.6 = shl i37 %tmp.5, 17
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
516 ret i37 %tmp.6
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
517 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
518
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
519 define i40 @test26(i40 %A) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
520 ; CHECK-LABEL: @test26(
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
521 ; CHECK-NEXT: [[B:%.*]] = and i40 [[A:%.*]], -2
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
522 ; CHECK-NEXT: ret i40 [[B]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
523 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
524 %B = lshr i40 %A, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
525 %C = bitcast i40 %B to i40
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
526 %D = shl i40 %C, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
527 ret i40 %D
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
528 }
147
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
529
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
530 ; OSS-Fuzz #9880
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
531 ; https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=9880
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
532 define i177 @ossfuzz_9880(i177 %X) {
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
533 ; CHECK-LABEL: @ossfuzz_9880(
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
534 ; CHECK-NEXT: [[A:%.*]] = alloca i177, align 8
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
535 ; CHECK-NEXT: [[L1:%.*]] = load i177, i177* [[A]], align 8
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
536 ; CHECK-NEXT: [[TMP1:%.*]] = icmp eq i177 [[L1]], 0
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
537 ; CHECK-NEXT: [[B1:%.*]] = zext i1 [[TMP1]] to i177
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
538 ; CHECK-NEXT: ret i177 [[B1]]
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
539 ;
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
540 %A = alloca i177
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
541 %L1 = load i177, i177* %A
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
542 %B = or i177 0, -1
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
543 %B5 = udiv i177 %L1, %B
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
544 %B4 = add i177 %B5, %B
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
545 %B2 = add i177 %B, %B4
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
546 %B6 = mul i177 %B5, %B2
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
547 %B20 = shl i177 %L1, %B6
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
548 %B14 = sub i177 %B20, %B5
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
549 %B1 = udiv i177 %B14, %B6
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
550 ret i177 %B1
c2174574ed3a LLVM 10
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 121
diff changeset
551 }