diff options
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/X86/X86CallingConv.td | 14 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 6 | 
2 files changed, 5 insertions, 15 deletions
| diff --git a/llvm/lib/Target/X86/X86CallingConv.td b/llvm/lib/Target/X86/X86CallingConv.td index d2ade2296b9..8d3e33d5703 100644 --- a/llvm/lib/Target/X86/X86CallingConv.td +++ b/llvm/lib/Target/X86/X86CallingConv.td @@ -593,8 +593,8 @@ def CC_X86_Win64_C : CallingConv<[    // FIXME: Handle byval stuff.    // FIXME: Handle varargs. -  // Promote i1/v1i1 arguments to i8. -  CCIfType<[i1, v1i1], CCPromoteToType<i8>>, +  // Promote i1/i8/i16/v1i1 arguments to i32. +  CCIfType<[i1, i8, i16, v1i1], CCPromoteToType<i32>>,    // The 'nest' parameter, if any, is passed in R10.    CCIfNest<CCAssignToReg<[R10]>>, @@ -619,10 +619,6 @@ def CC_X86_Win64_C : CallingConv<[    CCIfType<[x86mmx], CCBitConvertToType<i64>>,    // The first 4 integer arguments are passed in integer registers. -  CCIfType<[i8 ], CCAssignToRegWithShadow<[CL  , DL  , R8B , R9B ], -                                          [XMM0, XMM1, XMM2, XMM3]>>, -  CCIfType<[i16], CCAssignToRegWithShadow<[CX  , DX  , R8W , R9W ], -                                          [XMM0, XMM1, XMM2, XMM3]>>,    CCIfType<[i32], CCAssignToRegWithShadow<[ECX , EDX , R8D , R9D ],                                            [XMM0, XMM1, XMM2, XMM3]>>, @@ -851,15 +847,13 @@ def CC_X86_32_MCU : CallingConv<[  ]>;  def CC_X86_32_FastCall : CallingConv<[ -  // Promote i1 to i8. -  CCIfType<[i1], CCPromoteToType<i8>>, +  // Promote i1/i8/i16/v1i1 arguments to i32. +  CCIfType<[i1, i8, i16, v1i1], CCPromoteToType<i32>>,    // The 'nest' parameter, if any, is passed in EAX.    CCIfNest<CCAssignToReg<[EAX]>>,    // The first 2 integer arguments are passed in ECX/EDX -  CCIfInReg<CCIfType<[ i8], CCAssignToReg<[ CL,  DL]>>>, -  CCIfInReg<CCIfType<[i16], CCAssignToReg<[ CX,  DX]>>>,    CCIfInReg<CCIfType<[i32], CCAssignToReg<[ECX, EDX]>>>,    // Otherwise, same as everything else. diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index 8e9e090263e..242a008d050 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -3034,11 +3034,7 @@ SDValue X86TargetLowering::LowerFormalArguments(              getv64i1Argument(VA, ArgLocs[++I], Chain, DAG, dl, Subtarget);        } else {          const TargetRegisterClass *RC; -        if (RegVT == MVT::i8) -          RC = &X86::GR8RegClass; -        else if (RegVT == MVT::i16) -          RC = &X86::GR16RegClass; -        else if (RegVT == MVT::i32) +        if (RegVT == MVT::i32)            RC = &X86::GR32RegClass;          else if (Is64Bit && RegVT == MVT::i64)            RC = &X86::GR64RegClass; | 

