xref: /aosp_15_r20/external/llvm/test/Transforms/EarlyCSE/conditional.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: opt -early-cse -S < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; Can we CSE a known condition to a constant?
4*9880d681SAndroid Build Coastguard Workerdefine i1 @test(i8* %p) {
5*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test
6*9880d681SAndroid Build Coastguard Workerentry:
7*9880d681SAndroid Build Coastguard Worker  %cnd1 = icmp eq i8* %p, null
8*9880d681SAndroid Build Coastguard Worker  br i1 %cnd1, label %taken, label %untaken
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workertaken:
11*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: taken:
12*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i1 true
13*9880d681SAndroid Build Coastguard Worker  %cnd2 = icmp eq i8* %p, null
14*9880d681SAndroid Build Coastguard Worker  ret i1 %cnd2
15*9880d681SAndroid Build Coastguard Worker
16*9880d681SAndroid Build Coastguard Workeruntaken:
17*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: untaken:
18*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i1 false
19*9880d681SAndroid Build Coastguard Worker  %cnd3 = icmp eq i8* %p, null
20*9880d681SAndroid Build Coastguard Worker  ret i1 %cnd3
21*9880d681SAndroid Build Coastguard Worker}
22*9880d681SAndroid Build Coastguard Worker
23*9880d681SAndroid Build Coastguard Worker; We can CSE the condition, but we *don't* know it's value after the merge
24*9880d681SAndroid Build Coastguard Workerdefine i1 @test_neg1(i8* %p) {
25*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test_neg1
26*9880d681SAndroid Build Coastguard Workerentry:
27*9880d681SAndroid Build Coastguard Worker  %cnd1 = icmp eq i8* %p, null
28*9880d681SAndroid Build Coastguard Worker  br i1 %cnd1, label %taken, label %untaken
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Workertaken:
31*9880d681SAndroid Build Coastguard Worker  br label %merge
32*9880d681SAndroid Build Coastguard Worker
33*9880d681SAndroid Build Coastguard Workeruntaken:
34*9880d681SAndroid Build Coastguard Worker  br label %merge
35*9880d681SAndroid Build Coastguard Worker
36*9880d681SAndroid Build Coastguard Workermerge:
37*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: merge:
38*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i1 %cnd1
39*9880d681SAndroid Build Coastguard Worker  %cnd3 = icmp eq i8* %p, null
40*9880d681SAndroid Build Coastguard Worker  ret i1 %cnd3
41*9880d681SAndroid Build Coastguard Worker}
42*9880d681SAndroid Build Coastguard Worker
43*9880d681SAndroid Build Coastguard Worker; Check specifically for a case where we have a unique predecessor, but
44*9880d681SAndroid Build Coastguard Worker; not a single predecessor.  We can not know the value of the condition here.
45*9880d681SAndroid Build Coastguard Workerdefine i1 @test_neg2(i8* %p) {
46*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test_neg2
47*9880d681SAndroid Build Coastguard Workerentry:
48*9880d681SAndroid Build Coastguard Worker  %cnd1 = icmp eq i8* %p, null
49*9880d681SAndroid Build Coastguard Worker  br i1 %cnd1, label %merge, label %merge
50*9880d681SAndroid Build Coastguard Worker
51*9880d681SAndroid Build Coastguard Workermerge:
52*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: merge:
53*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i1 %cnd1
54*9880d681SAndroid Build Coastguard Worker  %cnd3 = icmp eq i8* %p, null
55*9880d681SAndroid Build Coastguard Worker  ret i1 %cnd3
56*9880d681SAndroid Build Coastguard Worker}
57*9880d681SAndroid Build Coastguard Worker
58*9880d681SAndroid Build Coastguard Worker; Replace a use rather than CSE
59*9880d681SAndroid Build Coastguard Workerdefine i1 @test2(i8* %p) {
60*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test2
61*9880d681SAndroid Build Coastguard Workerentry:
62*9880d681SAndroid Build Coastguard Worker  %cnd = icmp eq i8* %p, null
63*9880d681SAndroid Build Coastguard Worker  br i1 %cnd, label %taken, label %untaken
64*9880d681SAndroid Build Coastguard Worker
65*9880d681SAndroid Build Coastguard Workertaken:
66*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: taken:
67*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i1 true
68*9880d681SAndroid Build Coastguard Worker  ret i1 %cnd
69*9880d681SAndroid Build Coastguard Worker
70*9880d681SAndroid Build Coastguard Workeruntaken:
71*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: untaken:
72*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i1 false
73*9880d681SAndroid Build Coastguard Worker  ret i1 %cnd
74*9880d681SAndroid Build Coastguard Worker}
75*9880d681SAndroid Build Coastguard Worker
76*9880d681SAndroid Build Coastguard Worker; Not legal to replace use given it's not dominated by edge
77*9880d681SAndroid Build Coastguard Workerdefine i1 @test2_neg1(i8* %p) {
78*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test2_neg1
79*9880d681SAndroid Build Coastguard Workerentry:
80*9880d681SAndroid Build Coastguard Worker  %cnd1 = icmp eq i8* %p, null
81*9880d681SAndroid Build Coastguard Worker  br i1 %cnd1, label %taken, label %untaken
82*9880d681SAndroid Build Coastguard Worker
83*9880d681SAndroid Build Coastguard Workertaken:
84*9880d681SAndroid Build Coastguard Worker  br label %merge
85*9880d681SAndroid Build Coastguard Worker
86*9880d681SAndroid Build Coastguard Workeruntaken:
87*9880d681SAndroid Build Coastguard Worker  br label %merge
88*9880d681SAndroid Build Coastguard Worker
89*9880d681SAndroid Build Coastguard Workermerge:
90*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: merge:
91*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i1 %cnd1
92*9880d681SAndroid Build Coastguard Worker  ret i1 %cnd1
93*9880d681SAndroid Build Coastguard Worker}
94*9880d681SAndroid Build Coastguard Worker
95*9880d681SAndroid Build Coastguard Worker; Another single predecessor test, but for dominated use
96*9880d681SAndroid Build Coastguard Workerdefine i1 @test2_neg2(i8* %p) {
97*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test2_neg2
98*9880d681SAndroid Build Coastguard Workerentry:
99*9880d681SAndroid Build Coastguard Worker  %cnd1 = icmp eq i8* %p, null
100*9880d681SAndroid Build Coastguard Worker  br i1 %cnd1, label %merge, label %merge
101*9880d681SAndroid Build Coastguard Worker
102*9880d681SAndroid Build Coastguard Workermerge:
103*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: merge:
104*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i1 %cnd1
105*9880d681SAndroid Build Coastguard Worker  ret i1 %cnd1
106*9880d681SAndroid Build Coastguard Worker}
107*9880d681SAndroid Build Coastguard Worker
108