[llvm] b0bb214 - [NFCI][Local] removeUnreachableBlocks(): use DeleteDeadBlocks()
Roman Lebedev via llvm-commits
llvm-commits at lists.llvm.org
Wed May 19 10:39:00 PDT 2021
Author: Roman Lebedev
Date: 2021-05-19T20:38:30+03:00
New Revision: b0bb2149b3711d5d7c4fd3182a7eac3f8fc17341
URL: https://github.com/llvm/llvm-project/commit/b0bb2149b3711d5d7c4fd3182a7eac3f8fc17341
DIFF: https://github.com/llvm/llvm-project/commit/b0bb2149b3711d5d7c4fd3182a7eac3f8fc17341.diff
LOG: [NFCI][Local] removeUnreachableBlocks(): use DeleteDeadBlocks()
Added:
Modified:
llvm/lib/Transforms/Utils/Local.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Transforms/Utils/Local.cpp b/llvm/lib/Transforms/Utils/Local.cpp
index 2b42b50d5b12..0dc954532d33 100644
--- a/llvm/lib/Transforms/Utils/Local.cpp
+++ b/llvm/lib/Transforms/Utils/Local.cpp
@@ -2428,44 +2428,7 @@ bool llvm::removeUnreachableBlocks(Function &F, DomTreeUpdater *DTU,
if (MSSAU)
MSSAU->removeBlocks(BlocksToRemove);
- // Loop over all of the basic blocks that are up for removal, dropping all of
- // their internal references. Update DTU if available.
- std::vector<DominatorTree::UpdateType> Updates;
- for (auto *BB : BlocksToRemove) {
- SmallSet<BasicBlock *, 8> UniqueSuccessors;
- for (BasicBlock *Successor : successors(BB)) {
- // Only remove references to BB in reachable successors of BB.
- if (Reachable.count(Successor))
- Successor->removePredecessor(BB);
- if (DTU)
- UniqueSuccessors.insert(Successor);
- }
- BB->dropAllReferences();
- if (DTU) {
- Instruction *TI = BB->getTerminator();
- assert(TI && "Basic block should have a terminator");
- // Terminators like invoke can have users. We have to replace their users,
- // before removing them.
- if (!TI->use_empty())
- TI->replaceAllUsesWith(UndefValue::get(TI->getType()));
- TI->eraseFromParent();
- new UnreachableInst(BB->getContext(), BB);
- assert(succ_empty(BB) && "The successor list of BB isn't empty before "
- "applying corresponding DTU updates.");
- Updates.reserve(Updates.size() + UniqueSuccessors.size());
- for (auto *UniqueSuccessor : UniqueSuccessors)
- Updates.push_back({DominatorTree::Delete, BB, UniqueSuccessor});
- }
- }
-
- if (DTU) {
- DTU->applyUpdates(Updates);
- for (auto *BB : BlocksToRemove)
- DTU->deleteBB(BB);
- } else {
- for (auto *BB : BlocksToRemove)
- BB->eraseFromParent();
- }
+ DeleteDeadBlocks(BlocksToRemove.takeVector(), DTU);
return Changed;
}
More information about the llvm-commits
mailing list