diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2008-01-12 01:07:41 +0000 |
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2008-01-12 01:07:41 +0000 |
| commit | 02e78103ab5dca80ca35232b9886c652fb731a2d (patch) | |
| tree | c5bc355c8b0b1e97c90f600ae626f1294bd82aef /llvm/utils/TableGen/CallingConvEmitter.cpp | |
| parent | 18df33d0c8630ce25050d670ebd668fc1e68e7b8 (diff) | |
| download | bcm5719-llvm-02e78103ab5dca80ca35232b9886c652fb731a2d.tar.gz bcm5719-llvm-02e78103ab5dca80ca35232b9886c652fb731a2d.zip | |
ByVal arguments are passed on stack. Make sure to allocate a slot using size and alignment information on the parameter attribute.
llvm-svn: 45897
Diffstat (limited to 'llvm/utils/TableGen/CallingConvEmitter.cpp')
| -rw-r--r-- | llvm/utils/TableGen/CallingConvEmitter.cpp | 27 |
1 files changed, 20 insertions, 7 deletions
diff --git a/llvm/utils/TableGen/CallingConvEmitter.cpp b/llvm/utils/TableGen/CallingConvEmitter.cpp index f7c2eda5e86..c81c80f3fab 100644 --- a/llvm/utils/TableGen/CallingConvEmitter.cpp +++ b/llvm/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"; |

