From: Chris Lattner Date: Thu, 27 Feb 2003 21:59:36 +0000 (+0000) Subject: Fix bug: 2003-02-27-StoreSinkPHIs.ll X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=8601a9bf54049389e0e0b6a907dc51069dcadc60;p=oota-llvm.git Fix bug: 2003-02-27-StoreSinkPHIs.ll git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5658 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/LICM.cpp b/lib/Transforms/Scalar/LICM.cpp index 0febce48230..534a073abe1 100644 --- a/lib/Transforms/Scalar/LICM.cpp +++ b/lib/Transforms/Scalar/LICM.cpp @@ -437,7 +437,10 @@ void LICM::PromoteValuesInLoop() { for (succ_iterator SI = succ_begin(*I), SE = succ_end(*I); SI != SE; ++SI) if (!CurLoop->contains(*SI)) { // Copy all of the allocas into their memory locations... - Instruction *InsertPos = (*SI)->begin(); + BasicBlock::iterator BI = (*SI)->begin(); + while (isa(*BI)) + ++BI; // Skip over all of the phi nodes in the block... + Instruction *InsertPos = BI; for (unsigned i = 0, e = PromotedValues.size(); i != e; ++i) { // Load from the alloca... LoadInst *LI = new LoadInst(PromotedValues[i].first, "", InsertPos);