mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-11 23:05:31 +00:00
397fc4874e
The getPointerRegClass() hook can return register classes that depend on the calling convention of the current function (ptr_rc_tailcall). So far, we have been able to infer the calling convention from the subtarget alone, but as we add support for multiple calling conventions per target, that no longer works. Patch by Yiannis Tsiouris! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@156328 91177308-0d34-0410-b5e6-96231b3b80d8
61 lines
1.9 KiB
C++
61 lines
1.9 KiB
C++
//===-- MSP430RegisterInfo.h - MSP430 Register Information Impl -*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file contains the MSP430 implementation of the MRegisterInfo class.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_TARGET_MSP430REGISTERINFO_H
|
|
#define LLVM_TARGET_MSP430REGISTERINFO_H
|
|
|
|
#include "llvm/Target/TargetRegisterInfo.h"
|
|
|
|
#define GET_REGINFO_HEADER
|
|
#include "MSP430GenRegisterInfo.inc"
|
|
|
|
namespace llvm {
|
|
|
|
class TargetInstrInfo;
|
|
class MSP430TargetMachine;
|
|
|
|
struct MSP430RegisterInfo : public MSP430GenRegisterInfo {
|
|
private:
|
|
MSP430TargetMachine &TM;
|
|
const TargetInstrInfo &TII;
|
|
|
|
/// StackAlign - Default stack alignment.
|
|
///
|
|
unsigned StackAlign;
|
|
public:
|
|
MSP430RegisterInfo(MSP430TargetMachine &tm, const TargetInstrInfo &tii);
|
|
|
|
/// Code Generation virtual methods...
|
|
const uint16_t *getCalleeSavedRegs(const MachineFunction *MF = 0) const;
|
|
|
|
BitVector getReservedRegs(const MachineFunction &MF) const;
|
|
const TargetRegisterClass*
|
|
getPointerRegClass(const MachineFunction &MF, unsigned Kind = 0) const;
|
|
|
|
void eliminateCallFramePseudoInstr(MachineFunction &MF,
|
|
MachineBasicBlock &MBB,
|
|
MachineBasicBlock::iterator I) const;
|
|
|
|
void eliminateFrameIndex(MachineBasicBlock::iterator II,
|
|
int SPAdj, RegScavenger *RS = NULL) const;
|
|
|
|
void processFunctionBeforeFrameFinalized(MachineFunction &MF) const;
|
|
|
|
// Debug information queries.
|
|
unsigned getFrameRegister(const MachineFunction &MF) const;
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif // LLVM_TARGET_MSP430REGISTERINFO_H
|