From 89c34637cb471609343c2e4f4b08a81779189aa7 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 14 May 2005 06:20:26 +0000 Subject: [PATCH] add a getNode() version that allows construction of any node type. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22009 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 42 ++++++++++++++++++----- 1 file changed, 33 insertions(+), 9 deletions(-) diff --git a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index 160afec63c5..90d00cfba8d 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -257,6 +257,13 @@ void SelectionDAG::DeleteNodeIfDead(SDNode *N, void *NodeSet) { BinaryOps.erase(std::make_pair(N->getOpcode(), std::make_pair(N->getOperand(0), N->getOperand(1)))); + else { + // Remove the node from the ArbitraryNodes map. + std::vector RV(N->value_begin(), N->value_end()); + std::vector Ops(N->op_begin(), N->op_end()); + ArbitraryNodes.erase(std::make_pair(N->getOpcode(), + std::make_pair(RV, Ops))); + } break; } @@ -1410,29 +1417,29 @@ SDOperand SelectionDAG::getSrcValue(const Value *V, int Offset) { } SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT, - std::vector &Children) { - switch (Children.size()) { + std::vector &Ops) { + switch (Ops.size()) { case 0: return getNode(Opcode, VT); - case 1: return getNode(Opcode, VT, Children[0]); - case 2: return getNode(Opcode, VT, Children[0], Children[1]); - case 3: return getNode(Opcode, VT, Children[0], Children[1], Children[2]); + case 1: return getNode(Opcode, VT, Ops[0]); + case 2: return getNode(Opcode, VT, Ops[0], Ops[1]); + case 3: return getNode(Opcode, VT, Ops[0], Ops[1], Ops[2]); default: break; } - ConstantSDNode *N1C = dyn_cast(Children[1].Val); + ConstantSDNode *N1C = dyn_cast(Ops[1].Val); switch (Opcode) { default: break; case ISD::BRCONDTWOWAY: if (N1C) if (N1C->getValue()) // Unconditional branch to true dest. - return getNode(ISD::BR, MVT::Other, Children[0], Children[2]); + return getNode(ISD::BR, MVT::Other, Ops[0], Ops[2]); else // Unconditional branch to false dest. - return getNode(ISD::BR, MVT::Other, Children[0], Children[3]); + return getNode(ISD::BR, MVT::Other, Ops[0], Ops[3]); break; } // FIXME: MEMOIZE!! - SDNode *N = new SDNode(Opcode, Children); + SDNode *N = new SDNode(Opcode, Ops); if (Opcode != ISD::ADD_PARTS && Opcode != ISD::SUB_PARTS) { N->setValueTypes(VT); } else { @@ -1443,6 +1450,23 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT, return SDOperand(N, 0); } +SDOperand SelectionDAG::getNode(unsigned Opcode, + std::vector &ResultTys, + std::vector &Ops) { + if (ResultTys.size() == 1) + return getNode(Opcode, ResultTys[0], Ops); + + + // Memoize the node. + SDNode *&N = ArbitraryNodes[std::make_pair(Opcode, std::make_pair(ResultTys, + Ops))]; + if (N) return SDOperand(N, 0); + N = new SDNode(Opcode, Ops); + N->setValueTypes(ResultTys); + return SDOperand(N, 0); +} + + SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT,SDOperand N1, MVT::ValueType EVT) {