• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //===- NVPTXRegisterInfo.h - NVPTX Register Information Impl ----*- 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 // This file contains the NVPTX implementation of the TargetRegisterInfo class.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef NVPTXREGISTERINFO_H
15 #define NVPTXREGISTERINFO_H
16 
17 #include "ManagedStringPool.h"
18 #include "llvm/Target/TargetRegisterInfo.h"
19 
20 
21 #define GET_REGINFO_HEADER
22 #include "NVPTXGenRegisterInfo.inc"
23 #include "llvm/Target/TargetRegisterInfo.h"
24 #include <sstream>
25 
26 namespace llvm {
27 
28 // Forward Declarations.
29 class TargetInstrInfo;
30 class NVPTXSubtarget;
31 
32 class NVPTXRegisterInfo : public NVPTXGenRegisterInfo {
33 private:
34   bool Is64Bit;
35   // Hold Strings that can be free'd all together with NVPTXRegisterInfo
36   ManagedStringPool     ManagedStrPool;
37 
38 public:
39   NVPTXRegisterInfo(const TargetInstrInfo &tii,
40                     const NVPTXSubtarget &st);
41 
42 
43   //------------------------------------------------------
44   // Pure virtual functions from TargetRegisterInfo
45   //------------------------------------------------------
46 
47   // NVPTX callee saved registers
48   virtual const uint16_t*
49   getCalleeSavedRegs(const MachineFunction *MF = 0) const;
50 
51   // NVPTX callee saved register classes
52   virtual const TargetRegisterClass* const *
53   getCalleeSavedRegClasses(const MachineFunction *MF) const;
54 
55   virtual BitVector getReservedRegs(const MachineFunction &MF) const;
56 
57   virtual void eliminateFrameIndex(MachineBasicBlock::iterator MI,
58                                    int SPAdj, unsigned FIOperandNum,
59                                    RegScavenger *RS=NULL) const;
60 
61   virtual int getDwarfRegNum(unsigned RegNum, bool isEH) const;
62   virtual unsigned getFrameRegister(const MachineFunction &MF) const;
63   virtual unsigned getRARegister() const;
64 
getStrPool()65   ManagedStringPool *getStrPool() const {
66     return const_cast<ManagedStringPool *>(&ManagedStrPool);
67   }
68 
getName(unsigned RegNo)69   const char *getName(unsigned RegNo) const {
70     std::stringstream O;
71     O << "reg" << RegNo;
72     return getStrPool()->getManagedString(O.str().c_str())->c_str();
73   }
74 
75 };
76 
77 
78 std::string getNVPTXRegClassName (const TargetRegisterClass *RC);
79 std::string getNVPTXRegClassStr (const TargetRegisterClass *RC);
80 
81 } // end namespace llvm
82 
83 
84 #endif
85