1 //===--------------------- SIFrameLowering.h --------------------*- C++ -*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_LIB_TARGET_AMDGPU_SIFRAMELOWERING_H
10 #define LLVM_LIB_TARGET_AMDGPU_SIFRAMELOWERING_H
12 #include "AMDGPUFrameLowering.h"
17 class SIMachineFunctionInfo
;
21 class SIFrameLowering final
: public AMDGPUFrameLowering
{
23 SIFrameLowering(StackDirection D
, Align StackAl
, int LAO
,
25 : AMDGPUFrameLowering(D
, StackAl
, LAO
, TransAl
) {}
26 ~SIFrameLowering() override
= default;
28 void emitEntryFunctionPrologue(MachineFunction
&MF
,
29 MachineBasicBlock
&MBB
) const;
30 void emitPrologue(MachineFunction
&MF
,
31 MachineBasicBlock
&MBB
) const override
;
32 void emitEpilogue(MachineFunction
&MF
,
33 MachineBasicBlock
&MBB
) const override
;
34 int getFrameIndexReference(const MachineFunction
&MF
, int FI
,
35 unsigned &FrameReg
) const override
;
37 void determineCalleeSaves(MachineFunction
&MF
, BitVector
&SavedRegs
,
38 RegScavenger
*RS
= nullptr) const override
;
39 void determineCalleeSavesSGPR(MachineFunction
&MF
, BitVector
&SavedRegs
,
40 RegScavenger
*RS
= nullptr) const;
42 assignCalleeSavedSpillSlots(MachineFunction
&MF
,
43 const TargetRegisterInfo
*TRI
,
44 std::vector
<CalleeSavedInfo
> &CSI
) const override
;
46 bool isSupportedStackID(TargetStackID::Value ID
) const override
;
48 void processFunctionBeforeFrameFinalized(
50 RegScavenger
*RS
= nullptr) const override
;
52 MachineBasicBlock::iterator
53 eliminateCallFramePseudoInstr(MachineFunction
&MF
,
54 MachineBasicBlock
&MBB
,
55 MachineBasicBlock::iterator MI
) const override
;
58 void emitFlatScratchInit(const GCNSubtarget
&ST
,
60 MachineBasicBlock
&MBB
) const;
62 unsigned getReservedPrivateSegmentBufferReg(
63 const GCNSubtarget
&ST
,
64 const SIInstrInfo
*TII
,
65 const SIRegisterInfo
*TRI
,
66 SIMachineFunctionInfo
*MFI
,
67 MachineFunction
&MF
) const;
69 std::pair
<unsigned, bool> getReservedPrivateSegmentWaveByteOffsetReg(
70 const GCNSubtarget
&ST
, const SIInstrInfo
*TII
, const SIRegisterInfo
*TRI
,
71 SIMachineFunctionInfo
*MFI
, MachineFunction
&MF
) const;
73 // Emit scratch setup code for AMDPAL or Mesa, assuming ResourceRegUsed is set.
74 void emitEntryFunctionScratchSetup(const GCNSubtarget
&ST
, MachineFunction
&MF
,
75 MachineBasicBlock
&MBB
, SIMachineFunctionInfo
*MFI
,
76 MachineBasicBlock::iterator I
, unsigned PreloadedPrivateBufferReg
,
77 unsigned ScratchRsrcReg
) const;
80 bool hasFP(const MachineFunction
&MF
) const override
;
83 } // end namespace llvm
85 #endif // LLVM_LIB_TARGET_AMDGPU_SIFRAMELOWERING_H