forked from OSchip/llvm-project
Partial revert of 82fb4f4
Two crashes have been reported. This change disables the new logic while leaving the new node in tree. Hopefully, that's enough to allow investigation without breakage while avoiding massive churn.
This commit is contained in:
parent
abc787fbf3
commit
f62f47f5e1
|
@ -8254,7 +8254,7 @@ ScalarEvolution::computeExitLimitFromCondFromBinOp(
|
||||||
if (EL0.ExactNotTaken != getCouldNotCompute() &&
|
if (EL0.ExactNotTaken != getCouldNotCompute() &&
|
||||||
EL1.ExactNotTaken != getCouldNotCompute()) {
|
EL1.ExactNotTaken != getCouldNotCompute()) {
|
||||||
BECount = getUMinFromMismatchedTypes(EL0.ExactNotTaken, EL1.ExactNotTaken,
|
BECount = getUMinFromMismatchedTypes(EL0.ExactNotTaken, EL1.ExactNotTaken,
|
||||||
/*Sequential=*/!PoisonSafe);
|
/*Sequential=*/false);
|
||||||
|
|
||||||
// If EL0.ExactNotTaken was zero and ExitCond was a short-circuit form,
|
// If EL0.ExactNotTaken was zero and ExitCond was a short-circuit form,
|
||||||
// it should have been simplified to zero (see the condition (3) above)
|
// it should have been simplified to zero (see the condition (3) above)
|
||||||
|
|
|
@ -5,15 +5,15 @@ define i32 @logical_and_2ops(i32 %n, i32 %m) {
|
||||||
; CHECK-LABEL: 'logical_and_2ops'
|
; CHECK-LABEL: 'logical_and_2ops'
|
||||||
; CHECK-NEXT: Classifying expressions for: @logical_and_2ops
|
; CHECK-NEXT: Classifying expressions for: @logical_and_2ops
|
||||||
; CHECK-NEXT: %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
|
; CHECK-NEXT: %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
|
||||||
; CHECK-NEXT: --> {0,+,1}<%loop> U: full-set S: full-set Exits: (%n umin_seq %m) LoopDispositions: { %loop: Computable }
|
; CHECK-NEXT: --> {0,+,1}<%loop> U: full-set S: full-set Exits: (%n umin %m) LoopDispositions: { %loop: Computable }
|
||||||
; CHECK-NEXT: %i.next = add i32 %i, 1
|
; CHECK-NEXT: %i.next = add i32 %i, 1
|
||||||
; CHECK-NEXT: --> {1,+,1}<%loop> U: full-set S: full-set Exits: (1 + (%n umin_seq %m)) LoopDispositions: { %loop: Computable }
|
; CHECK-NEXT: --> {1,+,1}<%loop> U: full-set S: full-set Exits: (1 + (%n umin %m)) LoopDispositions: { %loop: Computable }
|
||||||
; CHECK-NEXT: %cond = select i1 %cond_p0, i1 %cond_p1, i1 false
|
; CHECK-NEXT: %cond = select i1 %cond_p0, i1 %cond_p1, i1 false
|
||||||
; CHECK-NEXT: --> %cond U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
; CHECK-NEXT: --> %cond U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
||||||
; CHECK-NEXT: Determining loop execution counts for: @logical_and_2ops
|
; CHECK-NEXT: Determining loop execution counts for: @logical_and_2ops
|
||||||
; CHECK-NEXT: Loop %loop: backedge-taken count is (%n umin_seq %m)
|
; CHECK-NEXT: Loop %loop: backedge-taken count is (%n umin %m)
|
||||||
; CHECK-NEXT: Loop %loop: max backedge-taken count is -1
|
; CHECK-NEXT: Loop %loop: max backedge-taken count is -1
|
||||||
; CHECK-NEXT: Loop %loop: Predicated backedge-taken count is (%n umin_seq %m)
|
; CHECK-NEXT: Loop %loop: Predicated backedge-taken count is (%n umin %m)
|
||||||
; CHECK-NEXT: Predicates:
|
; CHECK-NEXT: Predicates:
|
||||||
; CHECK: Loop %loop: Trip multiple is 1
|
; CHECK: Loop %loop: Trip multiple is 1
|
||||||
;
|
;
|
||||||
|
@ -34,15 +34,15 @@ define i32 @logical_or_2ops(i32 %n, i32 %m) {
|
||||||
; CHECK-LABEL: 'logical_or_2ops'
|
; CHECK-LABEL: 'logical_or_2ops'
|
||||||
; CHECK-NEXT: Classifying expressions for: @logical_or_2ops
|
; CHECK-NEXT: Classifying expressions for: @logical_or_2ops
|
||||||
; CHECK-NEXT: %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
|
; CHECK-NEXT: %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
|
||||||
; CHECK-NEXT: --> {0,+,1}<%loop> U: full-set S: full-set Exits: (%n umin_seq %m) LoopDispositions: { %loop: Computable }
|
; CHECK-NEXT: --> {0,+,1}<%loop> U: full-set S: full-set Exits: (%n umin %m) LoopDispositions: { %loop: Computable }
|
||||||
; CHECK-NEXT: %i.next = add i32 %i, 1
|
; CHECK-NEXT: %i.next = add i32 %i, 1
|
||||||
; CHECK-NEXT: --> {1,+,1}<%loop> U: full-set S: full-set Exits: (1 + (%n umin_seq %m)) LoopDispositions: { %loop: Computable }
|
; CHECK-NEXT: --> {1,+,1}<%loop> U: full-set S: full-set Exits: (1 + (%n umin %m)) LoopDispositions: { %loop: Computable }
|
||||||
; CHECK-NEXT: %cond = select i1 %cond_p0, i1 true, i1 %cond_p1
|
; CHECK-NEXT: %cond = select i1 %cond_p0, i1 true, i1 %cond_p1
|
||||||
; CHECK-NEXT: --> %cond U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
; CHECK-NEXT: --> %cond U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
||||||
; CHECK-NEXT: Determining loop execution counts for: @logical_or_2ops
|
; CHECK-NEXT: Determining loop execution counts for: @logical_or_2ops
|
||||||
; CHECK-NEXT: Loop %loop: backedge-taken count is (%n umin_seq %m)
|
; CHECK-NEXT: Loop %loop: backedge-taken count is (%n umin %m)
|
||||||
; CHECK-NEXT: Loop %loop: max backedge-taken count is -1
|
; CHECK-NEXT: Loop %loop: max backedge-taken count is -1
|
||||||
; CHECK-NEXT: Loop %loop: Predicated backedge-taken count is (%n umin_seq %m)
|
; CHECK-NEXT: Loop %loop: Predicated backedge-taken count is (%n umin %m)
|
||||||
; CHECK-NEXT: Predicates:
|
; CHECK-NEXT: Predicates:
|
||||||
; CHECK: Loop %loop: Trip multiple is 1
|
; CHECK: Loop %loop: Trip multiple is 1
|
||||||
;
|
;
|
||||||
|
@ -63,17 +63,17 @@ define i32 @logical_and_3ops(i32 %n, i32 %m, i32 %k) {
|
||||||
; CHECK-LABEL: 'logical_and_3ops'
|
; CHECK-LABEL: 'logical_and_3ops'
|
||||||
; CHECK-NEXT: Classifying expressions for: @logical_and_3ops
|
; CHECK-NEXT: Classifying expressions for: @logical_and_3ops
|
||||||
; CHECK-NEXT: %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
|
; CHECK-NEXT: %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
|
||||||
; CHECK-NEXT: --> {0,+,1}<%loop> U: full-set S: full-set Exits: (%n umin_seq %m umin_seq %k) LoopDispositions: { %loop: Computable }
|
; CHECK-NEXT: --> {0,+,1}<%loop> U: full-set S: full-set Exits: (%n umin %m umin %k) LoopDispositions: { %loop: Computable }
|
||||||
; CHECK-NEXT: %i.next = add i32 %i, 1
|
; CHECK-NEXT: %i.next = add i32 %i, 1
|
||||||
; CHECK-NEXT: --> {1,+,1}<%loop> U: full-set S: full-set Exits: (1 + (%n umin_seq %m umin_seq %k)) LoopDispositions: { %loop: Computable }
|
; CHECK-NEXT: --> {1,+,1}<%loop> U: full-set S: full-set Exits: (1 + (%n umin %m umin %k)) LoopDispositions: { %loop: Computable }
|
||||||
; CHECK-NEXT: %cond_p3 = select i1 %cond_p0, i1 %cond_p1, i1 false
|
; CHECK-NEXT: %cond_p3 = select i1 %cond_p0, i1 %cond_p1, i1 false
|
||||||
; CHECK-NEXT: --> %cond_p3 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
; CHECK-NEXT: --> %cond_p3 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
||||||
; CHECK-NEXT: %cond = select i1 %cond_p3, i1 %cond_p2, i1 false
|
; CHECK-NEXT: %cond = select i1 %cond_p3, i1 %cond_p2, i1 false
|
||||||
; CHECK-NEXT: --> %cond U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
; CHECK-NEXT: --> %cond U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
||||||
; CHECK-NEXT: Determining loop execution counts for: @logical_and_3ops
|
; CHECK-NEXT: Determining loop execution counts for: @logical_and_3ops
|
||||||
; CHECK-NEXT: Loop %loop: backedge-taken count is (%n umin_seq %m umin_seq %k)
|
; CHECK-NEXT: Loop %loop: backedge-taken count is (%n umin %m umin %k)
|
||||||
; CHECK-NEXT: Loop %loop: max backedge-taken count is -1
|
; CHECK-NEXT: Loop %loop: max backedge-taken count is -1
|
||||||
; CHECK-NEXT: Loop %loop: Predicated backedge-taken count is (%n umin_seq %m umin_seq %k)
|
; CHECK-NEXT: Loop %loop: Predicated backedge-taken count is (%n umin %m umin %k)
|
||||||
; CHECK-NEXT: Predicates:
|
; CHECK-NEXT: Predicates:
|
||||||
; CHECK: Loop %loop: Trip multiple is 1
|
; CHECK: Loop %loop: Trip multiple is 1
|
||||||
;
|
;
|
||||||
|
@ -96,17 +96,17 @@ define i32 @logical_or_3ops(i32 %n, i32 %m, i32 %k) {
|
||||||
; CHECK-LABEL: 'logical_or_3ops'
|
; CHECK-LABEL: 'logical_or_3ops'
|
||||||
; CHECK-NEXT: Classifying expressions for: @logical_or_3ops
|
; CHECK-NEXT: Classifying expressions for: @logical_or_3ops
|
||||||
; CHECK-NEXT: %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
|
; CHECK-NEXT: %i = phi i32 [ 0, %entry ], [ %i.next, %loop ]
|
||||||
; CHECK-NEXT: --> {0,+,1}<%loop> U: full-set S: full-set Exits: (%n umin_seq %m umin_seq %k) LoopDispositions: { %loop: Computable }
|
; CHECK-NEXT: --> {0,+,1}<%loop> U: full-set S: full-set Exits: (%n umin %m umin %k) LoopDispositions: { %loop: Computable }
|
||||||
; CHECK-NEXT: %i.next = add i32 %i, 1
|
; CHECK-NEXT: %i.next = add i32 %i, 1
|
||||||
; CHECK-NEXT: --> {1,+,1}<%loop> U: full-set S: full-set Exits: (1 + (%n umin_seq %m umin_seq %k)) LoopDispositions: { %loop: Computable }
|
; CHECK-NEXT: --> {1,+,1}<%loop> U: full-set S: full-set Exits: (1 + (%n umin %m umin %k)) LoopDispositions: { %loop: Computable }
|
||||||
; CHECK-NEXT: %cond_p3 = select i1 %cond_p0, i1 true, i1 %cond_p1
|
; CHECK-NEXT: %cond_p3 = select i1 %cond_p0, i1 true, i1 %cond_p1
|
||||||
; CHECK-NEXT: --> %cond_p3 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
; CHECK-NEXT: --> %cond_p3 U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
||||||
; CHECK-NEXT: %cond = select i1 %cond_p3, i1 true, i1 %cond_p2
|
; CHECK-NEXT: %cond = select i1 %cond_p3, i1 true, i1 %cond_p2
|
||||||
; CHECK-NEXT: --> %cond U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
; CHECK-NEXT: --> %cond U: full-set S: full-set Exits: <<Unknown>> LoopDispositions: { %loop: Variant }
|
||||||
; CHECK-NEXT: Determining loop execution counts for: @logical_or_3ops
|
; CHECK-NEXT: Determining loop execution counts for: @logical_or_3ops
|
||||||
; CHECK-NEXT: Loop %loop: backedge-taken count is (%n umin_seq %m umin_seq %k)
|
; CHECK-NEXT: Loop %loop: backedge-taken count is (%n umin %m umin %k)
|
||||||
; CHECK-NEXT: Loop %loop: max backedge-taken count is -1
|
; CHECK-NEXT: Loop %loop: max backedge-taken count is -1
|
||||||
; CHECK-NEXT: Loop %loop: Predicated backedge-taken count is (%n umin_seq %m umin_seq %k)
|
; CHECK-NEXT: Loop %loop: Predicated backedge-taken count is (%n umin %m umin %k)
|
||||||
; CHECK-NEXT: Predicates:
|
; CHECK-NEXT: Predicates:
|
||||||
; CHECK: Loop %loop: Trip multiple is 1
|
; CHECK: Loop %loop: Trip multiple is 1
|
||||||
;
|
;
|
||||||
|
|
|
@ -4,14 +4,12 @@
|
||||||
define i32 @logical_and_2ops(i32 %n, i32 %m) {
|
define i32 @logical_and_2ops(i32 %n, i32 %m) {
|
||||||
; CHECK-LABEL: @logical_and_2ops(
|
; CHECK-LABEL: @logical_and_2ops(
|
||||||
; CHECK-NEXT: entry:
|
; CHECK-NEXT: entry:
|
||||||
; CHECK-NEXT: [[UMIN:%.*]] = call i32 @llvm.umin.i32(i32 [[M:%.*]], i32 [[N:%.*]])
|
|
||||||
; CHECK-NEXT: br label [[LOOP:%.*]]
|
; CHECK-NEXT: br label [[LOOP:%.*]]
|
||||||
; CHECK: loop:
|
; CHECK: loop:
|
||||||
; CHECK-NEXT: br i1 false, label [[LOOP]], label [[EXIT:%.*]]
|
; CHECK-NEXT: br i1 false, label [[LOOP]], label [[EXIT:%.*]]
|
||||||
; CHECK: exit:
|
; CHECK: exit:
|
||||||
; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[N]], 0
|
; CHECK-NEXT: [[UMIN:%.*]] = call i32 @llvm.umin.i32(i32 [[M:%.*]], i32 [[N:%.*]])
|
||||||
; CHECK-NEXT: [[TMP1:%.*]] = select i1 [[TMP0]], i32 0, i32 [[UMIN]]
|
; CHECK-NEXT: ret i32 [[UMIN]]
|
||||||
; CHECK-NEXT: ret i32 [[TMP1]]
|
|
||||||
;
|
;
|
||||||
entry:
|
entry:
|
||||||
br label %loop
|
br label %loop
|
||||||
|
@ -29,14 +27,12 @@ exit:
|
||||||
define i32 @logical_or_2ops(i32 %n, i32 %m) {
|
define i32 @logical_or_2ops(i32 %n, i32 %m) {
|
||||||
; CHECK-LABEL: @logical_or_2ops(
|
; CHECK-LABEL: @logical_or_2ops(
|
||||||
; CHECK-NEXT: entry:
|
; CHECK-NEXT: entry:
|
||||||
; CHECK-NEXT: [[UMIN:%.*]] = call i32 @llvm.umin.i32(i32 [[M:%.*]], i32 [[N:%.*]])
|
|
||||||
; CHECK-NEXT: br label [[LOOP:%.*]]
|
; CHECK-NEXT: br label [[LOOP:%.*]]
|
||||||
; CHECK: loop:
|
; CHECK: loop:
|
||||||
; CHECK-NEXT: br i1 true, label [[EXIT:%.*]], label [[LOOP]]
|
; CHECK-NEXT: br i1 true, label [[EXIT:%.*]], label [[LOOP]]
|
||||||
; CHECK: exit:
|
; CHECK: exit:
|
||||||
; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[N]], 0
|
; CHECK-NEXT: [[UMIN:%.*]] = call i32 @llvm.umin.i32(i32 [[M:%.*]], i32 [[N:%.*]])
|
||||||
; CHECK-NEXT: [[TMP1:%.*]] = select i1 [[TMP0]], i32 0, i32 [[UMIN]]
|
; CHECK-NEXT: ret i32 [[UMIN]]
|
||||||
; CHECK-NEXT: ret i32 [[TMP1]]
|
|
||||||
;
|
;
|
||||||
entry:
|
entry:
|
||||||
br label %loop
|
br label %loop
|
||||||
|
@ -54,17 +50,13 @@ exit:
|
||||||
define i32 @logical_and_3ops(i32 %n, i32 %m, i32 %k) {
|
define i32 @logical_and_3ops(i32 %n, i32 %m, i32 %k) {
|
||||||
; CHECK-LABEL: @logical_and_3ops(
|
; CHECK-LABEL: @logical_and_3ops(
|
||||||
; CHECK-NEXT: entry:
|
; CHECK-NEXT: entry:
|
||||||
; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[M:%.*]], 0
|
; CHECK-NEXT: [[UMIN:%.*]] = call i32 @llvm.umin.i32(i32 [[K:%.*]], i32 [[M:%.*]])
|
||||||
; CHECK-NEXT: [[UMIN:%.*]] = call i32 @llvm.umin.i32(i32 [[K:%.*]], i32 [[M]])
|
|
||||||
; CHECK-NEXT: [[UMIN1:%.*]] = call i32 @llvm.umin.i32(i32 [[UMIN]], i32 [[N:%.*]])
|
|
||||||
; CHECK-NEXT: br label [[LOOP:%.*]]
|
; CHECK-NEXT: br label [[LOOP:%.*]]
|
||||||
; CHECK: loop:
|
; CHECK: loop:
|
||||||
; CHECK-NEXT: br i1 false, label [[LOOP]], label [[EXIT:%.*]]
|
; CHECK-NEXT: br i1 false, label [[LOOP]], label [[EXIT:%.*]]
|
||||||
; CHECK: exit:
|
; CHECK: exit:
|
||||||
; CHECK-NEXT: [[TMP1:%.*]] = icmp eq i32 [[N]], 0
|
; CHECK-NEXT: [[UMIN1:%.*]] = call i32 @llvm.umin.i32(i32 [[UMIN]], i32 [[N:%.*]])
|
||||||
; CHECK-NEXT: [[TMP2:%.*]] = select i1 [[TMP1]], i1 true, i1 [[TMP0]]
|
; CHECK-NEXT: ret i32 [[UMIN1]]
|
||||||
; CHECK-NEXT: [[TMP3:%.*]] = select i1 [[TMP2]], i32 0, i32 [[UMIN1]]
|
|
||||||
; CHECK-NEXT: ret i32 [[TMP3]]
|
|
||||||
;
|
;
|
||||||
entry:
|
entry:
|
||||||
br label %loop
|
br label %loop
|
||||||
|
@ -84,17 +76,13 @@ exit:
|
||||||
define i32 @logical_or_3ops(i32 %n, i32 %m, i32 %k) {
|
define i32 @logical_or_3ops(i32 %n, i32 %m, i32 %k) {
|
||||||
; CHECK-LABEL: @logical_or_3ops(
|
; CHECK-LABEL: @logical_or_3ops(
|
||||||
; CHECK-NEXT: entry:
|
; CHECK-NEXT: entry:
|
||||||
; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[M:%.*]], 0
|
; CHECK-NEXT: [[UMIN:%.*]] = call i32 @llvm.umin.i32(i32 [[K:%.*]], i32 [[M:%.*]])
|
||||||
; CHECK-NEXT: [[UMIN:%.*]] = call i32 @llvm.umin.i32(i32 [[K:%.*]], i32 [[M]])
|
|
||||||
; CHECK-NEXT: [[UMIN1:%.*]] = call i32 @llvm.umin.i32(i32 [[UMIN]], i32 [[N:%.*]])
|
|
||||||
; CHECK-NEXT: br label [[LOOP:%.*]]
|
; CHECK-NEXT: br label [[LOOP:%.*]]
|
||||||
; CHECK: loop:
|
; CHECK: loop:
|
||||||
; CHECK-NEXT: br i1 true, label [[EXIT:%.*]], label [[LOOP]]
|
; CHECK-NEXT: br i1 true, label [[EXIT:%.*]], label [[LOOP]]
|
||||||
; CHECK: exit:
|
; CHECK: exit:
|
||||||
; CHECK-NEXT: [[TMP1:%.*]] = icmp eq i32 [[N]], 0
|
; CHECK-NEXT: [[UMIN1:%.*]] = call i32 @llvm.umin.i32(i32 [[UMIN]], i32 [[N:%.*]])
|
||||||
; CHECK-NEXT: [[TMP2:%.*]] = select i1 [[TMP1]], i1 true, i1 [[TMP0]]
|
; CHECK-NEXT: ret i32 [[UMIN1]]
|
||||||
; CHECK-NEXT: [[TMP3:%.*]] = select i1 [[TMP2]], i32 0, i32 [[UMIN1]]
|
|
||||||
; CHECK-NEXT: ret i32 [[TMP3]]
|
|
||||||
;
|
;
|
||||||
entry:
|
entry:
|
||||||
br label %loop
|
br label %loop
|
||||||
|
|
Loading…
Reference in New Issue