diff options
author | Andrew Trick <atrick@apple.com> | 2012-03-20 21:24:44 +0000 |
---|---|---|
committer | Andrew Trick <atrick@apple.com> | 2012-03-20 21:24:44 +0000 |
commit | 9c45706baf885a03fa2232e5b2a37d09a0dafea4 (patch) | |
tree | b0df49c2066ff989004b25b1e2d13a7d6581e892 /llvm/lib/Analysis | |
parent | 3660735e18ee673029141aa664481a91de8087e9 (diff) | |
download | bcm5719-llvm-9c45706baf885a03fa2232e5b2a37d09a0dafea4.tar.gz bcm5719-llvm-9c45706baf885a03fa2232e5b2a37d09a0dafea4.zip |
LSR: teach isSimplifiedLoopNest to handle PHI IVUsers.
llvm-svn: 153132
Diffstat (limited to 'llvm/lib/Analysis')
-rw-r--r-- | llvm/lib/Analysis/IVUsers.cpp | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/llvm/lib/Analysis/IVUsers.cpp b/llvm/lib/Analysis/IVUsers.cpp index 308729fcf12..463584db897 100644 --- a/llvm/lib/Analysis/IVUsers.cpp +++ b/llvm/lib/Analysis/IVUsers.cpp @@ -148,7 +148,14 @@ bool IVUsers::AddUsersIfInteresting(Instruction *I, // Only consider IVUsers that are dominated by simplified loop // headers. Otherwise, SCEVExpander will crash. - if (!isSimplifiedLoopNest(User->getParent(), DT, LI, SimpleLoopNests)) + BasicBlock *UseBB = User->getParent(); + // A phi's use is live out of its predecessor block. + if (PHINode *PHI = dyn_cast<PHINode>(User)) { + unsigned OperandNo = UI.getOperandNo(); + unsigned ValNo = PHINode::getIncomingValueNumForOperand(OperandNo); + UseBB = PHI->getIncomingBlock(ValNo); + } + if (!isSimplifiedLoopNest(UseBB, DT, LI, SimpleLoopNests)) return false; // Descend recursively, but not into PHI nodes outside the current loop. |