mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
PPC should always use the register scavenger for CR spilling
This removes the -disable-ppc[32|64]-regscavenger options; the code that uses the register scavenger has been working well (and has been the default) for some time, and we don't need options to enable the old (broken) CR spilling code. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@176865 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ac5b3915aa
commit
7285e8d98c
@ -33,11 +33,6 @@
|
||||
#define GET_INSTRINFO_CTOR
|
||||
#include "PPCGenInstrInfo.inc"
|
||||
|
||||
namespace llvm {
|
||||
extern cl::opt<bool> DisablePPC32RS;
|
||||
extern cl::opt<bool> DisablePPC64RS;
|
||||
}
|
||||
|
||||
using namespace llvm;
|
||||
|
||||
static cl::
|
||||
@ -489,47 +484,11 @@ PPCInstrInfo::StoreRegToStackSlot(MachineFunction &MF,
|
||||
getKillRegState(isKill)),
|
||||
FrameIdx));
|
||||
} else if (PPC::CRRCRegClass.hasSubClassEq(RC)) {
|
||||
if ((!DisablePPC32RS && !TM.getSubtargetImpl()->isPPC64()) ||
|
||||
(!DisablePPC64RS && TM.getSubtargetImpl()->isPPC64())) {
|
||||
NewMIs.push_back(addFrameReference(BuildMI(MF, DL, get(PPC::SPILL_CR))
|
||||
.addReg(SrcReg,
|
||||
getKillRegState(isKill)),
|
||||
FrameIdx));
|
||||
return true;
|
||||
} else {
|
||||
// FIXME: We need a scatch reg here. The trouble with using R0 is that
|
||||
// it's possible for the stack frame to be so big the save location is
|
||||
// out of range of immediate offsets, necessitating another register.
|
||||
// We hack this on Darwin by reserving R2. It's probably broken on Linux
|
||||
// at the moment.
|
||||
|
||||
bool is64Bit = TM.getSubtargetImpl()->isPPC64();
|
||||
// We need to store the CR in the low 4-bits of the saved value. First,
|
||||
// issue a MFCR to save all of the CRBits.
|
||||
unsigned ScratchReg = TM.getSubtargetImpl()->isDarwinABI() ?
|
||||
(is64Bit ? PPC::X2 : PPC::R2) :
|
||||
(is64Bit ? PPC::X0 : PPC::R0);
|
||||
NewMIs.push_back(BuildMI(MF, DL, get(is64Bit ? PPC::MFCR8pseud :
|
||||
PPC::MFCRpseud), ScratchReg)
|
||||
.addReg(SrcReg, getKillRegState(isKill)));
|
||||
|
||||
// If the saved register wasn't CR0, shift the bits left so that they are
|
||||
// in CR0's slot.
|
||||
if (SrcReg != PPC::CR0) {
|
||||
unsigned ShiftBits = getPPCRegisterNumbering(SrcReg)*4;
|
||||
// rlwinm scratch, scratch, ShiftBits, 0, 31.
|
||||
NewMIs.push_back(BuildMI(MF, DL, get(is64Bit ? PPC::RLWINM8 :
|
||||
PPC::RLWINM), ScratchReg)
|
||||
.addReg(ScratchReg).addImm(ShiftBits)
|
||||
.addImm(0).addImm(31));
|
||||
}
|
||||
|
||||
NewMIs.push_back(addFrameReference(BuildMI(MF, DL, get(is64Bit ?
|
||||
PPC::STW8 : PPC::STW))
|
||||
.addReg(ScratchReg,
|
||||
getKillRegState(isKill)),
|
||||
FrameIdx));
|
||||
}
|
||||
NewMIs.push_back(addFrameReference(BuildMI(MF, DL, get(PPC::SPILL_CR))
|
||||
.addReg(SrcReg,
|
||||
getKillRegState(isKill)),
|
||||
FrameIdx));
|
||||
return true;
|
||||
} else if (PPC::CRBITRCRegClass.hasSubClassEq(RC)) {
|
||||
// FIXME: We use CRi here because there is no mtcrf on a bit. Since the
|
||||
// backend currently only uses CR1EQ as an individual bit, this should
|
||||
@ -642,37 +601,10 @@ PPCInstrInfo::LoadRegFromStackSlot(MachineFunction &MF, DebugLoc DL,
|
||||
NewMIs.push_back(addFrameReference(BuildMI(MF, DL, get(PPC::LFS), DestReg),
|
||||
FrameIdx));
|
||||
} else if (PPC::CRRCRegClass.hasSubClassEq(RC)) {
|
||||
if ((!DisablePPC32RS && !TM.getSubtargetImpl()->isPPC64()) ||
|
||||
(!DisablePPC64RS && TM.getSubtargetImpl()->isPPC64())) {
|
||||
NewMIs.push_back(addFrameReference(BuildMI(MF, DL,
|
||||
get(PPC::RESTORE_CR), DestReg)
|
||||
, FrameIdx));
|
||||
return true;
|
||||
} else {
|
||||
// FIXME: We need a scatch reg here. The trouble with using R0 is that
|
||||
// it's possible for the stack frame to be so big the save location is
|
||||
// out of range of immediate offsets, necessitating another register.
|
||||
// We hack this on Darwin by reserving R2. It's probably broken on Linux
|
||||
// at the moment.
|
||||
unsigned ScratchReg = TM.getSubtargetImpl()->isDarwinABI() ?
|
||||
PPC::R2 : PPC::R0;
|
||||
NewMIs.push_back(addFrameReference(BuildMI(MF, DL, get(PPC::LWZ),
|
||||
ScratchReg), FrameIdx));
|
||||
|
||||
// If the reloaded register isn't CR0, shift the bits right so that they are
|
||||
// in the right CR's slot.
|
||||
if (DestReg != PPC::CR0) {
|
||||
unsigned ShiftBits = getPPCRegisterNumbering(DestReg)*4;
|
||||
// rlwinm r11, r11, 32-ShiftBits, 0, 31.
|
||||
NewMIs.push_back(BuildMI(MF, DL, get(PPC::RLWINM), ScratchReg)
|
||||
.addReg(ScratchReg).addImm(32-ShiftBits).addImm(0)
|
||||
.addImm(31));
|
||||
}
|
||||
|
||||
NewMIs.push_back(BuildMI(MF, DL, get(TM.getSubtargetImpl()->isPPC64() ?
|
||||
PPC::MTCRF8 : PPC::MTCRF), DestReg)
|
||||
.addReg(ScratchReg));
|
||||
}
|
||||
NewMIs.push_back(addFrameReference(BuildMI(MF, DL,
|
||||
get(PPC::RESTORE_CR), DestReg),
|
||||
FrameIdx));
|
||||
return true;
|
||||
} else if (PPC::CRBITRCRegClass.hasSubClassEq(RC)) {
|
||||
|
||||
unsigned Reg = 0;
|
||||
|
@ -46,26 +46,8 @@
|
||||
#define GET_REGINFO_TARGET_DESC
|
||||
#include "PPCGenRegisterInfo.inc"
|
||||
|
||||
namespace llvm {
|
||||
cl::opt<bool> DisablePPC32RS("disable-ppc32-regscavenger",
|
||||
cl::init(false),
|
||||
cl::desc("Disable PPC32 register scavenger"),
|
||||
cl::Hidden);
|
||||
cl::opt<bool> DisablePPC64RS("disable-ppc64-regscavenger",
|
||||
cl::init(false),
|
||||
cl::desc("Disable PPC64 register scavenger"),
|
||||
cl::Hidden);
|
||||
}
|
||||
|
||||
using namespace llvm;
|
||||
|
||||
// FIXME (64-bit): Should be inlined.
|
||||
bool
|
||||
PPCRegisterInfo::requiresRegisterScavenging(const MachineFunction &) const {
|
||||
return ((!DisablePPC32RS && !Subtarget.isPPC64()) ||
|
||||
(!DisablePPC64RS && Subtarget.isPPC64()));
|
||||
}
|
||||
|
||||
PPCRegisterInfo::PPCRegisterInfo(const PPCSubtarget &ST,
|
||||
const TargetInstrInfo &tii)
|
||||
: PPCGenRegisterInfo(ST.isPPC64() ? PPC::LR8 : PPC::LR,
|
||||
@ -273,26 +255,16 @@ void PPCRegisterInfo::lowerDynamicAlloc(MachineBasicBlock::iterator II,
|
||||
const TargetRegisterClass *GPRC = &PPC::GPRCRegClass;
|
||||
const TargetRegisterClass *RC = LP64 ? G8RC : GPRC;
|
||||
|
||||
// FIXME (64-bit): Use "findScratchRegister"
|
||||
unsigned Reg;
|
||||
if (requiresRegisterScavenging(MF))
|
||||
Reg = findScratchRegister(II, RS, RC, SPAdj);
|
||||
else
|
||||
Reg = PPC::R0;
|
||||
unsigned Reg = findScratchRegister(II, RS, RC, SPAdj);
|
||||
|
||||
if (MaxAlign < TargetAlign && isInt<16>(FrameSize)) {
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::ADDI), Reg)
|
||||
.addReg(PPC::R31)
|
||||
.addImm(FrameSize);
|
||||
} else if (LP64) {
|
||||
if (requiresRegisterScavenging(MF)) // FIXME (64-bit): Use "true" part.
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::LD), Reg)
|
||||
.addImm(0)
|
||||
.addReg(PPC::X1);
|
||||
else
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::LD), PPC::X0)
|
||||
.addImm(0)
|
||||
.addReg(PPC::X1);
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::LD), Reg)
|
||||
.addImm(0)
|
||||
.addReg(PPC::X1);
|
||||
} else {
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::LWZ), Reg)
|
||||
.addImm(0)
|
||||
@ -302,17 +274,10 @@ void PPCRegisterInfo::lowerDynamicAlloc(MachineBasicBlock::iterator II,
|
||||
// Grow the stack and update the stack pointer link, then determine the
|
||||
// address of new allocated space.
|
||||
if (LP64) {
|
||||
if (requiresRegisterScavenging(MF)) // FIXME (64-bit): Use "true" part.
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::STDUX), PPC::X1)
|
||||
.addReg(Reg, RegState::Kill)
|
||||
.addReg(PPC::X1)
|
||||
.addReg(MI.getOperand(1).getReg());
|
||||
else
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::STDUX), PPC::X1)
|
||||
.addReg(PPC::X0, RegState::Kill)
|
||||
.addReg(PPC::X1)
|
||||
.addReg(MI.getOperand(1).getReg());
|
||||
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::STDUX), PPC::X1)
|
||||
.addReg(Reg, RegState::Kill)
|
||||
.addReg(PPC::X1)
|
||||
.addReg(MI.getOperand(1).getReg());
|
||||
if (!MI.getOperand(1).isKill())
|
||||
BuildMI(MBB, II, dl, TII.get(PPC::ADDI8), MI.getOperand(0).getReg())
|
||||
.addReg(PPC::X1)
|
||||
@ -499,14 +464,12 @@ PPCRegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,
|
||||
}
|
||||
|
||||
// Special case for pseudo-ops SPILL_CR and RESTORE_CR.
|
||||
if (requiresRegisterScavenging(MF)) {
|
||||
if (OpC == PPC::SPILL_CR) {
|
||||
lowerCRSpilling(II, FrameIndex, SPAdj, RS);
|
||||
return;
|
||||
} else if (OpC == PPC::RESTORE_CR) {
|
||||
lowerCRRestore(II, FrameIndex, SPAdj, RS);
|
||||
return;
|
||||
}
|
||||
if (OpC == PPC::SPILL_CR) {
|
||||
lowerCRSpilling(II, FrameIndex, SPAdj, RS);
|
||||
return;
|
||||
} else if (OpC == PPC::RESTORE_CR) {
|
||||
lowerCRRestore(II, FrameIndex, SPAdj, RS);
|
||||
return;
|
||||
}
|
||||
|
||||
// Replace the FrameIndex with base register with GPR1 (SP) or GPR31 (FP).
|
||||
@ -563,13 +526,9 @@ PPCRegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,
|
||||
// The offset doesn't fit into a single register, scavenge one to build the
|
||||
// offset in.
|
||||
|
||||
unsigned SReg;
|
||||
if (requiresRegisterScavenging(MF)) {
|
||||
const TargetRegisterClass *G8RC = &PPC::G8RCRegClass;
|
||||
const TargetRegisterClass *GPRC = &PPC::GPRCRegClass;
|
||||
SReg = findScratchRegister(II, RS, is64Bit ? G8RC : GPRC, SPAdj);
|
||||
} else
|
||||
SReg = is64Bit ? PPC::X0 : PPC::R0;
|
||||
const TargetRegisterClass *G8RC = &PPC::G8RCRegClass;
|
||||
const TargetRegisterClass *GPRC = &PPC::GPRCRegClass;
|
||||
unsigned SReg = findScratchRegister(II, RS, is64Bit ? G8RC : GPRC, SPAdj);
|
||||
|
||||
// Insert a set of rA with the full offset value before the ld, st, or add
|
||||
BuildMI(MBB, II, dl, TII.get(is64Bit ? PPC::LIS8 : PPC::LIS), SReg)
|
||||
|
@ -50,8 +50,9 @@ public:
|
||||
virtual bool avoidWriteAfterWrite(const TargetRegisterClass *RC) const;
|
||||
|
||||
/// requiresRegisterScavenging - We require a register scavenger.
|
||||
/// FIXME (64-bit): Should be inlined.
|
||||
bool requiresRegisterScavenging(const MachineFunction &MF) const;
|
||||
bool requiresRegisterScavenging(const MachineFunction &MF) const {
|
||||
return true;
|
||||
}
|
||||
|
||||
bool trackLivenessAfterRegAlloc(const MachineFunction &MF) const;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user