Revert r354244 "[DAGCombiner] Eliminate dead stores to stack."
[llvm-complete.git] / test / Transforms / CorrelatedValuePropagation / phi-common-val.ll
blobb761fff0031edc0b0008ca60871851fa97fbcc4c
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -correlated-propagation -S | FileCheck %s
3 ; RUN: opt < %s -passes="correlated-propagation" -S | FileCheck %s
5 define i8* @simplify_phi_common_value_op0(i8* %ptr, i32* %b) {
6 ; CHECK-LABEL: @simplify_phi_common_value_op0(
7 ; CHECK-NEXT:  entry:
8 ; CHECK-NEXT:    [[ISNULL:%.*]] = icmp eq i8* [[PTR:%.*]], null
9 ; CHECK-NEXT:    br i1 [[ISNULL]], label [[RETURN:%.*]], label [[ELSE:%.*]]
10 ; CHECK:       else:
11 ; CHECK-NEXT:    [[LB:%.*]] = load i32, i32* [[B:%.*]]
12 ; CHECK-NEXT:    [[ADD:%.*]] = add nsw i32 [[LB]], 1
13 ; CHECK-NEXT:    store i32 [[ADD]], i32* [[B]]
14 ; CHECK-NEXT:    br label [[RETURN]]
15 ; CHECK:       return:
16 ; CHECK-NEXT:    ret i8* [[PTR]]
18 entry:
19   %isnull = icmp eq i8* %ptr, null
20   br i1 %isnull, label %return, label %else
22 else:
23   %lb = load i32, i32* %b
24   %add = add nsw i32 %lb, 1
25   store i32 %add, i32* %b
26   br label %return
28 return:
29   %r = phi i8* [ %ptr, %else ], [ null, %entry ]
30   ret i8* %r
33 define i8* @simplify_phi_common_value_op1(i8* %ptr, i32* %b) {
34 ; CHECK-LABEL: @simplify_phi_common_value_op1(
35 ; CHECK-NEXT:  entry:
36 ; CHECK-NEXT:    [[ISNULL:%.*]] = icmp eq i8* [[PTR:%.*]], null
37 ; CHECK-NEXT:    br i1 [[ISNULL]], label [[RETURN:%.*]], label [[ELSE:%.*]]
38 ; CHECK:       else:
39 ; CHECK-NEXT:    [[LB:%.*]] = load i32, i32* [[B:%.*]]
40 ; CHECK-NEXT:    [[ADD:%.*]] = add i32 [[LB]], 1
41 ; CHECK-NEXT:    store i32 [[ADD]], i32* [[B]]
42 ; CHECK-NEXT:    br label [[RETURN]]
43 ; CHECK:       return:
44 ; CHECK-NEXT:    ret i8* [[PTR]]
46 entry:
47   %isnull = icmp eq i8* %ptr, null
48   br i1 %isnull, label %return, label %else
50 else:
51   %lb = load i32, i32* %b
52   %add = add i32 %lb, 1
53   store i32 %add, i32* %b
54   br label %return
56 return:
57   %r = phi i8* [ null, %entry], [ %ptr, %else ]
58   ret i8* %r
61 define i8 @simplify_phi_multiple_constants(i8 %x, i32* %b) {
62 ; CHECK-LABEL: @simplify_phi_multiple_constants(
63 ; CHECK-NEXT:  entry:
64 ; CHECK-NEXT:    [[IS0:%.*]] = icmp eq i8 [[X:%.*]], 0
65 ; CHECK-NEXT:    br i1 [[IS0]], label [[RETURN:%.*]], label [[ELSE1:%.*]]
66 ; CHECK:       else1:
67 ; CHECK-NEXT:    [[IS42:%.*]] = icmp eq i8 [[X]], 42
68 ; CHECK-NEXT:    br i1 [[IS42]], label [[RETURN]], label [[ELSE2:%.*]]
69 ; CHECK:       else2:
70 ; CHECK-NEXT:    [[LB:%.*]] = load i32, i32* [[B:%.*]]
71 ; CHECK-NEXT:    [[ADD:%.*]] = add i32 [[LB]], 1
72 ; CHECK-NEXT:    store i32 [[ADD]], i32* [[B]]
73 ; CHECK-NEXT:    br label [[RETURN]]
74 ; CHECK:       return:
75 ; CHECK-NEXT:    ret i8 [[X]]
77 entry:
78   %is0 = icmp eq i8 %x, 0
79   br i1 %is0, label %return, label %else1
81 else1:
82   %is42 = icmp eq i8 %x, 42
83   br i1 %is42, label %return, label %else2
85 else2:
86   %lb = load i32, i32* %b
87   %add = add i32 %lb, 1
88   store i32 %add, i32* %b
89   br label %return
91 return:
92   %r = phi i8 [ 0, %entry], [ %x, %else2 ], [ 42, %else1 ]
93   ret i8 %r
96 define i8* @simplify_phi_common_value_from_instruction(i8* %ptr_op, i32* %b, i32 %i) {
97 ; CHECK-LABEL: @simplify_phi_common_value_from_instruction(
98 ; CHECK-NEXT:  entry:
99 ; CHECK-NEXT:    [[PTR:%.*]] = getelementptr i8, i8* [[PTR_OP:%.*]], i32 [[I:%.*]]
100 ; CHECK-NEXT:    [[ISNULL:%.*]] = icmp eq i8* [[PTR]], null
101 ; CHECK-NEXT:    br i1 [[ISNULL]], label [[RETURN:%.*]], label [[ELSE:%.*]]
102 ; CHECK:       else:
103 ; CHECK-NEXT:    [[LB:%.*]] = load i32, i32* [[B:%.*]]
104 ; CHECK-NEXT:    [[ADD:%.*]] = add nsw i32 [[LB]], 1
105 ; CHECK-NEXT:    store i32 [[ADD]], i32* [[B]]
106 ; CHECK-NEXT:    br label [[RETURN]]
107 ; CHECK:       return:
108 ; CHECK-NEXT:    ret i8* [[PTR]]
110 entry:
111   %ptr = getelementptr i8, i8* %ptr_op, i32 %i
112   %isnull = icmp eq i8* %ptr, null
113   br i1 %isnull, label %return, label %else
115 else:
116   %lb = load i32, i32* %b
117   %add = add nsw i32 %lb, 1
118   store i32 %add, i32* %b
119   br label %return
121 return:
122   %r = phi i8* [ %ptr, %else ], [ null, %entry ]
123   ret i8* %r