mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-25 22:12:57 +02:00
558cec9d9b
This adds the actual lib/Target/SystemZ target files necessary to implement the SystemZ target. Note that at this point, the target cannot yet be built since the configure bits are missing. Those will be provided shortly by a follow-on patch. This version of the patch incorporates feedback from reviews by Chris Lattner and Anton Korobeynikov. Thanks to all reviewers! Patch by Richard Sandiford. llvm-svn: 181203
71 lines
2.3 KiB
C++
71 lines
2.3 KiB
C++
//===-- SystemZRegisterInfo.h - SystemZ register information ----*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef SystemZREGISTERINFO_H
|
|
#define SystemZREGISTERINFO_H
|
|
|
|
#include "SystemZ.h"
|
|
#include "llvm/Target/TargetRegisterInfo.h"
|
|
|
|
#define GET_REGINFO_HEADER
|
|
#include "SystemZGenRegisterInfo.inc"
|
|
|
|
namespace llvm {
|
|
|
|
namespace SystemZ {
|
|
// Return the subreg to use for referring to the even and odd registers
|
|
// in a GR128 pair. Is32Bit says whether we want a GR32 or GR64.
|
|
inline unsigned even128(bool Is32bit) {
|
|
return Is32bit ? subreg_32bit : subreg_high;
|
|
}
|
|
inline unsigned odd128(bool Is32bit) {
|
|
return Is32bit ? subreg_low32 : subreg_low;
|
|
}
|
|
}
|
|
|
|
class SystemZSubtarget;
|
|
class SystemZInstrInfo;
|
|
|
|
struct SystemZRegisterInfo : public SystemZGenRegisterInfo {
|
|
private:
|
|
SystemZTargetMachine &TM;
|
|
const SystemZInstrInfo &TII;
|
|
|
|
public:
|
|
SystemZRegisterInfo(SystemZTargetMachine &tm, const SystemZInstrInfo &tii);
|
|
|
|
// Override TargetRegisterInfo.h.
|
|
virtual bool requiresRegisterScavenging(const MachineFunction &MF) const
|
|
LLVM_OVERRIDE {
|
|
return true;
|
|
}
|
|
virtual bool requiresFrameIndexScavenging(const MachineFunction &MF) const
|
|
LLVM_OVERRIDE {
|
|
return true;
|
|
}
|
|
virtual const uint16_t *getCalleeSavedRegs(const MachineFunction *MF = 0)
|
|
const LLVM_OVERRIDE;
|
|
virtual BitVector getReservedRegs(const MachineFunction &MF)
|
|
const LLVM_OVERRIDE;
|
|
virtual bool saveScavengerRegister(MachineBasicBlock &MBB,
|
|
MachineBasicBlock::iterator SaveMBBI,
|
|
MachineBasicBlock::iterator &UseMBBI,
|
|
const TargetRegisterClass *RC,
|
|
unsigned Reg) const LLVM_OVERRIDE;
|
|
virtual void eliminateFrameIndex(MachineBasicBlock::iterator MI,
|
|
int SPAdj, unsigned FIOperandNum,
|
|
RegScavenger *RS) const LLVM_OVERRIDE;
|
|
virtual unsigned getFrameRegister(const MachineFunction &MF) const
|
|
LLVM_OVERRIDE;
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif
|