[llvm-commits] CVS: llvm/lib/VMCore/PassManager.cpp

Devang Patel dpatel at apple.com
Tue Nov 14 13:49:50 PST 2006



Changes in directory llvm/lib/VMCore:

PassManager.cpp updated: 1.27 -> 1.28
---
Log message:

Copy initializeAnalysisImpl() implementation from PassManagerT.
Update LastUser to recursively walk required transitive set.


---
Diffs of the changes:  (+39 -2)

 PassManager.cpp |   41 +++++++++++++++++++++++++++++++++++++++--
 1 files changed, 39 insertions(+), 2 deletions(-)


Index: llvm/lib/VMCore/PassManager.cpp
diff -u llvm/lib/VMCore/PassManager.cpp:1.27 llvm/lib/VMCore/PassManager.cpp:1.28
--- llvm/lib/VMCore/PassManager.cpp:1.27	Mon Nov 13 21:05:08 2006
+++ llvm/lib/VMCore/PassManager.cpp	Tue Nov 14 15:49:36 2006
@@ -72,7 +72,7 @@
   // successfully use the getAnalysis() method to retrieve the
   // implementations it needs.
   //
-  inline void initializeAnalysisImpl(Pass *P) { /* TODO : Implement */ }
+ void initializeAnalysisImpl(Pass *P);
 
   inline std::vector<Pass *>::iterator passVectorBegin() { 
     return PassVector.begin(); 
@@ -82,7 +82,23 @@
     return PassVector.end();
   }
 
-  inline void setLastUser(Pass *P, Pass *LU) { LastUser[P] = LU; }
+  inline void setLastUser(Pass *P, Pass *LU) { 
+    LastUser[P] = LU; 
+    // TODO : Check if pass P is available.
+
+    // Prolong live range of analyses that are needed after an analysis pass
+    // is destroyed, for querying by subsequent passes
+    AnalysisUsage AnUsage;
+    P->getAnalysisUsage(AnUsage);
+    const std::vector<AnalysisID> &IDs = AnUsage.getRequiredTransitiveSet();
+    for (std::vector<AnalysisID>::const_iterator I = IDs.begin(),
+           E = IDs.end(); I != E; ++I) {
+      Pass *AnalysisPass = getAnalysisPass(*I); // getAnalysisPassFromManager(*I);
+      assert (AnalysisPass && "Analysis pass is not available");
+      setLastUser(AnalysisPass, LU);
+    }
+
+  }
 
 private:
   // Analysis required by the passes managed by this manager. This information
@@ -258,6 +274,8 @@
   // FIXME: What about duplicates ?
   RequiredAnalysis.insert(RequiredAnalysis.end(), RequiredSet.begin(), 
                           RequiredSet.end());
+
+  initializeAnalysisImpl(P);
 }
 
 /// Augement AvailableAnalysis by adding analysis made available by pass P.
@@ -329,6 +347,25 @@
   PassVector.push_back(P);
 }
 
+// All Required analyses should be available to the pass as it runs!  Here
+// we fill in the AnalysisImpls member of the pass so that it can
+// successfully use the getAnalysis() method to retrieve the
+// implementations it needs.
+//
+void CommonPassManagerImpl::initializeAnalysisImpl(Pass *P) {
+  AnalysisUsage AnUsage;
+  P->getAnalysisUsage(AnUsage);
+ 
+  for (std::vector<const PassInfo *>::const_iterator
+         I = AnUsage.getRequiredSet().begin(),
+         E = AnUsage.getRequiredSet().end(); I != E; ++I) {
+    Pass *Impl = getAnalysisPass(*I);
+    if (Impl == 0)
+      assert(0 && "Analysis used but not available!");
+    // TODO:  P->AnalysisImpls.push_back(std::make_pair(*I, Impl));
+  }
+}
+
 /// BasicBlockPassManager implementation
 
 /// Add pass P into PassVector and return true. If this pass is not






More information about the llvm-commits mailing list