aboutsummaryrefslogtreecommitdiffstats
path: root/include/llvm/CodeGen
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-05-14 06:20:08 +0000
committerChris Lattner <sabre@nondot.org>2005-05-14 06:20:08 +0000
commit4211e73c4905af413db7524f24414c16a7f69102 (patch)
treec28bb4bcc05743ea455cd645ff8ab71cca40275f /include/llvm/CodeGen
parent50f5a51f41d36c519de68ff11fbf7c7c76f45416 (diff)
downloadexternal_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.h14
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;