diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2019-12-20 19:53:05 +0000 |
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2019-12-20 19:53:05 +0000 |
| commit | 0b57cec536236d46e3dba9bd041533462f33dbb7 (patch) | |
| tree | 56229dbdbbf76d18580f72f789003db17246c8d9 /contrib/llvm-project/llvm/lib/Target/AVR/AVRFrameLowering.h | |
| parent | 718ef55ec7785aae63f98f8ca05dc07ed399c16d (diff) | |
Notes
Diffstat (limited to 'contrib/llvm-project/llvm/lib/Target/AVR/AVRFrameLowering.h')
| -rw-r--r-- | contrib/llvm-project/llvm/lib/Target/AVR/AVRFrameLowering.h | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/contrib/llvm-project/llvm/lib/Target/AVR/AVRFrameLowering.h b/contrib/llvm-project/llvm/lib/Target/AVR/AVRFrameLowering.h new file mode 100644 index 000000000000..a7658438232a --- /dev/null +++ b/contrib/llvm-project/llvm/lib/Target/AVR/AVRFrameLowering.h @@ -0,0 +1,45 @@ +//===-- AVRFrameLowering.h - Define frame lowering for AVR ------*- 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 +// +//===----------------------------------------------------------------------===// + +#ifndef LLVM_AVR_FRAME_LOWERING_H +#define LLVM_AVR_FRAME_LOWERING_H + +#include "llvm/CodeGen/TargetFrameLowering.h" + +namespace llvm { + +/// Utilities for creating function call frames. +class AVRFrameLowering : public TargetFrameLowering { +public: + explicit AVRFrameLowering(); + +public: + void emitPrologue(MachineFunction &MF, MachineBasicBlock &MBB) const override; + void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const override; + bool hasFP(const MachineFunction &MF) const override; + bool spillCalleeSavedRegisters(MachineBasicBlock &MBB, + MachineBasicBlock::iterator MI, + const std::vector<CalleeSavedInfo> &CSI, + const TargetRegisterInfo *TRI) const override; + bool + restoreCalleeSavedRegisters(MachineBasicBlock &MBB, + MachineBasicBlock::iterator MI, + std::vector<CalleeSavedInfo> &CSI, + const TargetRegisterInfo *TRI) const override; + bool hasReservedCallFrame(const MachineFunction &MF) const override; + bool canSimplifyCallFramePseudos(const MachineFunction &MF) const override; + void determineCalleeSaves(MachineFunction &MF, BitVector &SavedRegs, + RegScavenger *RS = nullptr) const override; + MachineBasicBlock::iterator + eliminateCallFramePseudoInstr(MachineFunction &MF, MachineBasicBlock &MBB, + MachineBasicBlock::iterator MI) const override; +}; + +} // end namespace llvm + +#endif // LLVM_AVR_FRAME_LOWERING_H |
