1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 2
2 ; RUN: opt < %s -passes='print<scalar-evolution>,simple-loop-unswitch<no-nontrivial>,print<scalar-evolution>' -disable-output 2>&1 | FileCheck -check-prefix CHECK-SCEV %s
3 ; RUN: opt < %s -passes='function(loop-deletion,simple-loop-unswitch<no-nontrivial>),verify<scalar-evolution>' -S | FileCheck -check-prefix CHECK-IR %s
5 ; These tests used to hit an assertion failure in llvm::ScalarEvolution::BackedgeTakenInfo::getExact:
6 ; "We should only have known counts for exiting blocks that dominate latch!"' failed.
8 ; Verify that we no longer hit that assert, while we expect to have forgotten SCEV for the outer loop.
9 ; Also added checks to show and verify the IR transformation.
12 ; Before the unswitch:
14 ; CHECK-SCEV: Classifying expressions for: @f4
15 ; CHECK-SCEV-NEXT: %j.0 = phi i16 [ 0, %entry ], [ %0, %sw.bb2 ]
16 ; CHECK-SCEV-NEXT: --> {0,+,1}<nuw><nsw><%lbl1> U: [0,3) S: [0,3) Exits: 2 LoopDispositions: { %lbl1: Computable, %lbl2: Invariant }
17 ; CHECK-SCEV-NEXT: %0 = add i16 %j.0, 1
18 ; CHECK-SCEV-NEXT: --> {1,+,1}<nuw><nsw><%lbl1> U: [1,4) S: [1,4) Exits: 3 LoopDispositions: { %lbl1: Computable, %lbl2: Invariant }
19 ; CHECK-SCEV-DAG: Loop %lbl2: Unpredictable backedge-taken count.
20 ; CHECK-SCEV-DAG: Loop %lbl1: backedge-taken count is i16 2
24 ; CHECK-SCEV: Classifying expressions for: @f4
25 ; CHECK-SCEV-NEXT: %j.0 = phi i16 [ 0, %entry ], [ %0, %sw.bb2 ]
26 ; CHECK-SCEV-NEXT: --> {0,+,1}<nuw><nsw><%lbl1> U: [0,-32768) S: [0,-32768) Exits: <<Unknown>> LoopDispositions: { %lbl1: Computable }
27 ; CHECK-SCEV-NEXT: %0 = add i16 %j.0, 1
28 ; CHECK-SCEV-NEXT: --> {1,+,1}<nuw><nsw><%lbl1> U: [1,-32768) S: [1,-32768) Exits: <<Unknown>> LoopDispositions: { %lbl1: Computable }
29 ; CHECK-SCEV-DAG: Loop %lbl1: Unpredictable backedge-taken count.
30 ; CHECK-SCEV-DAG: Loop %lbl2: <multiple exits> Unpredictable backedge-taken count.
34 ; CHECK-IR-LABEL: define i16 @f4() {
35 ; CHECK-IR-NEXT: entry:
36 ; CHECK-IR-NEXT: br label [[LBL1:%.*]]
38 ; CHECK-IR-NEXT: [[J_0:%.*]] = phi i16 [ 0, [[ENTRY:%.*]] ], [ [[TMP0:%.*]], [[SW_BB2:%.*]] ]
39 ; CHECK-IR-NEXT: switch i16 [[J_0]], label [[LBL1_SPLIT:%.*]] [
40 ; CHECK-IR-NEXT: i16 0, label [[SW_BB2]]
41 ; CHECK-IR-NEXT: i16 1, label [[SW_BB2]]
42 ; CHECK-IR-NEXT: i16 2, label [[LBL3:%.*]]
44 ; CHECK-IR: lbl1.split:
45 ; CHECK-IR-NEXT: br label [[LBL2:%.*]]
47 ; CHECK-IR-NEXT: br label [[LBL2]]
49 ; CHECK-IR-NEXT: [[TMP0]] = add i16 [[J_0]], 1
50 ; CHECK-IR-NEXT: br label [[LBL1]]
52 ; CHECK-IR-NEXT: ret i16 0
57 lbl1: ; preds = %sw.bb2, %entry
58 %j.0 = phi i16 [ 0, %entry ], [ %0, %sw.bb2 ]
61 lbl2: ; preds = %lbl2, %lbl1
62 switch i16 %j.0, label %lbl2 [
68 sw.bb2: ; preds = %lbl2, %lbl2