[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / Transforms / LoopSimplifyCFG / merge-header.ll
blob91bc44baef94ba701405c853a1a419032aa1b673
1 ; RUN: opt -S -loop-simplifycfg < %s | FileCheck %s
2 ; RUN: opt -S -passes='require<domtree>,loop(simplify-cfg)' < %s | FileCheck %s
3 ; RUN: opt -S -loop-simplifycfg -enable-mssa-loop-dependency=true -verify-memoryssa < %s | FileCheck %s
5 ; CHECK-LABEL: foo
6 ; CHECK:      entry:
7 ; CHECK-NEXT:   br label %[[LOOP:[a-z]+]]
8 ; CHECK:      [[LOOP]]:
9 ; CHECK-NEXT:   phi
10 ; CHECK-NOT:    br label
11 ; CHECK:        br i1
12 define i32 @foo(i32* %P, i64* %Q) {
13 entry:
14   br label %outer
16 outer:                                            ; preds = %outer.latch2, %entry
17   %y.2 = phi i32 [ 0, %entry ], [ %y.inc2, %outer.latch2 ]
18   br label %inner
20 inner:                                            ; preds = %outer
21   store i32 0, i32* %P
22   store i32 1, i32* %P
23   store i32 2, i32* %P
24   %y.inc2 = add nsw i32 %y.2, 1
25   %exitcond.outer = icmp eq i32 %y.inc2, 3
26   store i32 %y.2, i32* %P
27   br i1 %exitcond.outer, label %exit, label %outer.latch2
29 outer.latch2:                                     ; preds = %inner
30   %t = sext i32 %y.inc2 to i64
31   store i64 %t, i64* %Q
32   br label %outer
34 exit:                                             ; preds = %inner
35   ret i32 0