diff options
author | Dan Gohman <gohman@apple.com> | 2009-03-23 15:49:37 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2009-03-23 15:49:37 +0000 |
commit | a9d71e131957df5f4a35f7033ac063291c26b739 (patch) | |
tree | e14fe6fe954405b2655f1aecffb1770c6a7e630b /lib/Analysis/LiveValues.cpp | |
parent | b45088cd96b9cc925b28b16bca285a151e04557a (diff) | |
download | external_llvm-a9d71e131957df5f4a35f7033ac063291c26b739.zip external_llvm-a9d71e131957df5f4a35f7033ac063291c26b739.tar.gz external_llvm-a9d71e131957df5f4a35f7033ac063291c26b739.tar.bz2 |
Enhance LiveValues to work on PHI operands.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67523 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/LiveValues.cpp')
-rw-r--r-- | lib/Analysis/LiveValues.cpp | 37 |
1 files changed, 24 insertions, 13 deletions
diff --git a/lib/Analysis/LiveValues.cpp b/lib/Analysis/LiveValues.cpp index 21ddf6b..7fc97c9 100644 --- a/lib/Analysis/LiveValues.cpp +++ b/lib/Analysis/LiveValues.cpp @@ -142,21 +142,32 @@ LiveValues::Memo &LiveValues::compute(const Value *V) { if (L->contains(UseBB)) break; - if (isa<PHINode>(U)) { - // The value is used by a PHI, so it is live-out of the defining block. - LiveOutOfDefBB = true; - } else if (UseBB != DefBB) { - // A use outside the defining block has been found. + // Search for live-through blocks. + const BasicBlock *BB; + if (const PHINode *PHI = dyn_cast<PHINode>(U)) { + // For PHI nodes, start the search at the incoming block paired with the + // incoming value, which must be dominated by the definition. + unsigned Num = PHI->getIncomingValueNumForOperand(I.getOperandNo()); + BB = PHI->getIncomingBlock(Num); + + // A PHI-node use means the value is live-out of it's defining block + // even if that block also contains the only use. LiveOutOfDefBB = true; + } else { + // Otherwise just start the search at the use. + BB = UseBB; + + // Note if the use is outside the defining block. + LiveOutOfDefBB |= UseBB != DefBB; + } - // Climb the immediate dominator tree from the use to the definition - // and mark all intermediate blocks as live-through. Don't do this if - // the user is a PHI because such users may not be dominated by the - // definition. - for (const BasicBlock *BB = getImmediateDominator(UseBB, DT); - BB != DefBB; BB = getImmediateDominator(BB, DT)) - if (!M.LiveThrough.insert(BB)) - break; + // Climb the immediate dominator tree from the use to the definition + // and mark all intermediate blocks as live-through. Don't do this if + // the user is a PHI because such users may not be dominated by the + // definition. + for (; BB != DefBB; BB = getImmediateDominator(BB, DT)) { + if (BB != UseBB && !M.LiveThrough.insert(BB)) + break; } } |