summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-02-04 01:31:47 +0000
committerChris Lattner <sabre@nondot.org>2007-02-04 01:31:47 +0000
commit0da331fe0bff24e6c90c706ef8f1f1c3a8d90c2a (patch)
tree89ad673981f56abf39ca140e8793afe0e2497e20 /lib
parent0ed44170752b85c3dd3bbf95459dd2668864f5ec (diff)
downloadllvm-0da331fe0bff24e6c90c706ef8f1f1c3a8d90c2a.tar.gz
llvm-0da331fe0bff24e6c90c706ef8f1f1c3a8d90c2a.tar.bz2
llvm-0da331fe0bff24e6c90c706ef8f1f1c3a8d90c2a.tar.xz
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
Diffstat (limited to 'lib')
-rw-r--r--lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp18
1 files changed, 11 insertions, 7 deletions
diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
index ad1f47c2dc..f0bd1420b2 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<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 @@ 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<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 @@ 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<ConstantInt>(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.