Loop exit sets are no longer explicitly held, they are dynamically computed on demand.
authorChris Lattner <sabre@nondot.org>
Sun, 18 Apr 2004 22:15:13 +0000 (22:15 +0000)
committerChris Lattner <sabre@nondot.org>
Sun, 18 Apr 2004 22:15:13 +0000 (22:15 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@13046 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/LICM.cpp

index 0bf94101d55d056a0697753255231edc9b94fed8..a02b66b20d6cc30f395984e918035d41c18f3fdb 100644 (file)
@@ -436,7 +436,8 @@ bool LICM::isLoopInvariantInst(Instruction &I) {
 void LICM::sink(Instruction &I) {
   DEBUG(std::cerr << "LICM sinking instruction: " << I);
 
-  const std::vector<BasicBlock*> &ExitBlocks = CurLoop->getExitBlocks();
+  std::vector<BasicBlock*> ExitBlocks;
+  CurLoop->getExitBlocks(ExitBlocks);
 
   if (isa<LoadInst>(I)) ++NumMovedLoads;
   else if (isa<CallInst>(I)) ++NumMovedCalls;
@@ -593,7 +594,8 @@ bool LICM::isSafeToExecuteUnconditionally(Instruction &Inst) {
     return true;
 
   // Get the exit blocks for the current loop.
-  const std::vector<BasicBlock*> &ExitBlocks = CurLoop->getExitBlocks();
+  std::vector<BasicBlock*> 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<BasicBlock*> ProcessedBlocks;
 
-  const std::vector<BasicBlock*> &ExitBlocks = CurLoop->getExitBlocks();
+  std::vector<BasicBlock*> 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...