[llvm-commits] CVS: llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp

Evan Cheng evan.cheng at apple.com
Wed Aug 2 15:00:50 PDT 2006



Changes in directory llvm/lib/CodeGen/SelectionDAG:

SelectionDAG.cpp updated: 1.315 -> 1.316
---
Log message:

- Change AssignTopologicalOrder to return vector of SDNode* by reference.
- Tweak implementation to avoid using std::map.


---
Diffs of the changes:  (+22 -16)

 SelectionDAG.cpp |   38 ++++++++++++++++++++++----------------
 1 files changed, 22 insertions(+), 16 deletions(-)


Index: llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
diff -u llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp:1.315 llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp:1.316
--- llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp:1.315	Tue Aug  1 03:20:41 2006
+++ llvm/lib/CodeGen/SelectionDAG/SelectionDAG.cpp	Wed Aug  2 17:00:34 2006
@@ -28,7 +28,7 @@
 #include <set>
 #include <cmath>
 #include <algorithm>
-#include <deque>
+#include <queue>
 using namespace llvm;
 
 static bool isCommutativeBinOp(unsigned Opcode) {
@@ -2711,37 +2711,43 @@
 }
 
 /// AssignTopologicalOrder - Assign a unique node id for each node in the DAG
-/// based on their topological order. It returns a vector of the SDNodes* in
-/// assigned order.
-std::vector<SDNode*> SelectionDAG::AssignTopologicalOrder() {
+/// based on their topological order. It returns the maximum id and a vector
+/// of the SDNodes* in assigned order by reference.
+unsigned SelectionDAG::AssignTopologicalOrder(std::vector<SDNode*> &TopOrder) {
   unsigned DAGSize = AllNodes.size();
-  std::vector<SDNode*> TopOrder;
-  std::map<SDNode*, unsigned> InDegree;
-  std::deque<SDNode*> Sources;
+  std::vector<unsigned> InDegree(DAGSize);
+  std::vector<SDNode*> Sources;
+
+  // Use a two pass approach to avoid using a std::map which is slow.
+  unsigned Id = 0;
   for (allnodes_iterator I = allnodes_begin(),E = allnodes_end(); I != E; ++I){
     SDNode *N = I;
+    N->setNodeId(Id++);
     unsigned Degree = N->use_size();
-    InDegree[N] = Degree;
+    InDegree[N->getNodeId()] = Degree;
     if (Degree == 0)
-      Sources.push_back(I);
+      Sources.push_back(N);
   }
 
-  int Id = 0;
   while (!Sources.empty()) {
-    SDNode *N = Sources.front();
-    Sources.pop_front();
+    SDNode *N = Sources.back();
+    Sources.pop_back();
     TopOrder.push_back(N);
-    N->setNodeId(Id++);
     for (SDNode::op_iterator I = N->op_begin(), E = N->op_end(); I != E; ++I) {
       SDNode *P = I->Val;
-      unsigned Degree = InDegree[P] - 1;
+      unsigned Degree = --InDegree[P->getNodeId()];
       if (Degree == 0)
         Sources.push_back(P);
-      InDegree[P] = Degree;
     }
   }
 
-  return TopOrder;
+  // Second pass, assign the actual topological order as node ids.
+  Id = 0;
+  for (std::vector<SDNode*>::iterator TI = TopOrder.begin(),TE = TopOrder.end();
+       TI != TE; ++TI)
+    (*TI)->setNodeId(Id++);
+
+  return Id;
 }
 
 






More information about the llvm-commits mailing list