Skip to content

Commit 306dd28

Browse files
committed
Port test from #138373
1 parent 911b97e commit 306dd28

File tree

1 file changed

+169
-0
lines changed

1 file changed

+169
-0
lines changed
Lines changed: 169 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,169 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2+
; RUN: opt < %s -passes=instcombine -S | FileCheck %s
3+
4+
; Basic functional test
5+
define i32 @basic(i32 %a, i32 %b) {
6+
; CHECK-LABEL: @basic(
7+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[A:%.*]], 0
8+
; CHECK-NEXT: [[RES:%.*]] = select i1 [[CMP]], i32 [[B:%.*]], i32 [[A]]
9+
; CHECK-NEXT: ret i32 [[RES]]
10+
;
11+
%cmp = icmp eq i32 %a, 0
12+
%sel = select i1 %cmp, i32 %b, i32 0
13+
%or = or i32 %sel, %a
14+
ret i32 %or
15+
}
16+
17+
; Operand order swap test
18+
define i32 @swap_operand_order(i32 %x, i32 %y) {
19+
; CHECK-LABEL: @swap_operand_order(
20+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[X:%.*]], 0
21+
; CHECK-NEXT: [[SEL:%.*]] = select i1 [[CMP]], i32 [[Y:%.*]], i32 0
22+
; CHECK-NEXT: [[RES:%.*]] = or i32 [[X]], [[SEL]]
23+
; CHECK-NEXT: ret i32 [[RES]]
24+
;
25+
%cmp = icmp eq i32 %x, 0
26+
%sel = select i1 %cmp, i32 %y, i32 0
27+
%or = or i32 %x, %sel
28+
ret i32 %or
29+
}
30+
31+
; Negative test: Non-zero false value in select
32+
define i32 @negative_non_zero_false_val(i32 %a, i32 %b) {
33+
; CHECK-LABEL: @negative_non_zero_false_val(
34+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[A:%.*]], 0
35+
; CHECK-NEXT: [[SEL:%.*]] = select i1 [[CMP]], i32 [[B:%.*]], i32 1
36+
; CHECK-NEXT: [[OR:%.*]] = or i32 [[SEL]], [[A]]
37+
; CHECK-NEXT: ret i32 [[OR]]
38+
;
39+
%cmp = icmp eq i32 %a, 0
40+
%sel = select i1 %cmp, i32 %b, i32 1
41+
%or = or i32 %sel, %a
42+
ret i32 %or
43+
}
44+
45+
; Negative test: Incorrect comparison predicate (NE)
46+
define i32 @negative_wrong_predicate(i32 %a, i32 %b) {
47+
; CHECK-LABEL: @negative_wrong_predicate(
48+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[A:%.*]], 0
49+
; CHECK-NEXT: [[OR:%.*]] = select i1 [[CMP]], i32 0, i32 [[TMP1:%.*]]
50+
; CHECK-NEXT: [[OR1:%.*]] = or i32 [[OR]], [[A]]
51+
; CHECK-NEXT: ret i32 [[OR1]]
52+
;
53+
%cmp = icmp ne i32 %a, 0
54+
%sel = select i1 %cmp, i32 %b, i32 0
55+
%or = or i32 %sel, %a
56+
ret i32 %or
57+
}
58+
59+
; Comparison direction swap test (0 == X)
60+
define i32 @cmp_swapped(i32 %x, i32 %y) {
61+
; CHECK-LABEL: @cmp_swapped(
62+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[X:%.*]], 0
63+
; CHECK-NEXT: [[SEL:%.*]] = select i1 [[CMP]], i32 [[Y:%.*]], i32 0
64+
; CHECK-NEXT: [[RES:%.*]] = or i32 [[X]], [[SEL]]
65+
; CHECK-NEXT: ret i32 [[RES]]
66+
;
67+
%cmp = icmp eq i32 0, %x
68+
%sel = select i1 %cmp, i32 %y, i32 0
69+
%or = or i32 %x, %sel
70+
ret i32 %or
71+
}
72+
73+
; Complex expression test
74+
define i32 @complex_expression(i32 %a, i32 %b) {
75+
; CHECK-LABEL: @complex_expression(
76+
; CHECK-NEXT: [[X:%.*]] = add i32 [[A:%.*]], 1
77+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[X]], 0
78+
; CHECK-NEXT: [[RES:%.*]] = select i1 [[CMP]], i32 [[B:%.*]], i32 [[X]]
79+
; CHECK-NEXT: ret i32 [[RES]]
80+
;
81+
%x = add i32 %a, 1
82+
%cmp = icmp eq i32 %x, 0
83+
%sel = select i1 %cmp, i32 %b, i32 0
84+
%or = or i32 %sel, %x
85+
ret i32 %or
86+
}
87+
88+
; zext test
89+
define i32 @zext_cond(i8 %a, i32 %b) {
90+
; CHECK-LABEL: @zext_cond(
91+
; CHECK-NEXT: [[Z:%.*]] = zext i8 [[A:%.*]] to i32
92+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i8 [[A]], 0
93+
; CHECK-NEXT: [[SEL:%.*]] = select i1 [[CMP]], i32 [[B:%.*]], i32 0
94+
; CHECK-NEXT: [[OR:%.*]] = or i32 [[SEL]], [[Z]]
95+
; CHECK-NEXT: ret i32 [[OR]]
96+
;
97+
%z = zext i8 %a to i32
98+
%cmp = icmp eq i8 %a, 0
99+
%sel = select i1 %cmp, i32 %b, i32 0
100+
%or = or i32 %sel, %z
101+
ret i32 %or
102+
}
103+
104+
; sext test
105+
define i32 @sext_cond(i8 %a, i32 %b) {
106+
; CHECK-LABEL: @sext_cond(
107+
; CHECK-NEXT: [[S:%.*]] = sext i8 [[A:%.*]] to i32
108+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i8 [[A]], 0
109+
; CHECK-NEXT: [[SEL:%.*]] = select i1 [[CMP]], i32 [[B:%.*]], i32 0
110+
; CHECK-NEXT: [[OR:%.*]] = or i32 [[SEL]], [[S]]
111+
; CHECK-NEXT: ret i32 [[OR]]
112+
;
113+
%s = sext i8 %a to i32
114+
%cmp = icmp eq i8 %a, 0
115+
%sel = select i1 %cmp, i32 %b, i32 0
116+
%or = or i32 %sel, %s
117+
ret i32 %or
118+
}
119+
120+
; Vector type test
121+
define <2 x i32> @vector_type(<2 x i32> %a, <2 x i32> %b) {
122+
; CHECK-LABEL: @vector_type(
123+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq <2 x i32> [[A:%.*]], zeroinitializer
124+
; CHECK-NEXT: [[RES:%.*]] = select <2 x i1> [[CMP]], <2 x i32> [[B:%.*]], <2 x i32> [[A]]
125+
; CHECK-NEXT: ret <2 x i32> [[RES]]
126+
;
127+
%cmp = icmp eq <2 x i32> %a, zeroinitializer
128+
%sel = select <2 x i1> %cmp, <2 x i32> %b, <2 x i32> zeroinitializer
129+
%or = or <2 x i32> %sel, %a
130+
ret <2 x i32> %or
131+
}
132+
133+
; Pointer type test (should not trigger optimization)
134+
define ptr @pointer_type(ptr %p, ptr %q) {
135+
; CHECK-LABEL: @pointer_type(
136+
; CHECK-NEXT: [[A:%.*]] = ptrtoint ptr [[P:%.*]] to i64
137+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq ptr [[P]], null
138+
; CHECK-NEXT: [[SEL:%.*]] = select i1 [[CMP]], ptr [[Q:%.*]], ptr null
139+
; CHECK-NEXT: [[SEL_INT:%.*]] = ptrtoint ptr [[SEL]] to i64
140+
; CHECK-NEXT: [[OR:%.*]] = or i64 [[A]], [[SEL_INT]]
141+
; CHECK-NEXT: [[RET:%.*]] = inttoptr i64 [[OR]] to ptr
142+
; CHECK-NEXT: ret ptr [[RET]]
143+
;
144+
%a = ptrtoint ptr %p to i64
145+
%cmp = icmp eq i64 %a, 0
146+
%sel = select i1 %cmp, ptr %q, ptr null
147+
%sel_int = ptrtoint ptr %sel to i64
148+
%or_val = or i64 %a, %sel_int
149+
%ret = inttoptr i64 %or_val to ptr
150+
ret ptr %ret
151+
}
152+
153+
; Multi-use test (should not trigger optimization)
154+
define i32 @multi_use_test(i32 %x, i32 %m) {
155+
; CHECK-LABEL: @multi_use_test(
156+
; CHECK-NEXT: [[CMP:%.*]] = icmp eq i32 [[X:%.*]], 0
157+
; CHECK-NEXT: [[SEL:%.*]] = select i1 [[CMP]], i32 [[M:%.*]], i32 0
158+
; CHECK-NEXT: [[OR:%.*]] = or i32 [[SEL]], [[X]]
159+
; CHECK-NEXT: [[ADD:%.*]] = add i32 [[SEL]], [[X]]
160+
; CHECK-NEXT: [[O2:%.*]] = sub i32 [[OR]], [[ADD]]
161+
; CHECK-NEXT: ret i32 [[O2]]
162+
;
163+
%cmp = icmp eq i32 %x, 0
164+
%sel = select i1 %cmp, i32 %m, i32 0
165+
%or = or i32 %sel, %x
166+
%add = add i32 %sel, %x
167+
%res = sub i32 %or, %add
168+
ret i32 %res
169+
}

0 commit comments

Comments
 (0)