From: Chris Lattner Date: Sun, 18 Apr 2004 22:15:13 +0000 (+0000) Subject: Loop exit sets are no longer explicitly held, they are dynamically computed on demand. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=5fa802fe279f10f402e039bc931aa57c0e424bf5;p=oota-llvm.git Loop exit sets are no longer explicitly held, they are dynamically computed on demand. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@13046 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/LICM.cpp b/lib/Transforms/Scalar/LICM.cpp index 0bf94101d55..a02b66b20d6 100644 --- a/lib/Transforms/Scalar/LICM.cpp +++ b/lib/Transforms/Scalar/LICM.cpp @@ -436,7 +436,8 @@ bool LICM::isLoopInvariantInst(Instruction &I) { void LICM::sink(Instruction &I) { DEBUG(std::cerr << "LICM sinking instruction: " << I); - const std::vector &ExitBlocks = CurLoop->getExitBlocks(); + std::vector ExitBlocks; + CurLoop->getExitBlocks(ExitBlocks); if (isa(I)) ++NumMovedLoads; else if (isa(I)) ++NumMovedCalls; @@ -593,7 +594,8 @@ bool LICM::isSafeToExecuteUnconditionally(Instruction &Inst) { return true; // Get the exit blocks for the current loop. - const std::vector &ExitBlocks = CurLoop->getExitBlocks(); + std::vector ExitBlocks; + CurLoop->getExitBlocks(ExitBlocks); // For each exit block, get the DT node and walk up the DT until the // instruction's basic block is found or we exit the loop. @@ -667,7 +669,8 @@ void LICM::PromoteValuesInLoop() { // std::set ProcessedBlocks; - const std::vector &ExitBlocks = CurLoop->getExitBlocks(); + std::vector ExitBlocks; + CurLoop->getExitBlocks(ExitBlocks); for (unsigned i = 0, e = ExitBlocks.size(); i != e; ++i) if (ProcessedBlocks.insert(ExitBlocks[i]).second) { // Copy all of the allocas into their memory locations...