summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/ValueTracking.cpp
diff options
context:
space:
mode:
authorDavid Majnemer <david.majnemer@gmail.com>2014-12-12 23:59:29 +0000
committerDavid Majnemer <david.majnemer@gmail.com>2014-12-12 23:59:29 +0000
commit9b6097586ccae0528326527e53fa16721c012b74 (patch)
tree97a4d16f03c38d4560cbd0e5c257ab04d9623a84 /llvm/lib/Analysis/ValueTracking.cpp
parentf770683f14f98eae7c64b942c1e6c3470ec0c81b (diff)
downloadbcm5719-llvm-9b6097586ccae0528326527e53fa16721c012b74.tar.gz
bcm5719-llvm-9b6097586ccae0528326527e53fa16721c012b74.zip
ValueTracking: Don't recurse too deeply in computeKnownBitsFromAssume
Respect the MaxDepth recursion limit, doing otherwise will trigger an assert in computeKnownBits. This fixes PR21891. llvm-svn: 224168
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
-rw-r--r--llvm/lib/Analysis/ValueTracking.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp
index fa428fa108d..4317bcde91e 100644
--- a/llvm/lib/Analysis/ValueTracking.cpp
+++ b/llvm/lib/Analysis/ValueTracking.cpp
@@ -511,6 +511,10 @@ static void computeKnownBitsFromAssume(Value *V, APInt &KnownZero,
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)),
OpenPOWER on IntegriCloud