mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 01:31:05 +00:00
Factor a long list of conditions into a predicate function. No functionality
change. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@160724 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6ce1eaf1a6
commit
742f2c9a43
@ -1516,6 +1516,20 @@ bool X86FastISel::X86SelectCall(const Instruction *I) {
|
||||
return DoSelectCall(I, 0);
|
||||
}
|
||||
|
||||
static unsigned computeBytesPopedByCalle(const X86Subtarget &Subtarget,
|
||||
const ImmutableCallSite &CS) {
|
||||
if (Subtarget.is64Bit())
|
||||
return 0;
|
||||
if (Subtarget.isTargetWindows())
|
||||
return 0;
|
||||
CallingConv::ID CC = CS.getCallingConv();
|
||||
if (CC == CallingConv::Fast || CC == CallingConv::GHC)
|
||||
return 0;
|
||||
if (!CS.paramHasAttr(1, Attribute::StructRet))
|
||||
return 0;
|
||||
return 4;
|
||||
}
|
||||
|
||||
// Select either a call, or an llvm.memcpy/memmove/memset intrinsic
|
||||
bool X86FastISel::DoSelectCall(const Instruction *I, const char *MemIntName) {
|
||||
const CallInst *CI = cast<CallInst>(I);
|
||||
@ -1862,12 +1876,7 @@ bool X86FastISel::DoSelectCall(const Instruction *I, const char *MemIntName) {
|
||||
|
||||
// Issue CALLSEQ_END
|
||||
unsigned AdjStackUp = TII.getCallFrameDestroyOpcode();
|
||||
unsigned NumBytesCallee = 0;
|
||||
if (!Subtarget->is64Bit() && !Subtarget->isTargetWindows() &&
|
||||
!(CS.getCallingConv() == CallingConv::Fast ||
|
||||
CS.getCallingConv() == CallingConv::GHC) &&
|
||||
CS.paramHasAttr(1, Attribute::StructRet))
|
||||
NumBytesCallee = 4;
|
||||
const unsigned NumBytesCallee = computeBytesPopedByCalle(*Subtarget, CS);
|
||||
BuildMI(*FuncInfo.MBB, FuncInfo.InsertPt, DL, TII.get(AdjStackUp))
|
||||
.addImm(NumBytes).addImm(NumBytesCallee);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user