A few small clean-ups, and the addition of an LCSSA statistic.
authorOwen Anderson <resistor@mac.com>
Sat, 27 May 2006 00:31:37 +0000 (00:31 +0000)
committerOwen Anderson <resistor@mac.com>
Sat, 27 May 2006 00:31:37 +0000 (00:31 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28512 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Utils/LCSSA.cpp

index 43f331d71b2b2780b9dea5a5959290aaf25c2dee..c8d9487a6d429c532a7aa47f7ce442a43dcc9f05 100644 (file)
 #include "llvm/Pass.h"
 #include "llvm/Function.h"
 #include "llvm/Instructions.h"
+#include "llvm/ADT/Statistic.h"
 #include "llvm/Analysis/Dominators.h"
 #include "llvm/Analysis/LoopInfo.h"
 #include "llvm/Support/CFG.h"
 #include <algorithm>
-#include <set>
 #include <vector>
 
 using namespace llvm;
 
 namespace {
+  static Statistic<> NumLCSSA("lcssa", "Number of times LCSSA was applied");
+  
   class LCSSA : public FunctionPass {
   public:
+    
+  
     LoopInfo *LI;  // Loop information
     DominatorTree *DT;       // Dominator Tree for the current Loop...
     DominanceFrontier *DF;   // Current Dominance Frontier
@@ -51,7 +55,8 @@ namespace {
     bool visitSubloop(Loop* L);
     
     /// This transformation requires natural loop information & requires that
-    /// loop preheaders be inserted into the CFG...
+    /// loop preheaders be inserted into the CFG.  It maintains both of these,
+    /// as well as the CFG.  It also requires dominator information.
     ///
     virtual void getAnalysisUsage(AnalysisUsage &AU) const {
       AU.setPreservesCFG();
@@ -102,6 +107,7 @@ bool LCSSA::visitSubloop(Loop* L) {
   
   for (std::set<Instruction*>::iterator I = AffectedValues.begin(),
        E = AffectedValues.end(); I != E; ++I) {
+    ++NumLCSSA; // We are applying the transformation
     for (std::vector<BasicBlock*>::iterator BBI = exitBlocks.begin(),
          BBE = exitBlocks.end(); BBI != BBE; ++BBI) {
       PHINode *phi = new PHINode((*I)->getType(), "lcssa");