[llvm-commits] [llvm] r52306 - /llvm/trunk/lib/CodeGen/LiveIntervalAnalysis.cpp

Owen Anderson resistor at mac.com
Mon Jun 16 00:10:50 PDT 2008


Author: resistor
Date: Mon Jun 16 02:10:49 2008
New Revision: 52306

URL: http://llvm.org/viewvc/llvm-project?rev=52306&view=rev
Log:
Make indexing empty basic blocks an option for the moment.

Modified:
    llvm/trunk/lib/CodeGen/LiveIntervalAnalysis.cpp

Modified: llvm/trunk/lib/CodeGen/LiveIntervalAnalysis.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/LiveIntervalAnalysis.cpp?rev=52306&r1=52305&r2=52306&view=diff

==============================================================================
--- llvm/trunk/lib/CodeGen/LiveIntervalAnalysis.cpp (original)
+++ llvm/trunk/lib/CodeGen/LiveIntervalAnalysis.cpp Mon Jun 16 02:10:49 2008
@@ -44,6 +44,8 @@
                                cl::init(true), cl::Hidden);
 static cl::opt<int> SplitLimit("split-limit",
                                cl::init(-1), cl::Hidden);
+static cl::opt<bool> EmptyBBIndex("empty-bb-index",
+                                  cl::init(false), cl::Hidden);
 
 STATISTIC(numIntervals, "Number of original intervals");
 STATISTIC(numIntervalsAfter, "Number of intervals after coalescing");
@@ -100,15 +102,23 @@
       i2miMap_.push_back(I);
       MIIndex += InstrSlots::NUM;
     }
-    
-    if (StartIdx == MIIndex) {
-      // Empty MBB
-      MIIndex += InstrSlots::NUM;
-      i2miMap_.push_back(0);
-    }
+
     // Set the MBB2IdxMap entry for this MBB.
-    MBB2IdxMap[MBB->getNumber()] = std::make_pair(StartIdx, MIIndex - 1);
-    Idx2MBBMap.push_back(std::make_pair(StartIdx, MBB));
+    if (!EmptyBBIndex) {
+      MBB2IdxMap[MBB->getNumber()] = (StartIdx == MIIndex)
+        ? std::make_pair(StartIdx, StartIdx)  // Empty MBB
+        : std::make_pair(StartIdx, MIIndex - 1);
+      Idx2MBBMap.push_back(std::make_pair(StartIdx, MBB));
+    } else {
+      if (StartIdx == MIIndex) {
+        // Empty MBB
+        MIIndex += InstrSlots::NUM;
+        i2miMap_.push_back(0);
+      }
+      
+      MBB2IdxMap[MBB->getNumber()] = std::make_pair(StartIdx, MIIndex - 1);
+      Idx2MBBMap.push_back(std::make_pair(StartIdx, MBB));
+    }
   }
   std::sort(Idx2MBBMap.begin(), Idx2MBBMap.end(), Idx2MBBCompare());
   
@@ -665,7 +675,9 @@
       MIIndex += InstrSlots::NUM;
     }
     
-    if (MBB->begin() == miEnd) MIIndex += InstrSlots::NUM; // Empty MBB
+    if (EmptyBBIndex) {
+      if (MBB->begin() == miEnd) MIIndex += InstrSlots::NUM; // Empty MBB
+    }
   }
 }
 





More information about the llvm-commits mailing list