From 1a61fa460f4dcd3effb0e6d6d7caad68d186ae39 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 15 May 2005 06:07:10 +0000 Subject: [PATCH] don't reserve space for tailcall arg areas. It explicitly managed. llvm-svn: 22050 --- llvm/lib/Target/X86/X86ISelPattern.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/llvm/lib/Target/X86/X86ISelPattern.cpp b/llvm/lib/Target/X86/X86ISelPattern.cpp index 28534a283834..1d30608d34c8 100644 --- a/llvm/lib/Target/X86/X86ISelPattern.cpp +++ b/llvm/lib/Target/X86/X86ISelPattern.cpp @@ -3764,8 +3764,10 @@ static SDOperand GetAdjustedArgumentStores(SDOperand Chain, int Offset, MVT::ValueType StoreVT; switch (Chain.getOpcode()) { case ISD::CALLSEQ_START: - // If we found the start of the call sequence, we're done. - return Chain; + // If we found the start of the call sequence, we're done. We actually + // strip off the CALLSEQ_START node, to avoid generating the + // ADJCALLSTACKDOWN marker for the tail call. + return Chain.getOperand(0); case ISD::TokenFactor: { std::vector Ops; Ops.reserve(Chain.getNumOperands());