diff options
author | Balaram Makam <bmakam@codeaurora.org> | 2017-10-25 14:55:48 +0000 |
---|---|---|
committer | Balaram Makam <bmakam@codeaurora.org> | 2017-10-25 14:55:48 +0000 |
commit | 925ddf1a93d25fb11452d8e08042a2a9f5337e78 (patch) | |
tree | e01592b1332df53a7326020f63ac8cee1c41b798 /llvm/lib/Transforms | |
parent | 3e94e441d6a66784a41fe3583e8a427a47436f58 (diff) | |
download | bcm5719-llvm-925ddf1a93d25fb11452d8e08042a2a9f5337e78.tar.gz bcm5719-llvm-925ddf1a93d25fb11452d8e08042a2a9f5337e78.zip |
[Local] Fix a bug in the domtree update logic for MergeBasicBlockIntoOnlyPred.
Summary: For some irreducible CFG the domtree nodes might be dead, do not update domtree for dead nodes.
Reviewers: kuhar, dberlin, hfinkel
Reviewed By: kuhar
Subscribers: llvm-commits, mcrosier
Differential Revision: https://reviews.llvm.org/D38960
llvm-svn: 316582
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r-- | llvm/lib/Transforms/Utils/Local.cpp | 10 |
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(); |