[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