[llvm] r224168 - ValueTracking: Don't recurse too deeply in computeKnownBitsFromAssume
David Majnemer
david.majnemer at gmail.com
Fri Dec 12 15:59:30 PST 2014
Author: majnemer
Date: Fri Dec 12 17:59:29 2014
New Revision: 224168
URL: http://llvm.org/viewvc/llvm-project?rev=224168&view=rev
Log:
ValueTracking: Don't recurse too deeply in computeKnownBitsFromAssume
Respect the MaxDepth recursion limit, doing otherwise will trigger an
assert in computeKnownBits.
This fixes PR21891.
Added:
llvm/trunk/test/Transforms/InstCombine/pr21891.ll
Modified:
llvm/trunk/lib/Analysis/ValueTracking.cpp
Modified: llvm/trunk/lib/Analysis/ValueTracking.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/ValueTracking.cpp?rev=224168&r1=224167&r2=224168&view=diff
==============================================================================
--- llvm/trunk/lib/Analysis/ValueTracking.cpp (original)
+++ llvm/trunk/lib/Analysis/ValueTracking.cpp Fri Dec 12 17:59:29 2014
@@ -511,6 +511,10 @@ static void computeKnownBitsFromAssume(V
return;
}
+ // The remaining tests are all recursive, so bail out if we hit the limit.
+ if (Depth == MaxDepth)
+ continue;
+
Value *A, *B;
auto m_V = m_CombineOr(m_Specific(V),
m_CombineOr(m_PtrToInt(m_Specific(V)),
Added: llvm/trunk/test/Transforms/InstCombine/pr21891.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/pr21891.ll?rev=224168&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/pr21891.ll (added)
+++ llvm/trunk/test/Transforms/InstCombine/pr21891.ll Fri Dec 12 17:59:29 2014
@@ -0,0 +1,18 @@
+; RUN: opt %s -instcombine
+
+define i32 @f(i32 %theNumber) {
+entry:
+ %cmp = icmp sgt i32 %theNumber, -1
+ call void @llvm.assume(i1 %cmp)
+ br i1 true, label %if.then, label %if.end
+
+if.then: ; preds = %entry
+ %shl = shl nuw i32 %theNumber, 1
+ br label %if.end
+
+if.end: ; preds = %if.then, %entry
+ %phi = phi i32 [ %shl, %if.then ], [ undef, %entry ]
+ ret i32 %phi
+}
+
+declare void @llvm.assume(i1)
More information about the llvm-commits
mailing list