Skip to content
Snippets Groups Projects
Commit be33e8d5 authored by Bill Wendling's avatar Bill Wendling
Browse files

A few places where we want to skip the landingpad instruction for insertion.

llvm-svn: 137712
parent 2263c109
No related branches found
No related tags found
No related merge requests found
...@@ -1323,8 +1323,11 @@ Value *SCEVExpander::expand(const SCEV *S) { ...@@ -1323,8 +1323,11 @@ Value *SCEVExpander::expand(const SCEV *S) {
// If the SCEV is computable at this level, insert it into the header // If the SCEV is computable at this level, insert it into the header
// after the PHIs (and after any other instructions that we've inserted // after the PHIs (and after any other instructions that we've inserted
// there) so that it is guaranteed to dominate any user inside the loop. // there) so that it is guaranteed to dominate any user inside the loop.
if (L && SE.hasComputableLoopEvolution(S, L) && !PostIncLoops.count(L)) if (L && SE.hasComputableLoopEvolution(S, L) && !PostIncLoops.count(L)) {
InsertPt = L->getHeader()->getFirstNonPHI(); InsertPt = L->getHeader()->getFirstNonPHI();
if (isa<LandingPadInst>(InsertPt))
InsertPt = llvm::next(BasicBlock::iterator(InsertPt));
}
while (isInsertedInstruction(InsertPt) || isa<DbgInfoIntrinsic>(InsertPt)) while (isInsertedInstruction(InsertPt) || isa<DbgInfoIntrinsic>(InsertPt))
InsertPt = llvm::next(BasicBlock::iterator(InsertPt)); InsertPt = llvm::next(BasicBlock::iterator(InsertPt));
break; break;
......
...@@ -601,6 +601,7 @@ bool InstCombiner::SimplifyStoreAtEndOfBlock(StoreInst &SI) { ...@@ -601,6 +601,7 @@ bool InstCombiner::SimplifyStoreAtEndOfBlock(StoreInst &SI) {
// Advance to a place where it is safe to insert the new store and // Advance to a place where it is safe to insert the new store and
// insert it. // insert it.
BBI = DestBB->getFirstNonPHI(); BBI = DestBB->getFirstNonPHI();
if (isa<LandingPadInst>(BBI)) ++BBI;
StoreInst *NewSI = new StoreInst(MergedVal, SI.getOperand(1), StoreInst *NewSI = new StoreInst(MergedVal, SI.getOperand(1),
SI.isVolatile(), SI.isVolatile(),
SI.getAlignment(), SI.getAlignment(),
......
...@@ -505,7 +505,9 @@ bool GCOVProfiler::emitProfileArcs(DebugInfoFinder &DIF) { ...@@ -505,7 +505,9 @@ bool GCOVProfiler::emitProfileArcs(DebugInfoFinder &DIF) {
} }
for (int i = 0, e = ComplexEdgeSuccs.size(); i != e; ++i) { for (int i = 0, e = ComplexEdgeSuccs.size(); i != e; ++i) {
// call runtime to perform increment // call runtime to perform increment
IRBuilder<> Builder(ComplexEdgeSuccs[i+1]->getFirstNonPHI()); BasicBlock::iterator InsertPt = ComplexEdgeSuccs[i+1]->getFirstNonPHI();
if (isa<LandingPadInst>(InsertPt)) ++InsertPt;
IRBuilder<> Builder(InsertPt);
Value *CounterPtrArray = Value *CounterPtrArray =
Builder.CreateConstInBoundsGEP2_64(EdgeTable, 0, Builder.CreateConstInBoundsGEP2_64(EdgeTable, 0,
i * ComplexEdgePreds.size()); i * ComplexEdgePreds.size());
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment