MSP430RegisterInfo.h revision d0c38176690e9602a93a20a43f1bd084564a8116
1//===- MSP430RegisterInfo.h - MSP430 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 MSP430 implementation of the MRegisterInfo class. 11// 12//===----------------------------------------------------------------------===// 13 14#ifndef LLVM_TARGET_MSP430REGISTERINFO_H 15#define LLVM_TARGET_MSP430REGISTERINFO_H 16 17#include "llvm/Target/TargetRegisterInfo.h" 18#include "MSP430GenRegisterInfo.h.inc" 19 20namespace llvm { 21 22class TargetInstrInfo; 23class MSP430TargetMachine; 24 25struct MSP430RegisterInfo : public MSP430GenRegisterInfo { 26private: 27 MSP430TargetMachine &TM; 28 const TargetInstrInfo &TII; 29 30 /// StackAlign - Default stack alignment. 31 /// 32 unsigned StackAlign; 33public: 34 MSP430RegisterInfo(MSP430TargetMachine &tm, const TargetInstrInfo &tii); 35 36 /// Code Generation virtual methods... 37 const unsigned *getCalleeSavedRegs(const MachineFunction *MF = 0) const; 38 39 BitVector getReservedRegs(const MachineFunction &MF) const; 40 const TargetRegisterClass* getPointerRegClass(unsigned Kind = 0) const; 41 42 void eliminateCallFramePseudoInstr(MachineFunction &MF, 43 MachineBasicBlock &MBB, 44 MachineBasicBlock::iterator I) const; 45 46 void eliminateFrameIndex(MachineBasicBlock::iterator II, 47 int SPAdj, RegScavenger *RS = NULL) const; 48 49 void processFunctionBeforeFrameFinalized(MachineFunction &MF) const; 50 51 // Debug information queries. 52 unsigned getRARegister() const; 53 unsigned getFrameRegister(const MachineFunction &MF) const; 54 55 //! Get DWARF debugging register number 56 int getDwarfRegNum(unsigned RegNum, bool isEH) const; 57}; 58 59} // end namespace llvm 60 61#endif // LLVM_TARGET_MSP430REGISTERINFO_H 62