diff options
author | Chris Lattner <sabre@nondot.org> | 2004-02-29 22:24:41 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-02-29 22:24:41 +0000 |
commit | 2de229f31b3341fd2484a922c008148f243fa968 (patch) | |
tree | c0d111fb7e06eed09d74cd3adab3e05c8c18f6f9 /llvm | |
parent | 9c9a4c4abdf180754c1f07395d8e07b8ce617416 (diff) | |
download | bcm5719-llvm-2de229f31b3341fd2484a922c008148f243fa968.tar.gz bcm5719-llvm-2de229f31b3341fd2484a922c008148f243fa968.zip |
Fix bug: test/Regression/Transforms/LowerInvoke/2004-02-29-PHICrash.llx
... which tickled the lowerinvoke pass because it used the BCE routines.
llvm-svn: 12012
Diffstat (limited to 'llvm')
-rw-r--r-- | llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp b/llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp index 178e8ca1957..8e00f9c613e 100644 --- a/llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp +++ b/llvm/lib/Transforms/Utils/BreakCriticalEdges.cpp @@ -119,8 +119,11 @@ bool llvm::SplitCriticalEdge(TerminatorInst *TI, unsigned SuccNum, Pass *P) { // for (BasicBlock::iterator I = DestBB->begin(); PHINode *PN = dyn_cast<PHINode>(I); ++I) { - // We no longer enter through TIBB, now we come in through NewBB. - PN->replaceUsesOfWith(TIBB, NewBB); + // We no longer enter through TIBB, now we come in through NewBB. Revector + // exactly one entry in the PHI node that used to come from TIBB to come + // from NewBB. + Value *InVal = PN->removeIncomingValue(TIBB, false); + PN->addIncoming(InVal, NewBB); } // If we don't have a pass object, we can't update anything... |