forked from OSchip/llvm-project
In places where it's using "getFirstNonPHI", skip the landingpad instruction if necessary.
llvm-svn: 137679
This commit is contained in:
parent
c5cc625c79
commit
5a18b7c7c7
|
|
@ -469,7 +469,7 @@ static bool OptimizeCmpExpression(CmpInst *CI) {
|
||||||
|
|
||||||
if (!InsertedCmp) {
|
if (!InsertedCmp) {
|
||||||
BasicBlock::iterator InsertPt = UserBB->getFirstNonPHI();
|
BasicBlock::iterator InsertPt = UserBB->getFirstNonPHI();
|
||||||
|
if (isa<LandingPadInst>(InsertPt)) ++InsertPt; // Skip landingpad inst.
|
||||||
InsertedCmp =
|
InsertedCmp =
|
||||||
CmpInst::Create(CI->getOpcode(),
|
CmpInst::Create(CI->getOpcode(),
|
||||||
CI->getPredicate(), CI->getOperand(0),
|
CI->getPredicate(), CI->getOperand(0),
|
||||||
|
|
@ -561,10 +561,13 @@ bool CodeGenPrepare::OptimizeCallInst(CallInst *CI) {
|
||||||
(DVI->getParent() != VI->getParent() || DT->dominates(DVI, VI))) {
|
(DVI->getParent() != VI->getParent() || DT->dominates(DVI, VI))) {
|
||||||
DEBUG(dbgs() << "Moving Debug Value before :\n" << *DVI << ' ' << *VI);
|
DEBUG(dbgs() << "Moving Debug Value before :\n" << *DVI << ' ' << *VI);
|
||||||
DVI->removeFromParent();
|
DVI->removeFromParent();
|
||||||
if (isa<PHINode>(VI))
|
if (isa<PHINode>(VI)) {
|
||||||
DVI->insertBefore(VI->getParent()->getFirstNonPHI());
|
BasicBlock::iterator InsertPt = VI->getParent()->getFirstNonPHI();
|
||||||
else
|
if (isa<LandingPadInst>(InsertPt)) ++InsertPt;
|
||||||
|
DVI->insertBefore(InsertPt);
|
||||||
|
} else {
|
||||||
DVI->insertAfter(VI);
|
DVI->insertAfter(VI);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1061,7 +1064,7 @@ bool CodeGenPrepare::OptimizeExtUses(Instruction *I) {
|
||||||
|
|
||||||
if (!InsertedTrunc) {
|
if (!InsertedTrunc) {
|
||||||
BasicBlock::iterator InsertPt = UserBB->getFirstNonPHI();
|
BasicBlock::iterator InsertPt = UserBB->getFirstNonPHI();
|
||||||
|
if (isa<LandingPadInst>(InsertPt)) ++InsertPt;
|
||||||
InsertedTrunc = new TruncInst(I, Src->getType(), "", InsertPt);
|
InsertedTrunc = new TruncInst(I, Src->getType(), "", InsertPt);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue