diff options
author | Duncan Sands <baldrick@free.fr> | 2007-11-14 08:29:13 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2007-11-14 08:29:13 +0000 |
commit | 87b665d3dee92ef5f30d9eb1afdb64448bc3e2ef (patch) | |
tree | 521936bd9b55ee796e8d3e92ca991adbe3796471 | |
parent | 38afd9e3ac3f6b47a45528e708e800730dbbfd2d (diff) | |
download | external_llvm-87b665d3dee92ef5f30d9eb1afdb64448bc3e2ef.zip external_llvm-87b665d3dee92ef5f30d9eb1afdb64448bc3e2ef.tar.gz external_llvm-87b665d3dee92ef5f30d9eb1afdb64448bc3e2ef.tar.bz2 |
Eliminate the recently introduced CCAssignToStackABISizeAlign
in favour of teaching CCAssignToStack that size 0 and/or align
0 means to use the ABI values. This seems a neater solution.
It is safe since no legal value type has size 0.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@44107 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/TargetCallingConv.td | 11 | ||||
-rw-r--r-- | lib/Target/X86/X86CallingConv.td | 4 | ||||
-rw-r--r-- | utils/TableGen/CallingConvEmitter.cpp | 26 |
3 files changed, 19 insertions, 22 deletions
diff --git a/lib/Target/TargetCallingConv.td b/lib/Target/TargetCallingConv.td index 05029a0..62eb1c7 100644 --- a/lib/Target/TargetCallingConv.td +++ b/lib/Target/TargetCallingConv.td @@ -60,19 +60,14 @@ class CCAssignToReg<list<Register> regList> : CCAction { } /// CCAssignToStack - This action always matches: it assigns the value to a -/// stack slot of the specified size and alignment on the stack. +/// stack slot of the specified size and alignment on the stack. If size is +/// zero then the ABI size is used; if align is zero then the ABI alignment +/// is used - these may depend on the target or subtarget. class CCAssignToStack<int size, int align> : CCAction { int Size = size; int Align = align; } -/// CCAssignToStackABISizeAlign - This action always matches: it assigns -/// the value to a stack slot of the ABISize and ABIAlignment for the type, -/// which may depend on the target or subtarget. -/// "ignored" is here because an empty arg list does not work. -class CCAssignToStackABISizeAlign<int ignored> : CCAction { -} - /// CCStructAssign - This action always matches: it will use the C ABI and /// the register availability to decided whether to assign to a set of /// registers or to a stack slot. diff --git a/lib/Target/X86/X86CallingConv.td b/lib/Target/X86/X86CallingConv.td index 97d4636..bb054e8 100644 --- a/lib/Target/X86/X86CallingConv.td +++ b/lib/Target/X86/X86CallingConv.td @@ -120,7 +120,7 @@ def CC_X86_64_C : CallingConv<[ // Long doubles get stack slots whose size and alignment depends on the // subtarget. - CCIfType<[f80], CCAssignToStackABISizeAlign<0>>, + CCIfType<[f80], CCAssignToStack<0, 0>>, // Vectors get 16-byte stack slots that are 16-byte aligned. CCIfType<[v16i8, v8i16, v4i32, v2i64, v4f32, v2f64], CCAssignToStack<16, 16>>, @@ -181,7 +181,7 @@ def CC_X86_32_Common : CallingConv<[ // Long doubles get slots whose size and alignment depends on the // subtarget. - CCIfType<[f80], CCAssignToStackABISizeAlign<0>>, + CCIfType<[f80], CCAssignToStack<0, 0>>, // The first 4 vector arguments are passed in XMM registers. CCIfType<[v16i8, v8i16, v4i32, v2i64, v4f32, v2f64], diff --git a/utils/TableGen/CallingConvEmitter.cpp b/utils/TableGen/CallingConvEmitter.cpp index 79e3a9c..82013c9 100644 --- a/utils/TableGen/CallingConvEmitter.cpp +++ b/utils/TableGen/CallingConvEmitter.cpp @@ -114,19 +114,21 @@ void CallingConvEmitter::EmitAction(Record *Action, } else if (Action->isSubClassOf("CCAssignToStack")) { int Size = Action->getValueAsInt("Size"); int Align = Action->getValueAsInt("Align"); - - 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"; - } else if (Action->isSubClassOf("CCAssignToStackABISizeAlign")) { + O << IndentStr << "unsigned Offset" << ++Counter - << " = State.AllocateStack(State.getTarget().getTargetData()" - "->getABITypeSize(MVT::getTypeForValueType(LocVT)),\n"; - O << IndentStr << " State.getTarget().getTargetData()" - "->getABITypeAlignment(MVT::getTypeForValueType(LocVT)));\n"; - O << IndentStr << "State.addLoc(CCValAssign::getMem(ValNo, ValVT, Offset" + << " = State.AllocateStack("; + if (Size) + O << Size << ", "; + else + O << "\n" << IndentStr << " State.getTarget().getTargetData()" + "->getABITypeSize(MVT::getTypeForValueType(LocVT)), "; + if (Align) + O << Align; + else + O << "\n" << IndentStr << " State.getTarget().getTargetData()" + "->getABITypeAlignment(MVT::getTypeForValueType(LocVT))"; + O << ");\n" << IndentStr + << "State.addLoc(CCValAssign::getMem(ValNo, ValVT, Offset" << Counter << ", LocVT, LocInfo));\n"; O << IndentStr << "return false;\n"; } else if (Action->isSubClassOf("CCPromoteToType")) { |