mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-01 13:11:39 +01:00
ce0a779ded
I've now needed to add an extra parameter to this call twice recently. Not only is the signature getting extremely unwieldy, but just updating all of the callsites and implementations is a pain. Putting the parameters in a struct sidesteps both issues. llvm-svn: 368408
53 lines
1.7 KiB
C++
53 lines
1.7 KiB
C++
//===- llvm/lib/Target/X86/X86CallLowering.h - Call lowering ----*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
/// \file
|
|
/// This file describes how to lower LLVM calls to machine code calls.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_LIB_TARGET_X86_X86CALLLOWERING_H
|
|
#define LLVM_LIB_TARGET_X86_X86CALLLOWERING_H
|
|
|
|
#include "llvm/ADT/ArrayRef.h"
|
|
#include "llvm/CodeGen/GlobalISel/CallLowering.h"
|
|
#include <functional>
|
|
|
|
namespace llvm {
|
|
|
|
class DataLayout;
|
|
class MachineRegisterInfo;
|
|
class X86TargetLowering;
|
|
|
|
class X86CallLowering : public CallLowering {
|
|
public:
|
|
X86CallLowering(const X86TargetLowering &TLI);
|
|
|
|
bool lowerReturn(MachineIRBuilder &MIRBuilder, const Value *Val,
|
|
ArrayRef<Register> VRegs) const override;
|
|
|
|
bool lowerFormalArguments(MachineIRBuilder &MIRBuilder, const Function &F,
|
|
ArrayRef<ArrayRef<Register>> VRegs) const override;
|
|
|
|
bool lowerCall(MachineIRBuilder &MIRBuilder,
|
|
CallLoweringInfo &Info) const override;
|
|
|
|
private:
|
|
/// A function of this type is used to perform value split action.
|
|
using SplitArgTy = std::function<void(ArrayRef<Register>)>;
|
|
|
|
bool splitToValueTypes(const ArgInfo &OrigArgInfo,
|
|
SmallVectorImpl<ArgInfo> &SplitArgs,
|
|
const DataLayout &DL, MachineRegisterInfo &MRI,
|
|
SplitArgTy SplitArg) const;
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif // LLVM_LIB_TARGET_X86_X86CALLLOWERING_H
|