summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms
diff options
context:
space:
mode:
authorBalaram Makam <bmakam@codeaurora.org>2017-10-26 15:04:53 +0000
committerBalaram Makam <bmakam@codeaurora.org>2017-10-26 15:04:53 +0000
commit9ee942f4814dd5a12cc37eb0be9e1734c4f0cfe4 (patch)
tree4bc90c10045fbd2759dd91ac78605903240b8fb3 /llvm/lib/Transforms
parentc70d28bff522332b0db2a7466b627fd4cff7c55d (diff)
downloadbcm5719-llvm-9ee942f4814dd5a12cc37eb0be9e1734c4f0cfe4.tar.gz
bcm5719-llvm-9ee942f4814dd5a12cc37eb0be9e1734c4f0cfe4.zip
Reapply r316582 [Local] Fix a bug in the domtree update logic for MergeBasicBlockIntoOnlyPred.
Summary: This reverts r316612 to reapply r316582. The buildbot failure was unrelated to this commit. Reviewers: Subscribers: llvm-svn: 316669
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r--llvm/lib/Transforms/Utils/Local.cpp10
1 files changed, 7 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/Utils/Local.cpp b/llvm/lib/Transforms/Utils/Local.cpp
index fd3367710f3..8c643c93ec4 100644
--- a/llvm/lib/Transforms/Utils/Local.cpp
+++ b/llvm/lib/Transforms/Utils/Local.cpp
@@ -649,9 +649,13 @@ void llvm::MergeBasicBlockIntoOnlyPred(BasicBlock *DestBB, DominatorTree *DT) {
DestBB->moveAfter(PredBB);
if (DT) {
- BasicBlock *PredBBIDom = DT->getNode(PredBB)->getIDom()->getBlock();
- DT->changeImmediateDominator(DestBB, PredBBIDom);
- DT->eraseNode(PredBB);
+ // For some irreducible CFG we end up having forward-unreachable blocks
+ // so check if getNode returns a valid node before updating the domtree.
+ if (DomTreeNode *DTN = DT->getNode(PredBB)) {
+ BasicBlock *PredBBIDom = DTN->getIDom()->getBlock();
+ DT->changeImmediateDominator(DestBB, PredBBIDom);
+ DT->eraseNode(PredBB);
+ }
}
// Nuke BB.
PredBB->eraseFromParent();
OpenPOWER on IntegriCloud