[llvm] r323309 - [NFC] Remove overconfident assert from IRCE
Max Kazantsev via llvm-commits
llvm-commits at lists.llvm.org
Tue Jan 23 23:51:41 PST 2018
Author: mkazantsev
Date: Tue Jan 23 23:51:41 2018
New Revision: 323309
URL: http://llvm.org/viewvc/llvm-project?rev=323309&view=rev
Log:
[NFC] Remove overconfident assert from IRCE
This patch removes assert that SCEV is able to prove that a value is
non-negative. In fact, SCEV can sometimes be unable to do this because
its cache does not update properly. This assert will be returned once this
problem is resolved.
Added:
llvm/trunk/test/Transforms/IRCE/optimistic_scev.ll
Modified:
llvm/trunk/lib/Transforms/Scalar/InductiveRangeCheckElimination.cpp
Modified: llvm/trunk/lib/Transforms/Scalar/InductiveRangeCheckElimination.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/InductiveRangeCheckElimination.cpp?rev=323309&r1=323308&r2=323309&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/InductiveRangeCheckElimination.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/InductiveRangeCheckElimination.cpp Tue Jan 23 23:51:41 2018
@@ -1643,8 +1643,6 @@ InductiveRangeCheck::computeSafeIteratio
// values, depending on type of latch condition that defines IV iteration
// space.
auto ClampedSubstract = [&](const SCEV *X, const SCEV *Y) {
- assert(SE.isKnownNonNegative(X) &&
- "We can only substract from values in [0; SINT_MAX]!");
if (IsLatchSigned) {
// X is a number from signed range, Y is interpreted as signed.
// Even if Y is SINT_MAX, (X - Y) does not reach SINT_MIN. So the only
Added: llvm/trunk/test/Transforms/IRCE/optimistic_scev.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/IRCE/optimistic_scev.ll?rev=323309&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/IRCE/optimistic_scev.ll (added)
+++ llvm/trunk/test/Transforms/IRCE/optimistic_scev.ll Tue Jan 23 23:51:41 2018
@@ -0,0 +1,42 @@
+; RUN: opt -verify-loop-info -irce-print-changed-loops -irce -S < %s 2>&1 | FileCheck %s
+
+; CHECK-LABEL: irce: in function test_01: constrained Loop at depth 2 containing:
+
+define void @test_01(i64 %len) {
+
+; CHECK-LABEL: @test_01(
+
+entry:
+ br label %loop
+
+check:
+ %entry_check = icmp eq i32 %idx.next, 0
+ br i1 %entry_check, label %exit, label %loop
+
+loop:
+ %idx = phi i32 [ 1, %entry ], [ %idx.next, %check ]
+ %idx_ext = sext i32 %idx to i64
+ br label %inner_loop
+
+inner_loop:
+ %iv = phi i64 [ 0, %loop ], [ %iv.next, %inner_backedge ]
+ %iv.next = add nuw nsw i64 %iv, 1
+ %inner_check = icmp slt i64 %iv.next, %idx_ext
+ br i1 %inner_check, label %inner, label %outer_check
+
+inner:
+ %iv_next_check = icmp slt i64 %iv.next, 100
+ br i1 %iv_next_check, label %inner_backedge, label %exit
+
+inner_backedge:
+ %cond = icmp eq i64 %iv.next, 100
+ br i1 %cond, label %exit, label %inner_loop
+
+outer_check:
+ %idx.next = add i32 %idx, 1
+ %loopdone = icmp slt i32 %idx.next, 2
+ br i1 %loopdone, label %check, label %exit
+
+exit:
+ ret void
+}
More information about the llvm-commits
mailing list