1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 11:13:28 +01:00

add TAILCALL node

llvm-svn: 21956
This commit is contained in:
Chris Lattner 2005-05-13 18:40:17 +00:00
parent 681f9f0993
commit 97505aa9ac
2 changed files with 7 additions and 5 deletions

View File

@ -129,8 +129,8 @@ public:
/// getCall - Note that this destroys the vector of RetVals passed in.
///
SDNode *getCall(std::vector<MVT::ValueType> &RetVals, SDOperand Chain,
SDOperand Callee) {
SDNode *NN = new SDNode(ISD::CALL, Chain, Callee);
SDOperand Callee, bool isTailCall = false) {
SDNode *NN = new SDNode(isTailCall ? ISD::TAILCALL : ISD::CALL, Chain, Callee);
NN->setValueTypes(RetVals);
AllNodes.push_back(NN);
return NN;
@ -140,10 +140,10 @@ 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) {
SDOperand Callee, std::vector<SDOperand> &ArgsInRegs, bool isTailCall = false) {
ArgsInRegs.insert(ArgsInRegs.begin(), Callee);
ArgsInRegs.insert(ArgsInRegs.begin(), Chain);
SDNode *NN = new SDNode(ISD::CALL, ArgsInRegs);
SDNode *NN = new SDNode(isTailCall ? ISD::TAILCALL : ISD::CALL, ArgsInRegs);
NN->setValueTypes(RetVals);
AllNodes.push_back(NN);
return NN;

View File

@ -234,8 +234,10 @@ namespace ISD {
// CALL - Call to a function pointer. The first operand is the chain, the
// second is the destination function pointer (a GlobalAddress for a direct
// call). Arguments have already been lowered to explicit DAGs according to
// the calling convention in effect here.
// the calling convention in effect here. TAILCALL is the same as CALL, but
// the callee is known not to access the stack of the caller.
CALL,
TAILCALL,
// MEMSET/MEMCPY/MEMMOVE - The first operand is the chain, and the rest
// correspond to the operands of the LLVM intrinsic functions. The only