mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-09 16:45:03 +00:00
Remove the use and initialization of the target machine and subtarget
from SystemZFrameLowering. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@212123 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f652ec594e
commit
389c2dd3ac
@ -10,8 +10,9 @@
|
||||
#include "SystemZFrameLowering.h"
|
||||
#include "SystemZCallingConv.h"
|
||||
#include "SystemZInstrBuilder.h"
|
||||
#include "SystemZInstrInfo.h"
|
||||
#include "SystemZMachineFunctionInfo.h"
|
||||
#include "SystemZTargetMachine.h"
|
||||
#include "SystemZRegisterInfo.h"
|
||||
#include "llvm/CodeGen/MachineModuleInfo.h"
|
||||
#include "llvm/CodeGen/MachineRegisterInfo.h"
|
||||
#include "llvm/CodeGen/RegisterScavenging.h"
|
||||
@ -44,11 +45,9 @@ static const TargetFrameLowering::SpillSlot SpillOffsetTable[] = {
|
||||
};
|
||||
} // end anonymous namespace
|
||||
|
||||
SystemZFrameLowering::SystemZFrameLowering(const SystemZTargetMachine &tm,
|
||||
const SystemZSubtarget &sti)
|
||||
: TargetFrameLowering(TargetFrameLowering::StackGrowsDown, 8,
|
||||
-SystemZMC::CallFrameSize, 8),
|
||||
TM(tm), STI(sti) {
|
||||
SystemZFrameLowering::SystemZFrameLowering()
|
||||
: TargetFrameLowering(TargetFrameLowering::StackGrowsDown, 8,
|
||||
-SystemZMC::CallFrameSize, 8) {
|
||||
// Create a mapping from register number to save slot offset.
|
||||
RegSpillOffsets.grow(SystemZ::NUM_TARGET_REGS);
|
||||
for (unsigned I = 0, E = array_lengthof(SpillOffsetTable); I != E; ++I)
|
||||
@ -108,9 +107,8 @@ processFunctionBeforeCalleeSavedScan(MachineFunction &MF,
|
||||
// instruction, or an implicit one that comes between the explicit start
|
||||
// and end registers.
|
||||
static void addSavedGPR(MachineBasicBlock &MBB, MachineInstrBuilder &MIB,
|
||||
const SystemZTargetMachine &TM,
|
||||
unsigned GPR64, bool IsImplicit) {
|
||||
const SystemZRegisterInfo *RI = TM.getRegisterInfo();
|
||||
const TargetRegisterInfo *RI = MBB.getParent()->getTarget().getRegisterInfo();
|
||||
unsigned GPR32 = RI->getSubReg(GPR64, SystemZ::subreg_l32);
|
||||
bool IsLive = MBB.isLiveIn(GPR64) || MBB.isLiveIn(GPR32);
|
||||
if (!IsLive || !IsImplicit) {
|
||||
@ -176,8 +174,8 @@ spillCalleeSavedRegisters(MachineBasicBlock &MBB,
|
||||
MachineInstrBuilder MIB = BuildMI(MBB, MBBI, DL, TII->get(SystemZ::STMG));
|
||||
|
||||
// Add the explicit register operands.
|
||||
addSavedGPR(MBB, MIB, TM, LowGPR, false);
|
||||
addSavedGPR(MBB, MIB, TM, HighGPR, false);
|
||||
addSavedGPR(MBB, MIB, LowGPR, false);
|
||||
addSavedGPR(MBB, MIB, HighGPR, false);
|
||||
|
||||
// Add the address.
|
||||
MIB.addReg(SystemZ::R15D).addImm(StartOffset);
|
||||
@ -187,13 +185,13 @@ spillCalleeSavedRegisters(MachineBasicBlock &MBB,
|
||||
for (unsigned I = 0, E = CSI.size(); I != E; ++I) {
|
||||
unsigned Reg = CSI[I].getReg();
|
||||
if (SystemZ::GR64BitRegClass.contains(Reg))
|
||||
addSavedGPR(MBB, MIB, TM, Reg, true);
|
||||
addSavedGPR(MBB, MIB, Reg, true);
|
||||
}
|
||||
|
||||
// ...likewise GPR varargs.
|
||||
if (IsVarArg)
|
||||
for (unsigned I = ZFI->getVarArgsFirstGPR(); I < SystemZ::NumArgGPRs; ++I)
|
||||
addSavedGPR(MBB, MIB, TM, SystemZ::ArgGPRs[I], true);
|
||||
addSavedGPR(MBB, MIB, SystemZ::ArgGPRs[I], true);
|
||||
}
|
||||
|
||||
// Save FPRs in the normal TargetInstrInfo way.
|
||||
|
@ -10,7 +10,6 @@
|
||||
#ifndef SYSTEMZFRAMELOWERING_H
|
||||
#define SYSTEMZFRAMELOWERING_H
|
||||
|
||||
#include "SystemZSubtarget.h"
|
||||
#include "llvm/ADT/IndexedMap.h"
|
||||
#include "llvm/Target/TargetFrameLowering.h"
|
||||
|
||||
@ -21,13 +20,8 @@ class SystemZSubtarget;
|
||||
class SystemZFrameLowering : public TargetFrameLowering {
|
||||
IndexedMap<unsigned> RegSpillOffsets;
|
||||
|
||||
protected:
|
||||
const SystemZTargetMachine &TM;
|
||||
const SystemZSubtarget &STI;
|
||||
|
||||
public:
|
||||
SystemZFrameLowering(const SystemZTargetMachine &tm,
|
||||
const SystemZSubtarget &sti);
|
||||
SystemZFrameLowering();
|
||||
|
||||
// Override TargetFrameLowering.
|
||||
bool isFPCloseToIncomingSP() const override { return false; }
|
||||
|
@ -22,17 +22,15 @@ extern "C" void LLVMInitializeSystemZTarget() {
|
||||
SystemZTargetMachine::SystemZTargetMachine(const Target &T, StringRef TT,
|
||||
StringRef CPU, StringRef FS,
|
||||
const TargetOptions &Options,
|
||||
Reloc::Model RM,
|
||||
CodeModel::Model CM,
|
||||
Reloc::Model RM, CodeModel::Model CM,
|
||||
CodeGenOpt::Level OL)
|
||||
: LLVMTargetMachine(T, TT, CPU, FS, Options, RM, CM, OL),
|
||||
Subtarget(TT, CPU, FS),
|
||||
// Make sure that global data has at least 16 bits of alignment by default,
|
||||
// so that we can refer to it using LARL. We don't have any special
|
||||
// requirements for stack variables though.
|
||||
DL("E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-a:8:16-n32:64"),
|
||||
InstrInfo(Subtarget), TLInfo(*this), TSInfo(DL),
|
||||
FrameLowering(*this, Subtarget) {
|
||||
: LLVMTargetMachine(T, TT, CPU, FS, Options, RM, CM, OL),
|
||||
Subtarget(TT, CPU, FS),
|
||||
// Make sure that global data has at least 16 bits of alignment by
|
||||
// default, so that we can refer to it using LARL. We don't have any
|
||||
// special requirements for stack variables though.
|
||||
DL("E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-a:8:16-n32:64"),
|
||||
InstrInfo(Subtarget), TLInfo(*this), TSInfo(DL), FrameLowering() {
|
||||
initAsmInfo();
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user