From 27e9b4146417a9bdbade90d0ecc32c9567694a87 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Wed, 11 May 2005 18:57:39 +0000 Subject: [PATCH] Do not memoize ADJCALLSTACKDOWN nodes, provide a method to hack on them. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21871 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 27 ++++++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index d0809db38cc..3c3de2d4370 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -1192,9 +1192,17 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT, #endif } - SDNode *&N = BinaryOps[std::make_pair(Opcode, std::make_pair(N1, N2))]; - if (N) return SDOperand(N, 0); - N = new SDNode(Opcode, N1, N2); + // Memoize this node if possible. + SDNode *N; + if (Opcode != ISD::ADJCALLSTACKDOWN) { + SDNode *&BON = BinaryOps[std::make_pair(Opcode, std::make_pair(N1, N2))]; + if (BON) return SDOperand(BON, 0); + + BON = N = new SDNode(Opcode, N1, N2); + } else { + N = new SDNode(ISD::ADJCALLSTACKDOWN, N1, N2); + } + if (Opcode != ISD::READPORT && Opcode != ISD::READIO) N->setValueTypes(VT); @@ -1205,6 +1213,19 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT, return SDOperand(N, 0); } +// setAdjCallChain - This method changes the token chain of an ADJCALLSTACKDOWN +// node to be the specified operand. +void SDNode::setAdjCallChain(SDOperand N) { + assert(N.getValueType() == MVT::Other); + assert(getOpcode() == ISD::ADJCALLSTACKDOWN && "Cannot adjust this node!"); + + Operands[0].Val->removeUser(this); + Operands[0] = N; + N.Val->Uses.push_back(this); +} + + + SDOperand SelectionDAG::getLoad(MVT::ValueType VT, SDOperand Chain, SDOperand Ptr, SDOperand SV) {