summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Majnemer <david.majnemer@gmail.com>2015-10-27 19:48:28 +0000
committerDavid Majnemer <david.majnemer@gmail.com>2015-10-27 19:48:28 +0000
commit235acde953856a52b692cecf2c0484f2c30fdf43 (patch)
treee151dfe8fcb7c1fd3b80c2099f04f12d7dd06d54
parent0e631639be8c20dae7e8bf259c271ba97c825b0a (diff)
downloadbcm5719-llvm-235acde953856a52b692cecf2c0484f2c30fdf43.tar.gz
bcm5719-llvm-235acde953856a52b692cecf2c0484f2c30fdf43.zip
[ScalarEvolutionExpander] PHI on a catchpad can be used on both edges
A PHI on a catchpad might be used by both edges out of the catchpad, feeding back into a loop. In this case, just use the insertion point. Anything more clever would require new basic blocks or PHI placement. llvm-svn: 251442
-rw-r--r--llvm/lib/Analysis/ScalarEvolutionExpander.cpp16
-rw-r--r--llvm/test/Transforms/LoopStrengthReduce/funclet.ll42
2 files changed, 47 insertions, 11 deletions
diff --git a/llvm/lib/Analysis/ScalarEvolutionExpander.cpp b/llvm/lib/Analysis/ScalarEvolutionExpander.cpp
index 428d989285c..81316849847 100644
--- a/llvm/lib/Analysis/ScalarEvolutionExpander.cpp
+++ b/llvm/lib/Analysis/ScalarEvolutionExpander.cpp
@@ -87,7 +87,6 @@ Value *SCEVExpander::ReuseOrCreateCast(Value *V, Type *Ty,
}
static BasicBlock::iterator findInsertPointAfter(Instruction *I,
- DominatorTree &DT,
BasicBlock *MustDominate) {
BasicBlock::iterator IP = ++I->getIterator();
if (auto *II = dyn_cast<InvokeInst>(I))
@@ -107,12 +106,8 @@ static BasicBlock::iterator findInsertPointAfter(Instruction *I,
IP = CEPI->getUnwindDest()->getFirstNonPHI();
} else if (auto *CEPI = dyn_cast<CleanupEndPadInst>(IP)) {
IP = CEPI->getUnwindDest()->getFirstNonPHI();
- } else if (auto *CPI = dyn_cast<CatchPadInst>(IP)) {
- BasicBlock *NormalDest = CPI->getNormalDest();
- if (NormalDest == MustDominate || DT.dominates(NormalDest, MustDominate))
- IP = NormalDest->getFirstNonPHI();
- else
- IP = CPI->getUnwindDest()->getFirstNonPHI();
+ } else if (isa<CatchPadInst>(IP)) {
+ IP = MustDominate->getFirstInsertionPt();
} else {
llvm_unreachable("unexpected eh pad!");
}
@@ -177,8 +172,7 @@ Value *SCEVExpander::InsertNoopCastOfTo(Value *V, Type *Ty) {
// Cast the instruction immediately after the instruction.
Instruction *I = cast<Instruction>(V);
- BasicBlock::iterator IP =
- findInsertPointAfter(I, SE.DT, Builder.GetInsertBlock());
+ BasicBlock::iterator IP = findInsertPointAfter(I, Builder.GetInsertBlock());
return ReuseOrCreateCast(I, Ty, Op, IP);
}
@@ -1423,8 +1417,8 @@ Value *SCEVExpander::visitAddRecExpr(const SCEVAddRecExpr *S) {
NewOps[i] = SE.getAnyExtendExpr(S->op_begin()[i], CanonicalIV->getType());
Value *V = expand(SE.getAddRecExpr(NewOps, S->getLoop(),
S->getNoWrapFlags(SCEV::FlagNW)));
- BasicBlock::iterator NewInsertPt = findInsertPointAfter(
- cast<Instruction>(V), SE.DT, Builder.GetInsertBlock());
+ BasicBlock::iterator NewInsertPt =
+ findInsertPointAfter(cast<Instruction>(V), Builder.GetInsertBlock());
V = expandCodeFor(SE.getTruncateExpr(SE.getUnknown(V), Ty), nullptr,
&*NewInsertPt);
return V;
diff --git a/llvm/test/Transforms/LoopStrengthReduce/funclet.ll b/llvm/test/Transforms/LoopStrengthReduce/funclet.ll
index 60bec76e7e6..ba2234f3105 100644
--- a/llvm/test/Transforms/LoopStrengthReduce/funclet.ll
+++ b/llvm/test/Transforms/LoopStrengthReduce/funclet.ll
@@ -146,3 +146,45 @@ iter: ; preds = %loop_body
; CHECK: blah2:
; CHECK-NEXT: ptrtoint i8* %phi2 to i32
+
+define void @i() personality i32 (...)* @_except_handler3 {
+entry:
+ br label %throw
+
+throw: ; preds = %throw, %entry
+ %tmp96 = getelementptr inbounds i8, i8* undef, i32 1
+ invoke void @reserve()
+ to label %throw unwind label %catchpad
+
+catchpad: ; preds = %throw
+ %phi2 = phi i8* [ %tmp96, %throw ]
+ catchpad [] to label %cp_body unwind label %catchendpad
+
+cp_body:
+ br label %loop_head
+
+catchendpad:
+ catchendpad unwind label %cleanuppad
+
+cleanuppad:
+ cleanuppad []
+ br label %loop_head
+
+loop_head:
+ br label %loop_body
+
+loop_body: ; preds = %iter, %catchpad
+ %tmp99 = phi i8* [ %tmp101, %iter ], [ %phi2, %loop_head ]
+ %tmp100 = icmp eq i8* %tmp99, undef
+ br i1 %tmp100, label %unwind_out, label %iter
+
+iter: ; preds = %loop_body
+ %tmp101 = getelementptr inbounds i8, i8* %tmp99, i32 1
+ br i1 undef, label %unwind_out, label %loop_body
+
+unwind_out: ; preds = %iter, %loop_body
+ unreachable
+}
+
+; CHECK-LABEL: define void @i(
+; CHECK: ptrtoint i8* %phi2 to i32
OpenPOWER on IntegriCloud