mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-25 04:39:44 +00:00
Rename and reorder the arguments to isImpliedCond, for consistency and clarity.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110750 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ae321ed287
commit
af08a36bd6
@ -352,10 +352,11 @@ namespace llvm {
|
||||
std::pair<BasicBlock *, BasicBlock *>
|
||||
getPredecessorWithUniqueSuccessorForBB(BasicBlock *BB);
|
||||
|
||||
/// isImpliedCond - Test whether the condition described by Pred, LHS,
|
||||
/// and RHS is true whenever the given Cond value evaluates to true.
|
||||
bool isImpliedCond(Value *Cond, ICmpInst::Predicate Pred,
|
||||
/// isImpliedCond - Test whether the condition described by Pred, LHS, and
|
||||
/// RHS is true whenever the given FoundCondValue value evaluates to true.
|
||||
bool isImpliedCond(ICmpInst::Predicate Pred,
|
||||
const SCEV *LHS, const SCEV *RHS,
|
||||
Value *FoundCondValue,
|
||||
bool Inverse);
|
||||
|
||||
/// isImpliedCondOperands - Test whether the condition described by Pred,
|
||||
|
@ -5223,7 +5223,8 @@ ScalarEvolution::isLoopBackedgeGuardedByCond(const Loop *L,
|
||||
LoopContinuePredicate->isUnconditional())
|
||||
return false;
|
||||
|
||||
return isImpliedCond(LoopContinuePredicate->getCondition(), Pred, LHS, RHS,
|
||||
return isImpliedCond(Pred, LHS, RHS,
|
||||
LoopContinuePredicate->getCondition(),
|
||||
LoopContinuePredicate->getSuccessor(0) != L->getHeader());
|
||||
}
|
||||
|
||||
@ -5252,7 +5253,8 @@ ScalarEvolution::isLoopEntryGuardedByCond(const Loop *L,
|
||||
LoopEntryPredicate->isUnconditional())
|
||||
continue;
|
||||
|
||||
if (isImpliedCond(LoopEntryPredicate->getCondition(), Pred, LHS, RHS,
|
||||
if (isImpliedCond(Pred, LHS, RHS,
|
||||
LoopEntryPredicate->getCondition(),
|
||||
LoopEntryPredicate->getSuccessor(0) != Pair.second))
|
||||
return true;
|
||||
}
|
||||
@ -5262,24 +5264,24 @@ ScalarEvolution::isLoopEntryGuardedByCond(const Loop *L,
|
||||
|
||||
/// isImpliedCond - Test whether the condition described by Pred, LHS,
|
||||
/// and RHS is true whenever the given Cond value evaluates to true.
|
||||
bool ScalarEvolution::isImpliedCond(Value *CondValue,
|
||||
ICmpInst::Predicate Pred,
|
||||
bool ScalarEvolution::isImpliedCond(ICmpInst::Predicate Pred,
|
||||
const SCEV *LHS, const SCEV *RHS,
|
||||
Value *FoundCondValue,
|
||||
bool Inverse) {
|
||||
// Recursively handle And and Or conditions.
|
||||
if (BinaryOperator *BO = dyn_cast<BinaryOperator>(CondValue)) {
|
||||
if (BinaryOperator *BO = dyn_cast<BinaryOperator>(FoundCondValue)) {
|
||||
if (BO->getOpcode() == Instruction::And) {
|
||||
if (!Inverse)
|
||||
return isImpliedCond(BO->getOperand(0), Pred, LHS, RHS, Inverse) ||
|
||||
isImpliedCond(BO->getOperand(1), Pred, LHS, RHS, Inverse);
|
||||
return isImpliedCond(Pred, LHS, RHS, BO->getOperand(0), Inverse) ||
|
||||
isImpliedCond(Pred, LHS, RHS, BO->getOperand(1), Inverse);
|
||||
} else if (BO->getOpcode() == Instruction::Or) {
|
||||
if (Inverse)
|
||||
return isImpliedCond(BO->getOperand(0), Pred, LHS, RHS, Inverse) ||
|
||||
isImpliedCond(BO->getOperand(1), Pred, LHS, RHS, Inverse);
|
||||
return isImpliedCond(Pred, LHS, RHS, BO->getOperand(0), Inverse) ||
|
||||
isImpliedCond(Pred, LHS, RHS, BO->getOperand(1), Inverse);
|
||||
}
|
||||
}
|
||||
|
||||
ICmpInst *ICI = dyn_cast<ICmpInst>(CondValue);
|
||||
ICmpInst *ICI = dyn_cast<ICmpInst>(FoundCondValue);
|
||||
if (!ICI) return false;
|
||||
|
||||
// Bail if the ICmp's operands' types are wider than the needed type
|
||||
|
Loading…
Reference in New Issue
Block a user