diff options
author | Bill Wendling <isanbard@gmail.com> | 2011-08-15 23:19:54 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2011-08-15 23:19:54 +0000 |
commit | 5a18b7c7c75e633c4cd1b76b81b4597e6a34a3d1 (patch) | |
tree | ffd691411f95c1e9bf7e3d044634e95c7f2ec98a /llvm/lib/Transforms/Scalar/CodeGenPrepare.cpp | |
parent | c5cc625c79e2b54035969fb205ac7d9847d62449 (diff) | |
download | bcm5719-llvm-5a18b7c7c75e633c4cd1b76b81b4597e6a34a3d1.tar.gz bcm5719-llvm-5a18b7c7c75e633c4cd1b76b81b4597e6a34a3d1.zip |
In places where it's using "getFirstNonPHI", skip the landingpad instruction if necessary.
llvm-svn: 137679
Diffstat (limited to 'llvm/lib/Transforms/Scalar/CodeGenPrepare.cpp')
-rw-r--r-- | llvm/lib/Transforms/Scalar/CodeGenPrepare.cpp | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/Scalar/CodeGenPrepare.cpp b/llvm/lib/Transforms/Scalar/CodeGenPrepare.cpp index c274b1595a7..fb4e8a4c9d8 100644 --- a/llvm/lib/Transforms/Scalar/CodeGenPrepare.cpp +++ b/llvm/lib/Transforms/Scalar/CodeGenPrepare.cpp @@ -469,7 +469,7 @@ static bool OptimizeCmpExpression(CmpInst *CI) { if (!InsertedCmp) { BasicBlock::iterator InsertPt = UserBB->getFirstNonPHI(); - + if (isa<LandingPadInst>(InsertPt)) ++InsertPt; // Skip landingpad inst. InsertedCmp = CmpInst::Create(CI->getOpcode(), CI->getPredicate(), CI->getOperand(0), @@ -561,10 +561,13 @@ bool CodeGenPrepare::OptimizeCallInst(CallInst *CI) { (DVI->getParent() != VI->getParent() || DT->dominates(DVI, VI))) { DEBUG(dbgs() << "Moving Debug Value before :\n" << *DVI << ' ' << *VI); DVI->removeFromParent(); - if (isa<PHINode>(VI)) - DVI->insertBefore(VI->getParent()->getFirstNonPHI()); - else + if (isa<PHINode>(VI)) { + BasicBlock::iterator InsertPt = VI->getParent()->getFirstNonPHI(); + if (isa<LandingPadInst>(InsertPt)) ++InsertPt; + DVI->insertBefore(InsertPt); + } else { DVI->insertAfter(VI); + } return true; } @@ -1061,7 +1064,7 @@ bool CodeGenPrepare::OptimizeExtUses(Instruction *I) { if (!InsertedTrunc) { BasicBlock::iterator InsertPt = UserBB->getFirstNonPHI(); - + if (isa<LandingPadInst>(InsertPt)) ++InsertPt; InsertedTrunc = new TruncInst(I, Src->getType(), "", InsertPt); } |