diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2011-04-28 20:19:12 +0000 | 
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2011-04-28 20:19:12 +0000 | 
| commit | 7cd5101ad3dccbe406b69598ddf04129e801d292 (patch) | |
| tree | 6def4b7d1f71dfd485e815b2fa0fcc561ab78be1 /llvm/lib/Target/X86/X86FastISel.cpp | |
| parent | 101720fb58a133ced215b76909e8dc70212c70ec (diff) | |
| download | bcm5719-llvm-7cd5101ad3dccbe406b69598ddf04129e801d292.tar.gz bcm5719-llvm-7cd5101ad3dccbe406b69598ddf04129e801d292.zip | |
fast-isel sret calls, try 2.  We actually do need to do something on x86-32. rdar://problem/9303592 .
llvm-svn: 130429
Diffstat (limited to 'llvm/lib/Target/X86/X86FastISel.cpp')
| -rw-r--r-- | llvm/lib/Target/X86/X86FastISel.cpp | 6 | 
1 files changed, 4 insertions, 2 deletions
| diff --git a/llvm/lib/Target/X86/X86FastISel.cpp b/llvm/lib/Target/X86/X86FastISel.cpp index 82ed9bad43b..1382f184c34 100644 --- a/llvm/lib/Target/X86/X86FastISel.cpp +++ b/llvm/lib/Target/X86/X86FastISel.cpp @@ -1618,7 +1618,6 @@ bool X86FastISel::X86SelectCall(const Instruction *I) {      // FIXME: Only handle *easy* calls for now.      if (CS.paramHasAttr(AttrInd, Attribute::InReg) || -        CS.paramHasAttr(AttrInd, Attribute::StructRet) ||          CS.paramHasAttr(AttrInd, Attribute::Nest) ||          CS.paramHasAttr(AttrInd, Attribute::ByVal))        return false; @@ -1811,8 +1810,11 @@ bool X86FastISel::X86SelectCall(const Instruction *I) {    // Issue CALLSEQ_END    unsigned AdjStackUp = TM.getRegisterInfo()->getCallFrameDestroyOpcode(); +  unsigned NumBytesCallee = 0; +  if (!Subtarget->is64Bit() && CS.paramHasAttr(1, Attribute::StructRet)) +    NumBytesCallee = 4;    BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, TII.get(AdjStackUp)) -    .addImm(NumBytes).addImm(0); +    .addImm(NumBytes).addImm(NumBytesCallee);    // Now handle call return value (if any).    SmallVector<unsigned, 4> UsedRegs; | 

