diff options
author | Chris Lattner <sabre@nondot.org> | 2004-03-18 05:38:31 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-03-18 05:38:31 +0000 |
commit | d07f89969166750f96c0e3055e387ec82bba88c5 (patch) | |
tree | 283bd323c564ae57cea7fd3cea7be31342eaca95 /lib/Transforms/Utils/CodeExtractor.cpp | |
parent | fa3e86f93de3c55cfc1d4559e5a15d8f523fe946 (diff) |
Fix CodeExtractor/2004-03-17-UpdatePHIsOutsideRegion.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12489 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Utils/CodeExtractor.cpp')
-rw-r--r-- | lib/Transforms/Utils/CodeExtractor.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/lib/Transforms/Utils/CodeExtractor.cpp b/lib/Transforms/Utils/CodeExtractor.cpp index 4e131b4a11..9a47130c7b 100644 --- a/lib/Transforms/Utils/CodeExtractor.cpp +++ b/lib/Transforms/Utils/CodeExtractor.cpp @@ -371,6 +371,19 @@ Function *CodeExtractor::ExtractCodeRegion(const std::vector<BasicBlock*> &code) if (!BlocksToExtract.count(PN->getIncomingBlock(i))) PN->setIncomingBlock(i, newFuncRoot); + // Look at all successors of the codeReplacer block. If any of these blocks + // had PHI nodes in them, we need to update the "from" block to be the code + // replacer, not the original block in the extracted region. + std::vector<BasicBlock*> Succs(succ_begin(codeReplacer), + succ_end(codeReplacer)); + for (unsigned i = 0, e = Succs.size(); i != e; ++i) + for (BasicBlock::iterator I = Succs[i]->begin(); + PHINode *PN = dyn_cast<PHINode>(I); ++I) + for (unsigned i = 0, e = PN->getNumIncomingValues(); i != e; ++i) + if (BlocksToExtract.count(PN->getIncomingBlock(i))) + PN->setIncomingBlock(i, codeReplacer); + + DEBUG(if (verifyFunction(*newFunction)) abort()); return newFunction; } |