annotate test/Transforms/InstCombine/apint-shift.ll @ 120:1172e4bd9c6f

update 4.0.0
author mir3636
date Fri, 25 Nov 2016 19:14:25 +0900
parents 95c75e76d11b
children 803732b1fca8
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 ; This test makes sure that shift instructions are properly eliminated
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 ; even with arbitrary precision integers.
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 ; RUN: opt < %s -instcombine -S | FileCheck %s
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
6 define i47 @test1(i47 %A) {
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 ; CHECK-LABEL: @test1(
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
8 ; CHECK-NEXT: ret i47 %A
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
9 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
10 %B = shl i47 %A, 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
11 ret i47 %B
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
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
14 define i41 @test2(i7 %X) {
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 ; CHECK-LABEL: @test2(
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
16 ; CHECK-NEXT: ret i41 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
17 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
18 %A = zext i7 %X to i41
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
19 %B = shl i41 0, %A
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
20 ret i41 %B
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
23 define i41 @test3(i41 %A) {
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 ; CHECK-LABEL: @test3(
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
25 ; CHECK-NEXT: ret i41 %A
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
26 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
27 %B = ashr i41 %A, 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
28 ret i41 %B
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
29 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
30
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
31 define i39 @test4(i7 %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
32 ; CHECK-LABEL: @test4(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
33 ; CHECK-NEXT: ret i39 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
34 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
35 %A = zext i7 %X to i39
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
36 %B = ashr i39 0, %A
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
37 ret i39 %B
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
40 define i55 @test5(i55 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
41 ; CHECK-LABEL: @test5(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
42 ; CHECK-NEXT: ret i55 undef
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
43 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
44 %B = lshr i55 %A, 55
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
45 ret i55 %B
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
46 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
47
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
48 define i32 @test5a(i32 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
49 ; CHECK-LABEL: @test5a(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
50 ; CHECK-NEXT: ret i32 undef
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
51 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
52 %B = shl i32 %A, 32
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
53 ret i32 %B
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
56 define i55 @test6(i55 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
57 ; CHECK-LABEL: @test6(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
58 ; CHECK-NEXT: [[C:%.*]] = mul i55 %A, 6
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
59 ; CHECK-NEXT: ret i55 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
60 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
61 %B = shl i55 %A, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
62 %C = mul i55 %B, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
63 ret i55 %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
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
66 define i55 @test6a(i55 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
67 ; CHECK-LABEL: @test6a(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
68 ; CHECK-NEXT: [[C:%.*]] = mul i55 %A, 6
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
69 ; CHECK-NEXT: ret i55 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
70 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
71 %B = mul i55 %A, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
72 %C = shl i55 %B, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
73 ret i55 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
76 define i29 @test7(i8 %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
77 ; CHECK-LABEL: @test7(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
78 ; CHECK-NEXT: ret i29 -1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
79 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
80 %A = zext i8 %X to i29
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
81 %B = ashr i29 -1, %A
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
82 ret i29 %B
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
85 define i7 @test8(i7 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
86 ; CHECK-LABEL: @test8(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
87 ; CHECK-NEXT: ret i7 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
88 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
89 %B = shl i7 %A, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
90 %C = shl i7 %B, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
91 ret i7 %C
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
92 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
93
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
94 define i17 @test9(i17 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
95 ; CHECK-LABEL: @test9(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
96 ; CHECK-NEXT: [[B:%.*]] = and i17 %A, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
97 ; CHECK-NEXT: ret i17 [[B]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
98 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
99 %B = shl i17 %A, 16
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
100 %C = lshr i17 %B, 16
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
101 ret i17 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
102 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
103
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
104 define i19 @test10(i19 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
105 ; CHECK-LABEL: @test10(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
106 ; CHECK-NEXT: [[B:%.*]] = and i19 %A, -262144
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
107 ; CHECK-NEXT: ret i19 [[B]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
108 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
109 %B = lshr i19 %A, 18
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
110 %C = shl i19 %B, 18
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
111 ret i19 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
113
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
114 ; Don't hide the shl from scalar evolution. DAGCombine will get it.
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
115 define i23 @test11(i23 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
116 ; CHECK-LABEL: @test11(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
117 ; CHECK-NEXT: [[A:%.*]] = mul i23 %A, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
118 ; CHECK-NEXT: [[B:%.*]] = lshr i23 [[A]], 11
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
119 ; CHECK-NEXT: [[C:%.*]] = shl i23 [[B]], 12
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
120 ; CHECK-NEXT: ret i23 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
121 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
122 %a = mul i23 %A, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
123 %B = lshr i23 %a, 11
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
124 %C = shl i23 %B, 12
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
125 ret i23 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
126 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
127
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
128 define i47 @test12(i47 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
129 ; CHECK-LABEL: @test12(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
130 ; CHECK-NEXT: [[B1:%.*]] = and i47 %A, -256
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
131 ; CHECK-NEXT: ret i47 [[B1]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
132 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
133 %B = ashr i47 %A, 8
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
134 %C = shl i47 %B, 8
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
135 ret i47 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
136 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
137
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
138 ; Don't hide the shl from scalar evolution. DAGCombine will get it.
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
139 define i18 @test13(i18 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
140 ; CHECK-LABEL: @test13(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
141 ; CHECK-NEXT: [[A:%.*]] = mul i18 %A, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
142 ; CHECK-NEXT: [[B1:%.*]] = lshr i18 [[A]], 8
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
143 ; CHECK-NEXT: [[C:%.*]] = shl i18 [[B1]], 9
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
144 ; CHECK-NEXT: ret i18 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
145 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
146 %a = mul i18 %A, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
147 %B = ashr i18 %a, 8
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
148 %C = shl i18 %B, 9
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
149 ret i18 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
151
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
152 define i35 @test14(i35 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
153 ; CHECK-LABEL: @test14(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
154 ; CHECK-NEXT: [[B:%.*]] = and i35 %A, -19760
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
155 ; CHECK-NEXT: [[C:%.*]] = or i35 [[B]], 19744
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
156 ; CHECK-NEXT: ret i35 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
157 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
158 %B = lshr i35 %A, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
159 %C = or i35 %B, 1234
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
160 %D = shl i35 %C, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
161 ret i35 %D
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
162 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
163
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
164 define i79 @test14a(i79 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
165 ; CHECK-LABEL: @test14a(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
166 ; CHECK-NEXT: [[C:%.*]] = and i79 %A, 77
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
167 ; CHECK-NEXT: ret i79 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
168 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
169 %B = shl i79 %A, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
170 %C = and i79 %B, 1234
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
171 %D = lshr i79 %C, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
172 ret i79 %D
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
173 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
174
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
175 define i45 @test15(i1 %C) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
176 ; CHECK-LABEL: @test15(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
177 ; CHECK-NEXT: [[A:%.*]] = select i1 %C, i45 12, i45 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
178 ; CHECK-NEXT: ret i45 [[A]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
179 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
180 %A = select i1 %C, i45 3, i45 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
181 %V = shl i45 %A, 2
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
182 ret i45 %V
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
184
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
185 define i53 @test15a(i1 %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
186 ; CHECK-LABEL: @test15a(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
187 ; CHECK-NEXT: [[V:%.*]] = select i1 %X, i53 512, i53 128
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
188 ; CHECK-NEXT: ret i53 [[V]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
189 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
190 %A = select i1 %X, i8 3, i8 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
191 %B = zext i8 %A to i53
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
192 %V = shl i53 64, %B
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
193 ret i53 %V
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
194 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
195
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
196 define i1 @test16(i84 %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
197 ; CHECK-LABEL: @test16(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
198 ; CHECK-NEXT: [[AND:%.*]] = and i84 %X, 16
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
199 ; CHECK-NEXT: [[CMP:%.*]] = icmp ne i84 [[AND]], 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
200 ; CHECK-NEXT: ret i1 [[CMP]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
201 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
202 %shr = ashr i84 %X, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
203 %and = and i84 %shr, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
204 %cmp = icmp ne i84 %and, 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
205 ret i1 %cmp
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
207
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
208 define <2 x i1> @test16vec(<2 x i84> %X) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
209 ; CHECK-LABEL: @test16vec(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
210 ; CHECK-NEXT: [[AND:%.*]] = and <2 x i84> %X, <i84 16, i84 16>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
211 ; CHECK-NEXT: [[CMP:%.*]] = icmp ne <2 x i84> [[AND]], zeroinitializer
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
212 ; CHECK-NEXT: ret <2 x i1> [[CMP]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
213 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
214 %shr = ashr <2 x i84> %X, <i84 4, i84 4>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
215 %and = and <2 x i84> %shr, <i84 1, i84 1>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
216 %cmp = icmp ne <2 x i84> %and, zeroinitializer
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
217 ret <2 x i1> %cmp
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
218 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
219
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
220 define i1 @test17(i106 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
221 ; CHECK-LABEL: @test17(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
222 ; CHECK-NEXT: [[B_MASK:%.*]] = and i106 %A, -8
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
223 ; CHECK-NEXT: [[C:%.*]] = icmp eq i106 [[B_MASK]], 9872
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
224 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
225 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
226 %B = lshr i106 %A, 3
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
227 %C = icmp eq i106 %B, 1234
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
228 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
229 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
230
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
231 define <2 x i1> @test17vec(<2 x i106> %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
232 ; CHECK-LABEL: @test17vec(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
233 ; CHECK-NEXT: [[B_MASK:%.*]] = and <2 x i106> %A, <i106 -8, i106 -8>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
234 ; CHECK-NEXT: [[C:%.*]] = icmp eq <2 x i106> [[B_MASK]], <i106 9872, i106 9872>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
235 ; CHECK-NEXT: ret <2 x i1> [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
236 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
237 %B = lshr <2 x i106> %A, <i106 3, i106 3>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
238 %C = icmp eq <2 x i106> %B, <i106 1234, i106 1234>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
239 ret <2 x i1> %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
240 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
241
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
242 define i1 @test18(i11 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
243 ; CHECK-LABEL: @test18(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
244 ; CHECK-NEXT: ret i1 false
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
245 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
246 %B = lshr i11 %A, 10
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
247 %C = icmp eq i11 %B, 123
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
248 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
249 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
250
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
251 define i1 @test19(i37 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
252 ; CHECK-LABEL: @test19(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
253 ; CHECK-NEXT: [[C:%.*]] = icmp ult i37 %A, 4
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
254 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
255 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
256 %B = ashr i37 %A, 2
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
257 %C = icmp eq i37 %B, 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
258 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
259 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
260
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
261 define <2 x i1> @test19vec(<2 x i37> %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
262 ; CHECK-LABEL: @test19vec(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
263 ; CHECK-NEXT: [[C:%.*]] = icmp ult <2 x i37> %A, <i37 4, i37 4>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
264 ; CHECK-NEXT: ret <2 x i1> [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
265 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
266 %B = ashr <2 x i37> %A, <i37 2, i37 2>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
267 %C = icmp eq <2 x i37> %B, zeroinitializer
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
268 ret <2 x i1> %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
269 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
270
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
271 define i1 @test19a(i39 %A) {
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
272 ; CHECK-LABEL: @test19a(
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
273 ; CHECK-NEXT: [[C:%.*]] = icmp ugt i39 %A, -5
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
274 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
275 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
276 %B = ashr i39 %A, 2
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
277 %C = icmp eq i39 %B, -1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
278 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
279 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
280
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
281 define <2 x i1> @test19a_vec(<2 x i39> %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
282 ; CHECK-LABEL: @test19a_vec(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
283 ; CHECK-NEXT: [[C:%.*]] = icmp ugt <2 x i39> %A, <i39 -5, i39 -5>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
284 ; CHECK-NEXT: ret <2 x i1> [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
285 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
286 %B = ashr <2 x i39> %A, <i39 2, i39 2>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
287 %C = icmp eq <2 x i39> %B, <i39 -1, i39 -1>
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
288 ret <2 x i1> %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
289 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
290
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
291 define i1 @test20(i13 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
292 ; CHECK-LABEL: @test20(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
293 ; CHECK-NEXT: ret i1 false
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
294 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
295 %B = ashr i13 %A, 12
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
296 %C = icmp eq i13 %B, 123
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
297 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
298 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
299
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
300 define i1 @test21(i12 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
301 ; CHECK-LABEL: @test21(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
302 ; CHECK-NEXT: [[B_MASK:%.*]] = and i12 %A, 63
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
303 ; CHECK-NEXT: [[C:%.*]] = icmp eq i12 [[B_MASK]], 62
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
304 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
305 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
306 %B = shl i12 %A, 6
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
307 %C = icmp eq i12 %B, -128
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
308 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
309 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
310
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
311 define i1 @test22(i14 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
312 ; CHECK-LABEL: @test22(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
313 ; CHECK-NEXT: [[B_MASK:%.*]] = and i14 %A, 127
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
314 ; CHECK-NEXT: [[C:%.*]] = icmp eq i14 [[B_MASK]], 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
315 ; CHECK-NEXT: ret i1 [[C]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
316 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
317 %B = shl i14 %A, 7
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
318 %C = icmp eq i14 %B, 0
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
319 ret i1 %C
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
320 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
321
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
322 define i11 @test23(i44 %A) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
323 ; CHECK-LABEL: @test23(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
324 ; CHECK-NEXT: [[D:%.*]] = trunc i44 %A to i11
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
325 ; CHECK-NEXT: ret i11 [[D]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
326 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
327 %B = shl i44 %A, 33
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
328 %C = ashr i44 %B, 33
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
329 %D = trunc i44 %C to i11
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
330 ret i11 %D
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
331 }
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
332
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
333 define i37 @test25(i37 %tmp.2, i37 %AA) {
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
334 ; CHECK-LABEL: @test25(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
335 ; CHECK-NEXT: [[TMP_3:%.*]] = and i37 %tmp.2, -131072
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
336 ; CHECK-NEXT: [[X2:%.*]] = add i37 [[TMP_3]], %AA
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
337 ; CHECK-NEXT: [[TMP_6:%.*]] = and i37 [[X2]], -131072
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
338 ; CHECK-NEXT: ret i37 [[TMP_6]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
339 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
340 %x = lshr i37 %AA, 17
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
341 %tmp.3 = lshr i37 %tmp.2, 17
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
342 %tmp.5 = add i37 %tmp.3, %x
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
343 %tmp.6 = shl i37 %tmp.5, 17
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
344 ret i37 %tmp.6
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
345 }
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
346
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
347 define i40 @test26(i40 %A) {
120
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
348 ; CHECK-LABEL: @test26(
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
349 ; CHECK-NEXT: [[B:%.*]] = and i40 %A, -2
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
350 ; CHECK-NEXT: ret i40 [[B]]
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
351 ;
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
352 %B = lshr i40 %A, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
353 %C = bitcast i40 %B to i40
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
354 %D = shl i40 %C, 1
1172e4bd9c6f update 4.0.0
mir3636
parents: 0
diff changeset
355 ret i40 %D
0
95c75e76d11b LLVM 3.4
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff changeset
356 }