diff options
author | Evgeniy Stepanov <eugeni.stepanov@gmail.com> | 2013-03-22 08:43:04 +0000 |
---|---|---|
committer | Evgeniy Stepanov <eugeni.stepanov@gmail.com> | 2013-03-22 08:43:04 +0000 |
commit | 2a066afce50be640103c36932fd88eefe69d9dde (patch) | |
tree | 5b05e2e6a815c44019390784196c9109028a560f /llvm/lib/Transforms/Utils/Local.cpp | |
parent | f364bc63e71355a94ca1ef442e7e5af64973239d (diff) | |
download | bcm5719-llvm-2a066afce50be640103c36932fd88eefe69d9dde.tar.gz bcm5719-llvm-2a066afce50be640103c36932fd88eefe69d9dde.zip |
Fix llvm::removeUnreachableBlocks to handle unreachable loops.
llvm-svn: 177713
Diffstat (limited to 'llvm/lib/Transforms/Utils/Local.cpp')
-rw-r--r-- | llvm/lib/Transforms/Utils/Local.cpp | 19 |
1 files changed, 7 insertions, 12 deletions
diff --git a/llvm/lib/Transforms/Utils/Local.cpp b/llvm/lib/Transforms/Utils/Local.cpp index a54ee08b676..be80d34d960 100644 --- a/llvm/lib/Transforms/Utils/Local.cpp +++ b/llvm/lib/Transforms/Utils/Local.cpp @@ -985,22 +985,17 @@ bool llvm::removeUnreachableBlocks(Function &F) { if (Reachable.count(I)) continue; - // Remove the block as predecessor of all its reachable successors. - // Unreachable successors don't matter as they'll soon be removed, too. for (succ_iterator SI = succ_begin(I), SE = succ_end(I); SI != SE; ++SI) if (Reachable.count(*SI)) (*SI)->removePredecessor(I); + I->dropAllReferences(); + } - // Zap all instructions in this basic block. - while (!I->empty()) { - Instruction &Inst = I->back(); - if (!Inst.use_empty()) - Inst.replaceAllUsesWith(UndefValue::get(Inst.getType())); - I->getInstList().pop_back(); - } + for (Function::iterator I = llvm::next(F.begin()), E=F.end(); I != E;) + if (!Reachable.count(I)) + I = F.getBasicBlockList().erase(I); + else + ++I; - --I; - llvm::next(I)->eraseFromParent(); - } return true; } |