diff options
author | Evan Cheng <evan.cheng@apple.com> | 2006-10-05 22:57:11 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2006-10-05 22:57:11 +0000 |
commit | ad071e1cd1a4b880019f1b2e827ee81867815f82 (patch) | |
tree | 94535c6ea772818b13e8b152950342446807511a /lib/CodeGen/SelectionDAG/SelectionDAG.cpp | |
parent | 9c78ecb511ba6c8f53579ce60bcc4ef782eb831c (diff) |
Add getStore() helper function to create ISD::STORE nodes.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30758 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/SelectionDAG.cpp')
-rw-r--r-- | lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index dc0d00f47e..e673175172 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -1490,6 +1490,21 @@ SDOperand SelectionDAG::getExtLoad(ISD::LoadExtType LType, MVT::ValueType VT, return getNode(ISD::LOADX, getVTList(VT, MVT::Other), Ops, 5); } +SDOperand SelectionDAG::getStore(SDOperand Chain, SDOperand Value, + SDOperand Ptr, SDOperand SV) { + SDVTList VTs = getVTList(MVT::Other); + SDOperand Ops[] = { Chain, Value, Ptr, SV }; + SelectionDAGCSEMap::NodeID ID(ISD::STORE, VTs, Ops, 4); + void *IP = 0; + if (SDNode *E = CSEMap.FindNodeOrInsertPos(ID, IP)) + return SDOperand(E, 0); + SDNode *N = new SDNode(ISD::STORE, Chain, Value, Ptr, SV); + N->setValueTypes(VTs); + CSEMap.InsertNode(N, IP); + AllNodes.push_back(N); + return SDOperand(N, 0); +} + SDOperand SelectionDAG::getVAArg(MVT::ValueType VT, SDOperand Chain, SDOperand Ptr, SDOperand SV) { @@ -1523,7 +1538,7 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT, // Also for ConstantFP? #endif if (Ops[0].getValueType() == EVT) // Normal store? - return getNode(ISD::STORE, VT, Ops[0], Ops[1], Ops[2], Ops[3]); + return getStore(Ops[0], Ops[1], Ops[2], Ops[3]); assert(Ops[1].getValueType() > EVT && "Not a truncation?"); assert(MVT::isInteger(Ops[1].getValueType()) == MVT::isInteger(EVT) && "Can't do FP-INT conversion!"); |