From: Chris Lattner Date: Sun, 4 Feb 2007 01:31:47 +0000 (+0000) Subject: Switch NodeMap from std::map to DenseMap, this speeds up isel by 2.3% X-Git-Tag: android-x86-6.0-r1~1003^2~37607 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=0da331fe0bff24e6c90c706ef8f1f1c3a8d90c2a;p=android-x86%2Fexternal-llvm.git Switch NodeMap from std::map to DenseMap, this speeds up isel by 2.3% git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33862 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index ad1f47c2dca..f0bd1420b20 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp @@ -354,7 +354,7 @@ namespace llvm { class SelectionDAGLowering { MachineBasicBlock *CurMBB; - std::map NodeMap; + DenseMap 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 @@ public: 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 @@ SDOperand SelectionDAGLowering::getValue(const Value *V) { if (Constant *C = const_cast(dyn_cast(V))) { if (ConstantExpr *CE = dyn_cast(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(C)) { return N = DAG.getGlobalAddress(GV, VT); } else if (isa(C)) { @@ -642,7 +643,8 @@ SDOperand SelectionDAGLowering::getValue(const Value *V) { // 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(C)->getZExtValue(),VT); @@ -890,6 +892,7 @@ void SelectionDAGLowering::FindMergedConditions(Value *Cond, else Condition = FPC; } else { + Condition = ISD::SETEQ; // silence warning. assert(0 && "Unknown compare instruction"); } @@ -1763,7 +1766,8 @@ void SelectionDAGLowering::visitAlloca(AllocaInst &I) { 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.