Split condition does not have to be ICmpInst in all cases.

llvm-svn: 41822
This commit is contained in:
Devang Patel 2007-09-11 00:12:56 +00:00
parent 82374f7476
commit 8394964f1a

View File

@ -64,8 +64,8 @@ namespace {
// Induction variable's range is split at this value. // Induction variable's range is split at this value.
Value *SplitValue; Value *SplitValue;
// This compare instruction compares IndVar against SplitValue. // This instruction compares IndVar against SplitValue.
ICmpInst *SplitCondition; Instruction *SplitCondition;
// True if after loop index split, first loop will execute split condition's // True if after loop index split, first loop will execute split condition's
// true branch. // true branch.
@ -221,7 +221,8 @@ bool LoopIndexSplit::runOnLoop(Loop *IncomingLoop, LPPassManager &LPM_Ref) {
for (SmallVector<SplitInfo, 4>::iterator SI = SplitData.begin(), for (SmallVector<SplitInfo, 4>::iterator SI = SplitData.begin(),
E = SplitData.end(); SI != E;) { E = SplitData.end(); SI != E;) {
SplitInfo &SD = *SI; SplitInfo &SD = *SI;
if (SD.SplitCondition->getPredicate() == ICmpInst::ICMP_EQ) { ICmpInst *CI = dyn_cast<ICmpInst>(SD.SplitCondition);
if (CI && CI->getPredicate() == ICmpInst::ICMP_EQ) {
Changed = processOneIterationLoop(SD); Changed = processOneIterationLoop(SD);
if (Changed) { if (Changed) {
++NumIndexSplit; ++NumIndexSplit;
@ -790,7 +791,8 @@ bool LoopIndexSplit::safeSplitCondition(SplitInfo &SD) {
/// based on split value. /// based on split value.
void LoopIndexSplit::calculateLoopBounds(SplitInfo &SD) { void LoopIndexSplit::calculateLoopBounds(SplitInfo &SD) {
ICmpInst::Predicate SP = SD.SplitCondition->getPredicate(); ICmpInst *SC = cast<ICmpInst>(SD.SplitCondition);
ICmpInst::Predicate SP = SC->getPredicate();
const Type *Ty = SD.SplitValue->getType(); const Type *Ty = SD.SplitValue->getType();
bool Sign = ExitCondition->isSignedPredicate(); bool Sign = ExitCondition->isSignedPredicate();
BasicBlock *Preheader = L->getLoopPreheader(); BasicBlock *Preheader = L->getLoopPreheader();
@ -1140,7 +1142,8 @@ bool LoopIndexSplit::splitLoop(SplitInfo &SD) {
ICmpInst *B_SplitCondition = cast<ICmpInst>(ValueMap[SD.SplitCondition]); ICmpInst *B_SplitCondition = cast<ICmpInst>(ValueMap[SD.SplitCondition]);
moveExitCondition(A_SplitCondBlock, A_ActiveBranch, A_ExitBlock, ExitCondition, moveExitCondition(A_SplitCondBlock, A_ActiveBranch, A_ExitBlock, ExitCondition,
SD.SplitCondition, IndVar, IndVarIncrement, ALoop); cast<ICmpInst>(SD.SplitCondition), IndVar, IndVarIncrement,
ALoop);
moveExitCondition(B_SplitCondBlock, B_ActiveBranch, B_ExitBlock, B_ExitCondition, moveExitCondition(B_SplitCondBlock, B_ActiveBranch, B_ExitBlock, B_ExitCondition,
B_SplitCondition, B_IndVar, B_IndVarIncrement, BLoop); B_SplitCondition, B_IndVar, B_IndVarIncrement, BLoop);