xref: /netbsd-src/external/apache2/llvm/dist/llvm/lib/Target/AMDGPU/R600FrameLowering.h (revision 82d56013d7b633d116a93943de88e08335357a7c)
1 //===--------------------- R600FrameLowering.h ------------------*- C++ -*-===//
2 //
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
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLVM_LIB_TARGET_AMDGPU_R600FRAMELOWERING_H
10 #define LLVM_LIB_TARGET_AMDGPU_R600FRAMELOWERING_H
11 
12 #include "AMDGPUFrameLowering.h"
13 
14 namespace llvm {
15 
16 class R600FrameLowering : public AMDGPUFrameLowering {
17 public:
18   R600FrameLowering(StackDirection D, Align StackAl, int LAO,
19                     Align TransAl = Align(1))
AMDGPUFrameLowering(D,StackAl,LAO,TransAl)20       : AMDGPUFrameLowering(D, StackAl, LAO, TransAl) {}
21   ~R600FrameLowering() override;
22 
emitPrologue(MachineFunction & MF,MachineBasicBlock & MBB)23   void emitPrologue(MachineFunction &MF,
24                     MachineBasicBlock &MBB) const override {}
emitEpilogue(MachineFunction & MF,MachineBasicBlock & MBB)25   void emitEpilogue(MachineFunction &MF,
26                     MachineBasicBlock &MBB) const override {}
27   StackOffset getFrameIndexReference(const MachineFunction &MF, int FI,
28                                      Register &FrameReg) const override;
29 
hasFP(const MachineFunction & MF)30   bool hasFP(const MachineFunction &MF) const override {
31     return false;
32   }
33 };
34 
35 } // end namespace llvm
36 
37 #endif // LLVM_LIB_TARGET_AMDGPU_R600FRAMELOWERING_H
38