mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-04 01:51:31 +00:00
Fix SCEVAddRecExpr::isLoopInvariant to test if all of its operands
are loop invariant, not just the start operand. llvm-svn: 74338
This commit is contained in:
parent
4384816259
commit
e8b1947a18
@ -327,12 +327,22 @@ SCEVAddRecExpr::replaceSymbolicValuesWithConcrete(const SCEV *Sym,
|
||||
|
||||
|
||||
bool SCEVAddRecExpr::isLoopInvariant(const Loop *QueryLoop) const {
|
||||
// This recurrence is invariant w.r.t to QueryLoop iff QueryLoop doesn't
|
||||
// contain L and if the start is invariant.
|
||||
// Add recurrences are never invariant in the function-body (null loop).
|
||||
return QueryLoop &&
|
||||
!QueryLoop->contains(L->getHeader()) &&
|
||||
getOperand(0)->isLoopInvariant(QueryLoop);
|
||||
if (!QueryLoop)
|
||||
return false;
|
||||
|
||||
// This recurrence is variant w.r.t. QueryLoop if QueryLoop contains L.
|
||||
if (QueryLoop->contains(L->getHeader()))
|
||||
return false;
|
||||
|
||||
// This recurrence is variant w.r.t. QueryLoop if any of its operands
|
||||
// are variant.
|
||||
for (unsigned i = 0, e = getNumOperands(); i != e; ++i)
|
||||
if (!getOperand(i)->isLoopInvariant(QueryLoop))
|
||||
return false;
|
||||
|
||||
// Otherwise it's loop-invariant.
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user