diff options
| author | Nick Lewycky <nicholas@mxc.ca> | 2008-03-08 07:48:41 +0000 |
|---|---|---|
| committer | Nick Lewycky <nicholas@mxc.ca> | 2008-03-08 07:48:41 +0000 |
| commit | 35e92c7bea7836cbac1939c5caa9fb8d40f414b5 (patch) | |
| tree | fc3e392cb1f0f2d51fcf02fea2e1dc5f7a18930e | |
| parent | a53414fd79f78ee960740a15ea85307dee5b7ecf (diff) | |
| download | bcm5719-llvm-35e92c7bea7836cbac1939c5caa9fb8d40f414b5.tar.gz bcm5719-llvm-35e92c7bea7836cbac1939c5caa9fb8d40f414b5.zip | |
Not all users of a BB are Instructions any more.
llvm-svn: 48047
| -rw-r--r-- | llvm/include/llvm/BasicBlock.h | 8 | ||||
| -rw-r--r-- | llvm/lib/Transforms/Scalar/SCCP.cpp | 7 |
2 files changed, 9 insertions, 6 deletions
diff --git a/llvm/include/llvm/BasicBlock.h b/llvm/include/llvm/BasicBlock.h index 5a1c5a45b2b..4099d3bd32e 100644 --- a/llvm/include/llvm/BasicBlock.h +++ b/llvm/include/llvm/BasicBlock.h @@ -95,11 +95,6 @@ public: const Function *getParent() const { return Parent; } Function *getParent() { return Parent; } - /// use_back - Specialize the methods defined in Value, as we know that an - /// BasicBlock can only be used by Instructions (specifically PHI and terms). - Instruction *use_back() { return cast<Instruction>(*use_begin());} - const Instruction *use_back() const { return cast<Instruction>(*use_begin());} - /// getTerminator() - If this is a well formed basic block, then this returns /// a pointer to the terminator instruction. If it is not, then you get a /// null pointer back. @@ -187,6 +182,9 @@ public: /// update the PHI nodes that reside in the block. Note that this should be /// called while the predecessor still refers to this block. /// + /// DontDeleteUselessPHIs will keep PHIs that have one value or the same + /// value for all entries. + /// void removePredecessor(BasicBlock *Pred, bool DontDeleteUselessPHIs = false); /// splitBasicBlock - This splits a basic block into two at the specified diff --git a/llvm/lib/Transforms/Scalar/SCCP.cpp b/llvm/lib/Transforms/Scalar/SCCP.cpp index 561cdb1fbb4..b1c923c2bdc 100644 --- a/llvm/lib/Transforms/Scalar/SCCP.cpp +++ b/llvm/lib/Transforms/Scalar/SCCP.cpp @@ -45,7 +45,7 @@ using namespace llvm; STATISTIC(NumInstRemoved, "Number of instructions removed"); STATISTIC(NumDeadBlocks , "Number of basic blocks unreachable"); -STATISTIC(IPNumInstRemoved, "Number ofinstructions removed by IPSCCP"); +STATISTIC(IPNumInstRemoved, "Number of instructions removed by IPSCCP"); STATISTIC(IPNumDeadBlocks , "Number of basic blocks unreachable by IPSCCP"); STATISTIC(IPNumArgsElimed ,"Number of arguments constant propagated by IPSCCP"); STATISTIC(IPNumGlobalConst, "Number of globals found to be constant by IPSCCP"); @@ -1637,6 +1637,11 @@ bool IPSCCP::runOnModule(Module &M) { // If there are any PHI nodes in this successor, drop entries for BB now. BasicBlock *DeadBB = BlocksToErase[i]; while (!DeadBB->use_empty()) { + if (BasicBlock *PredBB = dyn_cast<BasicBlock>(DeadBB->use_back())) { + PredBB->setUnwindDest(NULL); + continue; + } + Instruction *I = cast<Instruction>(DeadBB->use_back()); bool Folded = ConstantFoldTerminator(I->getParent()); if (!Folded) { |

