summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorNick Lewycky <nicholas@mxc.ca>2009-01-03 01:53:24 +0000
committerNick Lewycky <nicholas@mxc.ca>2009-01-03 01:53:24 +0000
commit8f375fc215f20c668504bce1094ac9058e8b61c7 (patch)
treec09cfe1918cabac36c1e05f3b9499e4da3d5bf59 /llvm/lib
parentcbb401c1d679a6476f0b5396a4bab09ce3f6ff9a (diff)
downloadbcm5719-llvm-8f375fc215f20c668504bce1094ac9058e8b61c7.tar.gz
bcm5719-llvm-8f375fc215f20c668504bce1094ac9058e8b61c7.zip
We know it's always a SCEVConstant if it gets here, so just cast it and
inline the only use of isNegative. Fixes warning reported by Mike Stump. llvm-svn: 61600
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Analysis/ScalarEvolution.cpp8
1 files changed, 2 insertions, 6 deletions
diff --git a/llvm/lib/Analysis/ScalarEvolution.cpp b/llvm/lib/Analysis/ScalarEvolution.cpp
index 375ad5ed707..b73eeab958a 100644
--- a/llvm/lib/Analysis/ScalarEvolution.cpp
+++ b/llvm/lib/Analysis/ScalarEvolution.cpp
@@ -2905,11 +2905,6 @@ bool ScalarEvolutionsImpl::executesAtLeastOnce(const Loop *L, bool isSigned,
return false;
}
-static bool isNegative(SCEVHandle X) {
- if (SCEVConstant *C = dyn_cast<SCEVConstant>(X))
- return C->getValue()->getValue().isNegative();
-}
-
/// potentialInfiniteLoop - Test whether the loop might jump over the exit value
/// due to wrapping around 2^n.
bool ScalarEvolutionsImpl::potentialInfiniteLoop(SCEV *Stride, SCEV *RHS,
@@ -2967,7 +2962,8 @@ HowManyLessThans(SCEV *LHS, SCEV *RHS, const Loop *L,
// the stride is negative, we're not counting how many times 'less-than' is
// true as we approach it, we're counting how far away we are from wrapping
// around the backside.
- if (isSigned && isNegative(Stride))
+ if (isSigned &&
+ cast<SCEVConstant>(Stride)->getValue()->getValue().isNegative())
return UnknownValue;
// We know the LHS is of the form {n,+,s} and the RHS is some loop-invariant
OpenPOWER on IntegriCloud