summaryrefslogtreecommitdiff
path: root/utils
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2008-01-12 01:07:41 +0000
committerEvan Cheng <evan.cheng@apple.com>2008-01-12 01:07:41 +0000
commit01b8fccca0f5526c57b2249b5457bfb585fd196f (patch)
tree0aa4e853f8a3efc34068ed475c29f713e959478b /utils
parent144ad580fd7b7a4dfeba11a934de69582855c676 (diff)
downloadllvm-01b8fccca0f5526c57b2249b5457bfb585fd196f.tar.gz
llvm-01b8fccca0f5526c57b2249b5457bfb585fd196f.tar.bz2
llvm-01b8fccca0f5526c57b2249b5457bfb585fd196f.tar.xz
ByVal arguments are passed on stack. Make sure to allocate a slot using size and alignment information on the parameter attribute.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@45897 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rw-r--r--utils/TableGen/CallingConvEmitter.cpp27
1 files changed, 20 insertions, 7 deletions
diff --git a/utils/TableGen/CallingConvEmitter.cpp b/utils/TableGen/CallingConvEmitter.cpp
index f7c2eda5e8..c81c80f3fa 100644
--- a/utils/TableGen/CallingConvEmitter.cpp
+++ b/utils/TableGen/CallingConvEmitter.cpp
@@ -115,19 +115,32 @@ void CallingConvEmitter::EmitAction(Record *Action,
int Size = Action->getValueAsInt("Size");
int Align = Action->getValueAsInt("Align");
- O << IndentStr << "unsigned Offset" << ++Counter
- << " = State.AllocateStack(";
+ O << IndentStr << "unsigned Size = ";
if (Size)
- O << Size << ", ";
+ O << Size;
else
- O << "\n" << IndentStr << " State.getTarget().getTargetData()"
- "->getABITypeSize(MVT::getTypeForValueType(LocVT)), ";
+ O << "State.getTarget().getTargetData()"
+ "->getABITypeSize(MVT::getTypeForValueType(LocVT))";
+ O << ";\n"
+ << IndentStr << "unsigned Align = ";
if (Align)
O << Align;
else
- O << "\n" << IndentStr << " State.getTarget().getTargetData()"
+ O << "State.getTarget().getTargetData()"
"->getABITypeAlignment(MVT::getTypeForValueType(LocVT))";
- O << ");\n" << IndentStr
+ O << ";\n";
+ O << IndentStr << "if (ArgFlags & ISD::ParamFlags::ByVal) {\n";
+ O << IndentStr << " " <<
+ "Size = (ArgFlags & ISD::ParamFlags::ByValSize) >> "
+ "ISD::ParamFlags::ByValSizeOffs;\n";
+ O << IndentStr << " " <<
+ "unsigned ParamAlign = 1 << ((ArgFlags & ISD::ParamFlags::ByValAlign) "
+ ">> ISD::ParamFlags::ByValAlignOffs);\n";
+ O << IndentStr << " Align = std::max(Align, ParamAlign);\n"
+ << IndentStr << "}\n";
+ O << IndentStr << "unsigned Offset" << ++Counter
+ << " = State.AllocateStack(Size, Align);\n";
+ O << IndentStr
<< "State.addLoc(CCValAssign::getMem(ValNo, ValVT, Offset"
<< Counter << ", LocVT, LocInfo));\n";
O << IndentStr << "return false;\n";