[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / Transforms / GVN / PRE / local-pre.ll
blob22d9b506644b11c25fcf625d069de42e391e1281
1 ; RUN: opt < %s -gvn -enable-pre -S | FileCheck %s
3 declare void @may_exit() nounwind
5 declare void @may_exit_1(i32) nounwind
7 define i32 @main(i32 %p, i32 %q) {
9 ; CHECK-LABEL: @main(
11 block1:
12     %cmp = icmp eq i32 %p, %q 
13         br i1 %cmp, label %block2, label %block3
15 block2:
16  %a = add i32 %p, 1
17  br label %block4
19 block3:
20   br label %block4
21 ; CHECK: %.pre = add i32 %p, 1
22 ; CHECK-NEXT: br label %block4
24 block4:
25   %b = add i32 %p, 1
26   ret i32 %b
27 ; CHECK: %b.pre-phi = phi i32 [ %.pre, %block3 ], [ %a, %block2 ]
28 ; CHECK-NEXT: ret i32 %b.pre-phi
31 ; Don't PRE across implicit control flow.
32 define i32 @test2(i32 %p, i32 %q) {
34 ; CHECK-LABEL: @test2
35 ; CHECK: block1:
37 block1:
38   %cmp = icmp eq i32 %p, %q
39   br i1 %cmp, label %block2, label %block3
41 block2:
42  %a = sdiv i32 %p, %q
43  br label %block4
45 block3:
46   br label %block4
48 ; CHECK: block4:
49 ; CHECK-NEXT: call void @may_exit(
50 ; CHECK-NEXT: %b = sdiv
51 ; CHECK-NEXT: ret i32 %b
53 block4:
54   call void @may_exit() nounwind
55   %b = sdiv i32 %p, %q
56   ret i32 %b
59 ; Don't PRE across implicit control flow.
60 define i32 @test3(i32 %p, i32 %q, i1 %r) {
62 ; CHECK-LABEL: @test3
63 ; CHECK: block1:
65 block1:
66   br i1 %r, label %block2, label %block3
68 block2:
69  %a = sdiv i32 %p, %q
70  br label %block4
72 block3:
73   br label %block4
75 block4:
77 ; CHECK: block4:
78 ; CHECK-NEXT: phi i32
79 ; CHECK-NEXT: call void @may_exit_1(
80 ; CHECK-NEXT: %b = sdiv
81 ; CHECK-NEXT: ret i32 %b
83   %phi = phi i32 [ 0, %block3 ], [ %a, %block2 ]
84   call void @may_exit_1(i32 %phi) nounwind
85   %b = sdiv i32 %p, %q
86   ret i32 %b
90 ; It's OK to PRE an instruction that is guaranteed to be safe to execute
91 ; speculatively.
92 ; TODO: Does it make any sense in this case?
93 define i32 @test4(i32 %p, i32 %q) {
95 ; CHECK-LABEL: @test4
96 ; CHECK: block1:
98 block1:
99   %cmp = icmp eq i32 %p, %q
100   br i1 %cmp, label %block2, label %block3
102 block2:
103  %a = sdiv i32 %p, 6
104  br label %block4
106 block3:
107   br label %block4
109 ; CHECK: block4:
110 ; CHECK-NEXT: %b.pre-phi = phi i32
111 ; CHECK-NEXT: call void @may_exit(
112 ; CHECK-NEXT: ret i32 %b
114 block4:
115   call void @may_exit() nounwind
116   %b = sdiv i32 %p, 6
117   ret i32 %b
120 ; It is OK to PRE across implicit control flow if we don't insert new
121 ; instructions.
122 define i32 @test5(i1 %cond, i32 %p, i32 %q) {
124 ; CHECK-LABEL: @test5
125 ; CHECK: block1:
127 block1:
128   br i1 %cond, label %block2, label %block3
130 block2:
131  %a = sdiv i32 %p, %q
132  br label %block4
134 block3:
135   %b = sdiv i32 %p, %q
136   br label %block4
138 ; CHECK: block4:
139 ; CHECK-NEXT: %c.pre-phi = phi i32 [ %b, %block3 ], [ %a, %block2 ]
140 ; CHECK-NEXT: call void @may_exit()
141 ; CHECK-NEXT: ret i32 %c.pre-phi
143 block4:
144   call void @may_exit() nounwind
145   %c = sdiv i32 %p, %q
146   ret i32 %c