mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-07 20:04:03 +00:00
Split condition does not have to be ICmpInst in all cases.
llvm-svn: 41822
This commit is contained in:
parent
82374f7476
commit
8394964f1a
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user