c372e831797089a966a4b99615b01e23b0f9b609
[oota-llvm.git] / lib / Target / NVPTX / NVPTXFrameLowering.h
1 //===--- NVPTXFrameLowering.h - Define frame lowering for NVPTX -*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 //
11 //
12 //===----------------------------------------------------------------------===//
13
14 #ifndef NVPTX_FRAMELOWERING_H
15 #define NVPTX_FRAMELOWERING_H
16
17 #include "NVPTXSubtarget.h"
18 #include "llvm/Target/TargetFrameLowering.h"
19
20 namespace llvm {
21
22 class NVPTXFrameLowering : public TargetFrameLowering {
23   bool is64bit;
24
25 public:
26   explicit NVPTXFrameLowering(NVPTXSubtarget &STI)
27       : TargetFrameLowering(TargetFrameLowering::StackGrowsUp, 8, 0),
28         is64bit(STI.is64Bit()) {}
29
30   bool hasFP(const MachineFunction &MF) const override;
31   void emitPrologue(MachineFunction &MF) const override;
32   void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const override;
33
34   void eliminateCallFramePseudoInstr(MachineFunction &MF,
35                                   MachineBasicBlock &MBB,
36                                   MachineBasicBlock::iterator I) const override;
37 };
38
39 } // End llvm namespace
40
41 #endif