From: Eli Friedman Date: Sat, 2 Apr 2011 22:11:56 +0000 (+0000) Subject: Don't assume something which might be a constant expression is an instruction. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=6bdd261df972b5e70e4242721ab16b57c6fe3d1f;p=oota-llvm.git Don't assume something which might be a constant expression is an instruction. Based on PR9429, but no testcase because I can't figure out how to trigger it anymore given other changes to the relevant code. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@128781 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/ValueTracking.cpp b/lib/Analysis/ValueTracking.cpp index 0f4bfb7b0d9..a8117e6e42e 100644 --- a/lib/Analysis/ValueTracking.cpp +++ b/lib/Analysis/ValueTracking.cpp @@ -729,9 +729,9 @@ bool llvm::isPowerOfTwo(Value *V, const TargetData *TD, unsigned Depth) { // copying a sign bit (sdiv int_min, 2). if (match(V, m_LShr(m_Value(), m_Value())) || match(V, m_UDiv(m_Value(), m_Value()))) { - BinaryOperator *BO = cast(V); - if (BO->isExact()) - return isPowerOfTwo(BO->getOperand(0), TD, Depth); + PossiblyExactOperator *PEO = cast(V); + if (PEO->isExact()) + return isPowerOfTwo(PEO->getOperand(0), TD, Depth); } return false;