Path: blob/main/contrib/llvm-project/llvm/lib/Target/RISCV/GISel/RISCVCallLowering.h
35294 views
//===-- RISCVCallLowering.h - Call lowering ---------------------*- C++ -*-===//1//2// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.3// See https://llvm.org/LICENSE.txt for license information.4// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception5//6//===----------------------------------------------------------------------===//7//8/// \file9/// This file describes how to lower LLVM calls to machine code calls.10//11//===----------------------------------------------------------------------===//1213#ifndef LLVM_LIB_TARGET_RISCV_RISCVCALLLOWERING_H14#define LLVM_LIB_TARGET_RISCV_RISCVCALLLOWERING_H1516#include "llvm/CodeGen/CallingConvLower.h"17#include "llvm/CodeGen/GlobalISel/CallLowering.h"1819namespace llvm {2021class MachineInstrBuilder;22class MachineIRBuilder;23class RISCVTargetLowering;2425class RISCVCallLowering : public CallLowering {2627public:28RISCVCallLowering(const RISCVTargetLowering &TLI);2930bool lowerReturn(MachineIRBuilder &MIRBuiler, const Value *Val,31ArrayRef<Register> VRegs,32FunctionLoweringInfo &FLI) const override;3334bool lowerFormalArguments(MachineIRBuilder &MIRBuilder, const Function &F,35ArrayRef<ArrayRef<Register>> VRegs,36FunctionLoweringInfo &FLI) const override;3738bool lowerCall(MachineIRBuilder &MIRBuilder,39CallLoweringInfo &Info) const override;4041private:42bool lowerReturnVal(MachineIRBuilder &MIRBuilder, const Value *Val,43ArrayRef<Register> VRegs, MachineInstrBuilder &Ret) const;4445void saveVarArgRegisters(MachineIRBuilder &MIRBuilder,46CallLowering::IncomingValueHandler &Handler,47IncomingValueAssigner &Assigner,48CCState &CCInfo) const;49};5051} // end namespace llvm5253#endif // LLVM_LIB_TARGET_RISCV_RISCVCALLLOWERING_H545556