Use 'continue' to reduce nesting in this loop. No functionality change.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51399 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2008-05-22 00:53:38 +00:00
parent ddc4ee82b5
commit 29d929363d

View File

@ -787,8 +787,10 @@ void LICM::FindPromotableValuesInLoop(
// We can promote this alias set if it has a store, if it is a "Must" alias // We can promote this alias set if it has a store, if it is a "Must" alias
// set, if the pointer is loop invariant, and if we are not eliminating any // set, if the pointer is loop invariant, and if we are not eliminating any
// volatile loads or stores. // volatile loads or stores.
if (!AS.isForwardingAliasSet() && AS.isMod() && AS.isMustAlias() && if (AS.isForwardingAliasSet() || !AS.isMod() || !AS.isMustAlias() ||
!AS.isVolatile() && CurLoop->isLoopInvariant(AS.begin()->first)) { AS.isVolatile() || !CurLoop->isLoopInvariant(AS.begin()->first))
continue;
assert(!AS.empty() && assert(!AS.empty() &&
"Must alias set should have at least one pointer element in it!"); "Must alias set should have at least one pointer element in it!");
Value *V = AS.begin()->first; Value *V = AS.begin()->first;
@ -796,18 +798,21 @@ void LICM::FindPromotableValuesInLoop(
// Check that all of the pointers in the alias set have the same type. We // Check that all of the pointers in the alias set have the same type. We
// cannot (yet) promote a memory location that is loaded and stored in // cannot (yet) promote a memory location that is loaded and stored in
// different sizes. // different sizes.
{
bool PointerOk = true; bool PointerOk = true;
for (AliasSet::iterator I = AS.begin(), E = AS.end(); I != E; ++I) for (AliasSet::iterator I = AS.begin(), E = AS.end(); I != E; ++I)
if (V->getType() != I->first->getType()) { if (V->getType() != I->first->getType()) {
PointerOk = false; PointerOk = false;
break; break;
} }
if (!PointerOk)
continue;
}
// If one use of value V inside the loop is safe then it is OK to promote // If one use of value V inside the loop is safe then it is OK to promote
// this value. On the otherside if there is not any unsafe use inside the // this value. On the otherside if there is not any unsafe use inside the
// loop then also it is OK to promote this value. Otherwise it is // loop then also it is OK to promote this value. Otherwise it is
// unsafe to promote this value. // unsafe to promote this value.
if (PointerOk) {
bool oneSafeUse = false; bool oneSafeUse = false;
bool oneUnsafeUse = false; bool oneUnsafeUse = false;
for(Value::use_iterator UI = V->use_begin(), UE = V->use_end(); for(Value::use_iterator UI = V->use_begin(), UE = V->use_end();
@ -815,6 +820,7 @@ void LICM::FindPromotableValuesInLoop(
Instruction *Use = dyn_cast<Instruction>(*UI); Instruction *Use = dyn_cast<Instruction>(*UI);
if (!Use || !CurLoop->contains(Use->getParent())) if (!Use || !CurLoop->contains(Use->getParent()))
continue; continue;
for (SmallVector<Instruction *, 4>::iterator for (SmallVector<Instruction *, 4>::iterator
ExitI = LoopExits.begin(), ExitE = LoopExits.end(); ExitI = LoopExits.begin(), ExitE = LoopExits.end();
ExitI != ExitE; ++ExitI) { ExitI != ExitE; ++ExitI) {
@ -822,8 +828,7 @@ void LICM::FindPromotableValuesInLoop(
if (!isa<PHINode>(Use) && DT->dominates(Use, Ex)) { if (!isa<PHINode>(Use) && DT->dominates(Use, Ex)) {
oneSafeUse = true; oneSafeUse = true;
break; break;
} } else
else
oneUnsafeUse = true; oneUnsafeUse = true;
} }
@ -831,15 +836,9 @@ void LICM::FindPromotableValuesInLoop(
break; break;
} }
if (oneSafeUse) if (!oneSafeUse && oneUnsafeUse)
PointerOk = true; continue;
else if (!oneUnsafeUse)
PointerOk = true;
else
PointerOk = false;
}
if (PointerOk) {
const Type *Ty = cast<PointerType>(V->getType())->getElementType(); const Type *Ty = cast<PointerType>(V->getType())->getElementType();
AllocaInst *AI = new AllocaInst(Ty, 0, V->getName()+".tmp", FnStart); AllocaInst *AI = new AllocaInst(Ty, 0, V->getName()+".tmp", FnStart);
PromotedValues.push_back(std::make_pair(AI, V)); PromotedValues.push_back(std::make_pair(AI, V));
@ -853,8 +852,6 @@ void LICM::FindPromotableValuesInLoop(
DOUT << "LICM: Promoting value: " << *V << "\n"; DOUT << "LICM: Promoting value: " << *V << "\n";
} }
} }
}
}
/// cloneBasicBlockAnalysis - Simple Analysis hook. Clone alias set info. /// cloneBasicBlockAnalysis - Simple Analysis hook. Clone alias set info.
void LICM::cloneBasicBlockAnalysis(BasicBlock *From, BasicBlock *To, Loop *L) { void LICM::cloneBasicBlockAnalysis(BasicBlock *From, BasicBlock *To, Loop *L) {