diff options
author | Chris Lattner <sabre@nondot.org> | 2005-05-14 06:20:08 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-05-14 06:20:08 +0000 |
commit | 4211e73c4905af413db7524f24414c16a7f69102 (patch) | |
tree | c28bb4bcc05743ea455cd645ff8ab71cca40275f /include/llvm/CodeGen | |
parent | 50f5a51f41d36c519de68ff11fbf7c7c76f45416 (diff) | |
download | external_llvm-4211e73c4905af413db7524f24414c16a7f69102.zip external_llvm-4211e73c4905af413db7524f24414c16a7f69102.tar.gz external_llvm-4211e73c4905af413db7524f24414c16a7f69102.tar.bz2 |
Add a way to construct an arbitrary node, cleanly.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22008 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/CodeGen')
-rw-r--r-- | include/llvm/CodeGen/SelectionDAG.h | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/include/llvm/CodeGen/SelectionDAG.h b/include/llvm/CodeGen/SelectionDAG.h index 26e11b6..26e7922 100644 --- a/include/llvm/CodeGen/SelectionDAG.h +++ b/include/llvm/CodeGen/SelectionDAG.h @@ -130,7 +130,8 @@ public: /// SDNode *getCall(std::vector<MVT::ValueType> &RetVals, SDOperand Chain, SDOperand Callee, bool isTailCall = false) { - SDNode *NN = new SDNode(isTailCall ? ISD::TAILCALL : ISD::CALL, Chain, Callee); + SDNode *NN = new SDNode(isTailCall ? ISD::TAILCALL : ISD::CALL, Chain, + Callee); NN->setValueTypes(RetVals); AllNodes.push_back(NN); return NN; @@ -140,7 +141,8 @@ public: /// where arguments are passed in physical registers. This destroys the /// RetVals and ArgsInRegs vectors. SDNode *getCall(std::vector<MVT::ValueType> &RetVals, SDOperand Chain, - SDOperand Callee, std::vector<SDOperand> &ArgsInRegs, bool isTailCall = false) { + SDOperand Callee, std::vector<SDOperand> &ArgsInRegs, + bool isTailCall = false) { ArgsInRegs.insert(ArgsInRegs.begin(), Callee); ArgsInRegs.insert(ArgsInRegs.begin(), Chain); SDNode *NN = new SDNode(isTailCall ? ISD::TAILCALL : ISD::CALL, ArgsInRegs); @@ -169,6 +171,8 @@ public: SDOperand N1, SDOperand N2, SDOperand N3, SDOperand N4); SDOperand getNode(unsigned Opcode, MVT::ValueType VT, std::vector<SDOperand> &Children); + SDOperand getNode(unsigned Opcode, std::vector<MVT::ValueType> &ResultTys, + std::vector<SDOperand> &Ops); // getNode - These versions take an extra value type for extending and // truncating loads, stores, rounds, extends etc. @@ -182,6 +186,7 @@ public: SDOperand N2, SDOperand N3, SDOperand N4, MVT::ValueType EVT); + /// getLoad - Loads are not normal binary operators: their result type is not /// determined by their operands, and they produce a value AND a token chain. /// @@ -220,6 +225,11 @@ private: std::map<int, SDNode*> FrameIndices; std::map<unsigned, SDNode*> ConstantPoolIndices; std::map<MachineBasicBlock *, SDNode*> BBNodes; + std::map<std::pair<unsigned, + std::pair<std::vector<MVT::ValueType>, + std::vector<SDOperand> > >, + SDNode*> ArbitraryNodes; + std::map<std::string, SDNode*> ExternalSymbols; struct EVTStruct { unsigned Opcode; |