[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / Transforms / NewGVN / pr32838.ll
blobb6b7b0d19b867f39ac76a3a2f33374e9c82c077e
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ;RUN: opt -newgvn -S < %s | FileCheck %s
3 target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
4 target triple = "x86_64-apple-macosx10.12.0"
5 ;; Ensure we don't infinite loop when all phi arguments are really unreachable or self-defined
6 define void @fn1(i64 %arg) {
7 ; CHECK-LABEL: @fn1(
8 ; CHECK-NEXT:  entry:
9 ; CHECK-NEXT:    br i1 undef, label [[IF_THEN:%.*]], label [[COND_TRUE:%.*]]
10 ; CHECK:       if.then:
11 ; CHECK-NEXT:    br i1 false, label [[FIRSTPHIBLOCK:%.*]], label [[TEMP:%.*]]
12 ; CHECK:       firstphiblock:
13 ; CHECK-NEXT:    br i1 undef, label %for.cond17thread-pre-split, label [[SECONDPHIBLOCK:%.*]]
14 ; CHECK:       secondphiblock:
15 ; CHECK-NEXT:    [[SECONDPHI:%.*]] = phi i64 [ [[THIRDPHI:%.*]], [[THIRDPHIBLOCK:%.*]] ], [ undef, [[FIRSTPHIBLOCK]] ]
16 ; CHECK-NEXT:    br i1 undef, label [[FIRSTPHIBLOCK]], label [[THIRDPHIBLOCK]]
17 ; CHECK:       thirdphiblock:
18 ; CHECK-NEXT:    [[THIRDPHI]] = phi i64 [ [[SECONDPHI]], [[SECONDPHIBLOCK]] ], [ [[DIV:%.*]], [[COND_TRUE]] ]
19 ; CHECK-NEXT:    br label [[SECONDPHIBLOCK]]
20 ; CHECK:       for.cond17thread-pre-split:
21 ; CHECK-NEXT:    br label [[COND_TRUE]]
22 ; CHECK:       cond.true:
23 ; CHECK-NEXT:    [[DIV]] = sdiv i64 [[ARG:%.*]], 4
24 ; CHECK-NEXT:    br label [[THIRDPHIBLOCK]]
25 ; CHECK:       temp:
26 ; CHECK-NEXT:    ret void
28 entry:
29   br i1 undef, label %if.then, label %cond.true
30 if.then:
31   br i1 false, label %firstphiblock, label %temp
32 firstphiblock:
33   %firstphi = phi i64 [ %arg, %if.then ], [ undef, %secondphiblock ]
34   br i1 undef, label %for.cond17thread-pre-split, label %secondphiblock
35 secondphiblock:
36   %secondphi = phi i64 [ %thirdphi, %thirdphiblock ], [ %firstphi, %firstphiblock ]
37   br i1 undef, label %firstphiblock, label %thirdphiblock
38 thirdphiblock:
39   %thirdphi = phi i64 [ %secondphi, %secondphiblock ], [ %div, %cond.true ]
40   br label %secondphiblock
41 for.cond17thread-pre-split:
42   br label %cond.true
43 cond.true:
44   %fourthphi = phi i64 [ %arg, %entry ], [ %firstphi, %for.cond17thread-pre-split ]
45   %div = sdiv i64 %fourthphi, 4
46   br label %thirdphiblock
47 temp:
48   ret void
50 define void @fn2(i64 %arg) {
51 ; CHECK-LABEL: @fn2(
52 ; CHECK-NEXT:  entry:
53 ; CHECK-NEXT:    br i1 undef, label [[IF_THEN:%.*]], label [[COND_TRUE:%.*]]
54 ; CHECK:       if.then:
55 ; CHECK-NEXT:    br i1 false, label [[FIRSTPHIBLOCK:%.*]], label [[TEMP:%.*]]
56 ; CHECK:       firstphiblock:
57 ; CHECK-NEXT:    [[FIRSTPHI:%.*]] = phi i64 [ undef, [[IF_THEN]] ], [ [[SECONDPHI:%.*]], [[SECONDPHIBLOCK:%.*]] ]
58 ; CHECK-NEXT:    br i1 undef, label %for.cond17thread-pre-split, label [[SECONDPHIBLOCK]]
59 ; CHECK:       secondphiblock:
60 ; CHECK-NEXT:    [[SECONDPHI]] = phi i64 [ [[THIRDPHI:%.*]], [[THIRDPHIBLOCK:%.*]] ], [ [[FIRSTPHI]], [[FIRSTPHIBLOCK]] ]
61 ; CHECK-NEXT:    br i1 undef, label [[FIRSTPHIBLOCK]], label [[THIRDPHIBLOCK]]
62 ; CHECK:       thirdphiblock:
63 ; CHECK-NEXT:    [[THIRDPHI]] = phi i64 [ [[SECONDPHI]], [[SECONDPHIBLOCK]] ], [ [[DIV:%.*]], [[COND_TRUE]] ]
64 ; CHECK-NEXT:    br label [[SECONDPHIBLOCK]]
65 ; CHECK:       for.cond17thread-pre-split:
66 ; CHECK-NEXT:    br label [[COND_TRUE]]
67 ; CHECK:       cond.true:
68 ; CHECK-NEXT:    [[FOURTHPHI:%.*]] = phi i64 [ [[ARG:%.*]], [[ENTRY:%.*]] ], [ [[FIRSTPHI]], %for.cond17thread-pre-split ]
69 ; CHECK-NEXT:    [[DIV]] = sdiv i64 [[FOURTHPHI]], 4
70 ; CHECK-NEXT:    br label [[THIRDPHIBLOCK]]
71 ; CHECK:       temp:
72 ; CHECK-NEXT:    ret void
74 entry:
75   br i1 undef, label %if.then, label %cond.true
76 if.then:
77   br i1 false, label %firstphiblock, label %temp
78 firstphiblock:
79   %firstphi = phi i64 [ %arg, %if.then ], [ %secondphi, %secondphiblock ]
80   br i1 undef, label %for.cond17thread-pre-split, label %secondphiblock
81 secondphiblock:
82   %secondphi = phi i64 [ %thirdphi, %thirdphiblock ], [ %firstphi, %firstphiblock ]
83   br i1 undef, label %firstphiblock, label %thirdphiblock
84 thirdphiblock:
85   %thirdphi = phi i64 [ %secondphi, %secondphiblock ], [ %div, %cond.true ]
86   br label %secondphiblock
87 for.cond17thread-pre-split:
88   br label %cond.true
89 cond.true:
90   %fourthphi = phi i64 [ %arg, %entry ], [ %firstphi, %for.cond17thread-pre-split ]
91   %div = sdiv i64 %fourthphi, 4
92   br label %thirdphiblock
93 temp:
94   ret void
96 @b = external global i32, align 4
97 @a = external global i32, align 4
98 define void @fn3() {
99 ; CHECK-LABEL: @fn3(
100 ; CHECK-NEXT:  entry:
101 ; CHECK-NEXT:    br label [[L1:%.*]]
102 ; CHECK:       l1.loopexit:
103 ; CHECK-NEXT:    br label [[L1]]
104 ; CHECK:       l1:
105 ; CHECK-NEXT:    [[F_0:%.*]] = phi i32* [ @b, [[ENTRY:%.*]] ], [ @a, [[L1_LOOPEXIT:%.*]] ]
106 ; CHECK-NEXT:    br label [[FOR_COND:%.*]]
107 ; CHECK:       for.cond.loopexit:
108 ; CHECK-NEXT:    store i8 undef, i8* null
109 ; CHECK-NEXT:    br label [[FOR_COND]]
110 ; CHECK:       for.cond:
111 ; CHECK-NEXT:    br i1 undef, label [[FOR_END14:%.*]], label [[FOR_COND1_PREHEADER:%.*]]
112 ; CHECK:       for.cond1.preheader:
113 ; CHECK-NEXT:    br label [[FOR_BODY3:%.*]]
114 ; CHECK:       for.cond1:
115 ; CHECK-NEXT:    br label [[L2:%.*]]
116 ; CHECK:       for.body3:
117 ; CHECK-NEXT:    br i1 undef, label [[FOR_COND1:%.*]], label [[L1_LOOPEXIT]]
118 ; CHECK:       l2:
119 ; CHECK-NEXT:    [[G_4:%.*]] = phi i32* [ @b, [[FOR_END14]] ], [ @a, [[FOR_COND1]] ]
120 ; CHECK-NEXT:    [[F_2:%.*]] = phi i32* [ [[F_0]], [[FOR_END14]] ], [ @a, [[FOR_COND1]] ]
121 ; CHECK-NEXT:    br label [[FOR_INC:%.*]]
122 ; CHECK:       for.inc:
123 ; CHECK-NEXT:    br i1 false, label [[FOR_COND_LOOPEXIT:%.*]], label [[FOR_INC]]
124 ; CHECK:       for.end14:
125 ; CHECK-NEXT:    br label [[L2]]
127 entry:
128   br label %l1
129 l1.loopexit:
130   %g.223.lcssa = phi i32* [ @b, %for.body3 ]
131   br label %l1
133   %g.0 = phi i32* [ undef, %entry ], [ %g.223.lcssa, %l1.loopexit ]
134   %f.0 = phi i32* [ @b, %entry ], [ @a, %l1.loopexit ]
135   br label %for.cond
136 for.cond.loopexit:
137   br label %for.cond
138 for.cond:
139   %g.1 = phi i32* [ %g.0, %l1 ], [ %g.4, %for.cond.loopexit ]
140   %f.1 = phi i32* [ %f.0, %l1 ], [ %f.2, %for.cond.loopexit ]
141   br i1 undef, label %for.end14, label %for.cond1.preheader
142 for.cond1.preheader:
143   br label %for.body3
144 for.cond1:
145   br label %l2
146 for.body3:
147   br i1 undef, label %for.cond1, label %l1.loopexit
149   %g.4 = phi i32* [ %g.1, %for.end14 ], [ @a, %for.cond1 ]
150   %f.2 = phi i32* [ %f.1, %for.end14 ], [ @a, %for.cond1 ]
151   br label %for.inc
152 for.inc:
153   br i1 false, label %for.cond.loopexit, label %for.inc
154 for.end14:
155   br label %l2