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

Chris Lattner sabre at nondot.org
Sat Feb 3 17:32:03 PST 2007



Changes in directory llvm/lib/CodeGen/SelectionDAG:

SelectionDAGISel.cpp updated: 1.355 -> 1.356
---
Log message:

Switch NodeMap from std::map to DenseMap, this speeds up isel by 2.3%


---
Diffs of the changes:  (+11 -7)

 SelectionDAGISel.cpp |   18 +++++++++++-------
 1 files changed, 11 insertions(+), 7 deletions(-)


Index: llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
diff -u llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:1.355 llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:1.356
--- llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:1.355	Thu Feb  1 20:16:22 2007
+++ llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp	Sat Feb  3 19:31:47 2007
@@ -354,7 +354,7 @@
 class SelectionDAGLowering {
   MachineBasicBlock *CurMBB;
 
-  std::map<const Value*, SDOperand> NodeMap;
+  DenseMap<const Value*, SDOperand> NodeMap;
 
   /// PendingLoads - Loads are not emitted to the program immediately.  We bunch
   /// them up and then emit token factor nodes when possible.  This allows us to
@@ -467,10 +467,10 @@
 
   SDOperand getValue(const Value *V);
 
-  const SDOperand &setValue(const Value *V, SDOperand NewN) {
+  void setValue(const Value *V, SDOperand NewN) {
     SDOperand &N = NodeMap[V];
     assert(N.Val == 0 && "Already set a value for this node!");
-    return N = NewN;
+    N = NewN;
   }
   
   RegsForValue GetRegistersForValue(const std::string &ConstrCode,
@@ -593,8 +593,9 @@
   if (Constant *C = const_cast<Constant*>(dyn_cast<Constant>(V))) {
     if (ConstantExpr *CE = dyn_cast<ConstantExpr>(C)) {
       visit(CE->getOpcode(), *CE);
-      assert(N.Val && "visit didn't populate the ValueMap!");
-      return N;
+      SDOperand N1 = NodeMap[V];
+      assert(N1.Val && "visit didn't populate the ValueMap!");
+      return N1;
     } else if (GlobalValue *GV = dyn_cast<GlobalValue>(C)) {
       return N = DAG.getGlobalAddress(GV, VT);
     } else if (isa<ConstantPointerNull>(C)) {
@@ -642,7 +643,8 @@
       // Create a VBUILD_VECTOR node with generic Vector type.
       Ops.push_back(DAG.getConstant(NumElements, MVT::i32));
       Ops.push_back(DAG.getValueType(PVT));
-      return N = DAG.getNode(ISD::VBUILD_VECTOR,MVT::Vector,&Ops[0],Ops.size());
+      return NodeMap[V] = DAG.getNode(ISD::VBUILD_VECTOR, MVT::Vector, &Ops[0],
+                                      Ops.size());
     } else {
       // Canonicalize all constant ints to be unsigned.
       return N = DAG.getConstant(cast<ConstantInt>(C)->getZExtValue(),VT);
@@ -890,6 +892,7 @@
         else 
           Condition = FPC;
       } else {
+        Condition = ISD::SETEQ; // silence warning.
         assert(0 && "Unknown compare instruction");
       }
       
@@ -1763,7 +1766,8 @@
   const MVT::ValueType *VTs = DAG.getNodeValueTypes(AllocSize.getValueType(),
                                                     MVT::Other);
   SDOperand DSA = DAG.getNode(ISD::DYNAMIC_STACKALLOC, VTs, 2, Ops, 3);
-  DAG.setRoot(setValue(&I, DSA).getValue(1));
+  setValue(&I, DSA);
+  DAG.setRoot(DSA.getValue(1));
 
   // Inform the Frame Information that we have just allocated a variable-sized
   // object.






More information about the llvm-commits mailing list