[llvm-branch-commits] [llvm-branch] r113851 - in /llvm/branches/release_28: ./ lib/Transforms/Utils/LoopSimplify.cpp test/Transforms/LoopSimplify/preserve-scev.ll

Bill Wendling isanbard at gmail.com
Tue Sep 14 13:57:16 PDT 2010


Author: void
Date: Tue Sep 14 15:57:16 2010
New Revision: 113851

URL: http://llvm.org/viewvc/llvm-project?rev=113851&view=rev
Log:
Approved by Chris:

$ svn merge -c 113057 https://llvm.org/svn/llvm-project/llvm/trunk
--- Merging r113057 into '.':
A    test/Transforms/LoopSimplify/preserve-scev.ll
U    lib/Transforms/Utils/LoopSimplify.cpp


Added:
    llvm/branches/release_28/test/Transforms/LoopSimplify/preserve-scev.ll
      - copied unchanged from r113057, llvm/trunk/test/Transforms/LoopSimplify/preserve-scev.ll
Modified:
    llvm/branches/release_28/   (props changed)
    llvm/branches/release_28/lib/Transforms/Utils/LoopSimplify.cpp

Propchange: llvm/branches/release_28/
------------------------------------------------------------------------------
--- svn:mergeinfo (original)
+++ svn:mergeinfo Tue Sep 14 15:57:16 2010
@@ -1,2 +1,2 @@
 /llvm/branches/Apple/Pertwee:110850,110961
-/llvm/trunk:113109,113123,113146,113158,113255,113257,113260,113297,113299,113303,113322,113345,113365-113366,113394,113483-113485,113576,113637,113820
+/llvm/trunk:113057,113109,113123,113146,113158,113255,113257,113260,113297,113299,113303,113322,113345,113365-113366,113394,113483-113485,113576,113637,113820

Modified: llvm/branches/release_28/lib/Transforms/Utils/LoopSimplify.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/release_28/lib/Transforms/Utils/LoopSimplify.cpp?rev=113851&r1=113850&r2=113851&view=diff
==============================================================================
--- llvm/branches/release_28/lib/Transforms/Utils/LoopSimplify.cpp (original)
+++ llvm/branches/release_28/lib/Transforms/Utils/LoopSimplify.cpp Tue Sep 14 15:57:16 2010
@@ -46,6 +46,7 @@
 #include "llvm/LLVMContext.h"
 #include "llvm/Type.h"
 #include "llvm/Analysis/AliasAnalysis.h"
+#include "llvm/Analysis/ScalarEvolution.h"
 #include "llvm/Analysis/Dominators.h"
 #include "llvm/Analysis/LoopPass.h"
 #include "llvm/Transforms/Utils/BasicBlockUtils.h"
@@ -71,6 +72,7 @@
     AliasAnalysis *AA;
     LoopInfo *LI;
     DominatorTree *DT;
+    ScalarEvolution *SE;
     Loop *L;
     virtual bool runOnLoop(Loop *L, LPPassManager &LPM);
 
@@ -83,7 +85,7 @@
       AU.addPreserved<LoopInfo>();
 
       AU.addPreserved<AliasAnalysis>();
-      AU.addPreserved("scalar-evolution");
+      AU.addPreserved<ScalarEvolution>();
       AU.addPreservedID(BreakCriticalEdgesID);  // No critical edges added.
       AU.addPreserved<DominanceFrontier>();
       AU.addPreservedID(LCSSAID);
@@ -121,6 +123,7 @@
   LI = &getAnalysis<LoopInfo>();
   AA = getAnalysisIfAvailable<AliasAnalysis>();
   DT = &getAnalysis<DominatorTree>();
+  SE = getAnalysisIfAvailable<ScalarEvolution>();
 
   Changed |= ProcessLoop(L, LPM);
 
@@ -532,6 +535,12 @@
 
   DEBUG(dbgs() << "LoopSimplify: Splitting out a new outer loop\n");
 
+  // If ScalarEvolution is around and knows anything about values in
+  // this loop, tell it to forget them, because we're about to
+  // substantially change it.
+  if (SE)
+    SE->forgetLoop(L);
+
   BasicBlock *Header = L->getHeader();
   BasicBlock *NewBB = SplitBlockPredecessors(Header, &OuterLoopPreds[0],
                                              OuterLoopPreds.size(),





More information about the llvm-branch-commits mailing list