[InstCombine] Signed saturation tests. NFC
[llvm-complete.git] / test / Transforms / LoopSimplify / pr28272.ll
blobd4025dbd44c52ac0f897c3f5f4053e86381f3d06
1 ; RUN: opt < %s -lcssa -loop-simplify -indvars -S | FileCheck %s
2 target triple = "x86_64-unknown-linux-gnu"
4 ; PR28272, PR28825
5 ; When LoopSimplify separates nested loops, it might break LCSSA form: values
6 ; from the original loop might be used in the outer loop. This test invokes
7 ; loop-unroll, which calls loop-simplify before itself. If LCSSA is broken
8 ; after loop-simplify, we crash on assertion.
10 ; CHECK-LABEL: @foo
11 define void @foo() {
12 entry:
13   br label %header
15 header:
16   br label %loop1
18 loop1:
19   br i1 true, label %loop1, label %bb43
21 bb43:
22   %a = phi i32 [ undef, %loop1 ], [ 0, %bb45 ], [ %a, %bb54 ]
23   %b = phi i32 [ 0, %loop1 ], [ 1, %bb54 ], [ %c, %bb45 ]
24   br i1 true, label %bb114, label %header
26 bb114:
27   %c = add i32 0, 1
28   %d = add i32 0, 1
29   br i1 true, label %bb45, label %bb54
31 bb45:
32   %x = add i32 %d, 0
33   br label %bb43
35 bb54:
36   br label %bb43
39 ; CHECK-LABEL: @foo2
40 define void @foo2() {
41 entry:
42   br label %outer
44 outer.loopexit:
45   br label %outer
47 outer:
48   br label %loop1
50 loop1:
51   br i1 true, label %loop1, label %loop2.preheader
53 loop2.preheader:
54   %a.ph = phi i32 [ undef, %loop1 ]
55   %b.ph = phi i32 [ 0, %loop1 ]
56   br label %loop2
58 loop2:
59   %a = phi i32 [ 0, %loop2.if.true ], [ %a, %loop2.if.false ], [ %a.ph, %loop2.preheader ], [0, %bb]
60   %b = phi i32 [ 1, %loop2.if.false ], [ %c, %loop2.if.true ], [ %b.ph, %loop2.preheader ], [%c, %bb]
61   br i1 true, label %loop2.if, label %outer.loopexit
63 loop2.if:
64   %c = add i32 0, 1
65   switch i32 undef, label %loop2.if.false [i32 0, label %loop2.if.true
66                                        i32 1, label %bb]
68 loop2.if.true:
69   br i1 undef, label %loop2, label %bb
71 loop2.if.false:
72   br label %loop2
74 bb:
75   br label %loop2
78 ; When LoopSimplify separates nested loops, it might break LCSSA form: values
79 ; from the original loop might be used in exit blocks of the outer loop.
80 ; CHECK-LABEL: @foo3
81 define void @foo3() {
82 entry:
83   br label %bb1
85 bb1:
86   br i1 undef, label %bb2, label %bb1
88 bb2:
89   %a = phi i32 [ undef, %bb1 ], [ %a, %bb3 ], [ undef, %bb5 ]
90   br i1 undef, label %bb3, label %bb1
92 bb3:
93   %b = load i32*, i32** undef
94   br i1 undef, label %bb2, label %bb4
96 bb4:
97   br i1 undef, label %bb5, label %bb6
99 bb5:
100   br i1 undef, label %bb2, label %bb4
102 bb6:
103   br i1 undef, label %bb_end, label %bb1
105 bb_end:
106   %x = getelementptr i32, i32* %b
107   br label %bb_end
110 ; When LoopSimplify separates nested loops, it might break LCSSA form: values
111 ; from the original loop might occur in a loop, which is now a sibling of the
112 ; original loop (before separating it was a subloop of the original loop, and
113 ; thus didn't require an lcssa phi nodes).
114 ; CHECK-LABEL: @foo4
115 define void @foo4() {
116 bb1:
117   br label %bb2
119 ; CHECK: bb2.loopexit:
120 bb2.loopexit:                                     ; preds = %bb3
121   %i.ph = phi i32 [ 0, %bb3 ]
122   br label %bb2
124 ; CHECK: bb2.outer:
125 ; CHECK: bb2:
126 bb2:                                              ; preds = %bb2.loopexit, %bb2, %bb1
127   %i = phi i32 [ 0, %bb1 ], [ %i, %bb2 ], [ %i.ph, %bb2.loopexit ]
128   %x = load i32, i32* undef, align 8
129   br i1 undef, label %bb2, label %bb3.preheader
131 ; CHECK: bb3.preheader:
132 bb3.preheader:                                    ; preds = %bb2
133 ; CHECK: %x.lcssa = phi i32 [ %x, %bb2 ]
134   br label %bb3
136 bb3:                                              ; preds = %bb3.preheader, %bb3
137   %y = add i32 2, %x
138   br i1 true, label %bb2.loopexit, label %bb3