mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-12 13:30:51 +00:00
ARM: remove unnecessary state-tracking during frame lowering.
ResolveFrameIndex had what appeared to be a very nasty hack for when the frame-index referred to a callee-saved register. In this case it "adjusted" the offset so that the address was correct if (and only if) the MachineInstr immediately followed the respective push. This "worked" for all forms of GPR & DPR but was only ever used to set the frame pointer itself, and once this was put in a more sensible location the entire state-tracking machinery it relied on became redundant. So I stripped it. The only wrinkle is that "add r7, sp, #0" might theoretically be slower (need an actual ALU slot) compared to "mov r7, sp" so I added a micro-optimisation that also makes emitARMRegUpdate and emitT2RegUpdate also work when NumBytes == 0. No test changes since there shouldn't be any functionality change. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194025 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
627ef0cf5e
commit
e53abc2072
@ -1826,6 +1826,14 @@ void llvm::emitARMRegPlusImmediate(MachineBasicBlock &MBB,
|
||||
unsigned DestReg, unsigned BaseReg, int NumBytes,
|
||||
ARMCC::CondCodes Pred, unsigned PredReg,
|
||||
const ARMBaseInstrInfo &TII, unsigned MIFlags) {
|
||||
if (NumBytes == 0 && DestReg != BaseReg) {
|
||||
BuildMI(MBB, MBBI, dl, TII.get(ARM::MOVr), DestReg)
|
||||
.addReg(BaseReg, RegState::Kill)
|
||||
.addImm((unsigned)Pred).addReg(PredReg).addReg(0)
|
||||
.setMIFlags(MIFlags);
|
||||
return;
|
||||
}
|
||||
|
||||
bool isSub = NumBytes < 0;
|
||||
if (isSub) NumBytes = -NumBytes;
|
||||
|
||||
|
@ -115,20 +115,31 @@ static bool isCSRestore(MachineInstr *MI,
|
||||
return false;
|
||||
}
|
||||
|
||||
static void
|
||||
emitSPUpdate(bool isARM,
|
||||
MachineBasicBlock &MBB, MachineBasicBlock::iterator &MBBI,
|
||||
DebugLoc dl, const ARMBaseInstrInfo &TII,
|
||||
int NumBytes, unsigned MIFlags = MachineInstr::NoFlags,
|
||||
ARMCC::CondCodes Pred = ARMCC::AL, unsigned PredReg = 0) {
|
||||
static void emitRegPlusImmediate(bool isARM, MachineBasicBlock &MBB,
|
||||
MachineBasicBlock::iterator &MBBI, DebugLoc dl,
|
||||
const ARMBaseInstrInfo &TII, unsigned DestReg,
|
||||
unsigned SrcReg, int NumBytes,
|
||||
unsigned MIFlags = MachineInstr::NoFlags,
|
||||
ARMCC::CondCodes Pred = ARMCC::AL,
|
||||
unsigned PredReg = 0) {
|
||||
if (isARM)
|
||||
emitARMRegPlusImmediate(MBB, MBBI, dl, ARM::SP, ARM::SP, NumBytes,
|
||||
emitARMRegPlusImmediate(MBB, MBBI, dl, DestReg, SrcReg, NumBytes,
|
||||
Pred, PredReg, TII, MIFlags);
|
||||
else
|
||||
emitT2RegPlusImmediate(MBB, MBBI, dl, ARM::SP, ARM::SP, NumBytes,
|
||||
emitT2RegPlusImmediate(MBB, MBBI, dl, DestReg, SrcReg, NumBytes,
|
||||
Pred, PredReg, TII, MIFlags);
|
||||
}
|
||||
|
||||
static void emitSPUpdate(bool isARM, MachineBasicBlock &MBB,
|
||||
MachineBasicBlock::iterator &MBBI, DebugLoc dl,
|
||||
const ARMBaseInstrInfo &TII, int NumBytes,
|
||||
unsigned MIFlags = MachineInstr::NoFlags,
|
||||
ARMCC::CondCodes Pred = ARMCC::AL,
|
||||
unsigned PredReg = 0) {
|
||||
emitRegPlusImmediate(isARM, MBB, MBBI, dl, TII, ARM::SP, ARM::SP, NumBytes,
|
||||
MIFlags, Pred, PredReg);
|
||||
}
|
||||
|
||||
void ARMFrameLowering::emitPrologue(MachineFunction &MF) const {
|
||||
MachineBasicBlock &MBB = MF.front();
|
||||
MachineBasicBlock::iterator MBBI = MBB.begin();
|
||||
@ -186,7 +197,6 @@ void ARMFrameLowering::emitPrologue(MachineFunction &MF) const {
|
||||
case ARM::LR:
|
||||
if (Reg == FramePtr)
|
||||
FramePtrSpillFI = FI;
|
||||
AFI->addGPRCalleeSavedArea1Frame(FI);
|
||||
GPRCS1Size += 4;
|
||||
break;
|
||||
case ARM::R8:
|
||||
@ -196,47 +206,25 @@ void ARMFrameLowering::emitPrologue(MachineFunction &MF) const {
|
||||
case ARM::R12:
|
||||
if (Reg == FramePtr)
|
||||
FramePtrSpillFI = FI;
|
||||
if (STI.isTargetIOS()) {
|
||||
AFI->addGPRCalleeSavedArea2Frame(FI);
|
||||
if (STI.isTargetIOS())
|
||||
GPRCS2Size += 4;
|
||||
} else {
|
||||
AFI->addGPRCalleeSavedArea1Frame(FI);
|
||||
else
|
||||
GPRCS1Size += 4;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
// This is a DPR. Exclude the aligned DPRCS2 spills.
|
||||
if (Reg == ARM::D8)
|
||||
D8SpillFI = FI;
|
||||
if (Reg < ARM::D8 || Reg >= ARM::D8 + AFI->getNumAlignedDPRCS2Regs()) {
|
||||
AFI->addDPRCalleeSavedAreaFrame(FI);
|
||||
if (Reg < ARM::D8 || Reg >= ARM::D8 + AFI->getNumAlignedDPRCS2Regs())
|
||||
DPRCSSize += 8;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Move past area 1.
|
||||
if (GPRCS1Size > 0) MBBI++;
|
||||
|
||||
// Set FP to point to the stack slot that contains the previous FP.
|
||||
// For iOS, FP is R7, which has now been stored in spill area 1.
|
||||
// Otherwise, if this is not iOS, all the callee-saved registers go
|
||||
// into spill area 1, including the FP in R11. In either case, it is
|
||||
// now safe to emit this assignment.
|
||||
bool HasFP = hasFP(MF);
|
||||
if (HasFP) {
|
||||
unsigned ADDriOpc = !AFI->isThumbFunction() ? ARM::ADDri : ARM::t2ADDri;
|
||||
MachineInstrBuilder MIB =
|
||||
BuildMI(MBB, MBBI, dl, TII.get(ADDriOpc), FramePtr)
|
||||
.addFrameIndex(FramePtrSpillFI).addImm(0)
|
||||
.setMIFlag(MachineInstr::FrameSetup);
|
||||
AddDefaultCC(AddDefaultPred(MIB));
|
||||
}
|
||||
|
||||
// Move past area 2.
|
||||
if (GPRCS2Size > 0) MBBI++;
|
||||
|
||||
// Determine starting offsets of spill areas.
|
||||
bool HasFP = hasFP(MF);
|
||||
unsigned DPRCSOffset = NumBytes - (GPRCS1Size + GPRCS2Size + DPRCSSize);
|
||||
unsigned GPRCS2Offset = DPRCSOffset + DPRCSSize;
|
||||
unsigned GPRCS1Offset = GPRCS2Offset + GPRCS2Size;
|
||||
@ -247,6 +235,21 @@ void ARMFrameLowering::emitPrologue(MachineFunction &MF) const {
|
||||
AFI->setGPRCalleeSavedArea2Offset(GPRCS2Offset);
|
||||
AFI->setDPRCalleeSavedAreaOffset(DPRCSOffset);
|
||||
|
||||
// Set FP to point to the stack slot that contains the previous FP.
|
||||
// For iOS, FP is R7, which has now been stored in spill area 1.
|
||||
// Otherwise, if this is not iOS, all the callee-saved registers go
|
||||
// into spill area 1, including the FP in R11. In either case, it is
|
||||
// now safe to emit this assignment.
|
||||
if (HasFP) {
|
||||
int FramePtrOffset = MFI->getObjectOffset(FramePtrSpillFI) + GPRCS1Size;
|
||||
emitRegPlusImmediate(!AFI->isThumbFunction(), MBB, MBBI, dl, TII,
|
||||
FramePtr, ARM::SP, FramePtrOffset,
|
||||
MachineInstr::FrameSetup);
|
||||
}
|
||||
|
||||
// Move past area 2.
|
||||
if (GPRCS2Size > 0) MBBI++;
|
||||
|
||||
// Move past area 3.
|
||||
if (DPRCSSize > 0) {
|
||||
MBBI++;
|
||||
@ -506,12 +509,6 @@ ARMFrameLowering::ResolveFrameIndexReference(const MachineFunction &MF,
|
||||
|
||||
FrameReg = ARM::SP;
|
||||
Offset += SPAdj;
|
||||
if (AFI->isGPRCalleeSavedArea1Frame(FI))
|
||||
return Offset - AFI->getGPRCalleeSavedArea1Offset();
|
||||
else if (AFI->isGPRCalleeSavedArea2Frame(FI))
|
||||
return Offset - AFI->getGPRCalleeSavedArea2Offset();
|
||||
else if (AFI->isDPRCalleeSavedAreaFrame(FI))
|
||||
return Offset - AFI->getDPRCalleeSavedAreaOffset();
|
||||
|
||||
// SP can move around if there are allocas. We may also lose track of SP
|
||||
// when emergency spilling inside a non-reserved call frame setup.
|
||||
|
@ -84,12 +84,6 @@ class ARMFunctionInfo : public MachineFunctionInfo {
|
||||
unsigned GPRCS2Size;
|
||||
unsigned DPRCSSize;
|
||||
|
||||
/// GPRCS1Frames, GPRCS2Frames, DPRCSFrames - Keeps track of frame indices
|
||||
/// which belong to these spill areas.
|
||||
BitVector GPRCS1Frames;
|
||||
BitVector GPRCS2Frames;
|
||||
BitVector DPRCSFrames;
|
||||
|
||||
/// NumAlignedDPRCS2Regs - The number of callee-saved DPRs that are saved in
|
||||
/// the aligned portion of the stack frame. This is always a contiguous
|
||||
/// sequence of D-registers starting from d8.
|
||||
@ -128,7 +122,6 @@ public:
|
||||
LRSpilledForFarJump(false),
|
||||
FramePtrSpillOffset(0), GPRCS1Offset(0), GPRCS2Offset(0), DPRCSOffset(0),
|
||||
GPRCS1Size(0), GPRCS2Size(0), DPRCSSize(0),
|
||||
GPRCS1Frames(0), GPRCS2Frames(0), DPRCSFrames(0),
|
||||
NumAlignedDPRCS2Regs(0),
|
||||
JumpTableUId(0), PICLabelUId(0),
|
||||
VarArgsFrameIndex(0), HasITBlocks(false), GlobalBaseReg(0) {}
|
||||
@ -141,7 +134,6 @@ public:
|
||||
LRSpilledForFarJump(false),
|
||||
FramePtrSpillOffset(0), GPRCS1Offset(0), GPRCS2Offset(0), DPRCSOffset(0),
|
||||
GPRCS1Size(0), GPRCS2Size(0), DPRCSSize(0),
|
||||
GPRCS1Frames(32), GPRCS2Frames(32), DPRCSFrames(32),
|
||||
JumpTableUId(0), PICLabelUId(0),
|
||||
VarArgsFrameIndex(0), HasITBlocks(false), GlobalBaseReg(0) {}
|
||||
|
||||
@ -190,59 +182,6 @@ public:
|
||||
void setGPRCalleeSavedArea2Size(unsigned s) { GPRCS2Size = s; }
|
||||
void setDPRCalleeSavedAreaSize(unsigned s) { DPRCSSize = s; }
|
||||
|
||||
bool isGPRCalleeSavedArea1Frame(int fi) const {
|
||||
if (fi < 0 || fi >= (int)GPRCS1Frames.size())
|
||||
return false;
|
||||
return GPRCS1Frames[fi];
|
||||
}
|
||||
bool isGPRCalleeSavedArea2Frame(int fi) const {
|
||||
if (fi < 0 || fi >= (int)GPRCS2Frames.size())
|
||||
return false;
|
||||
return GPRCS2Frames[fi];
|
||||
}
|
||||
bool isDPRCalleeSavedAreaFrame(int fi) const {
|
||||
if (fi < 0 || fi >= (int)DPRCSFrames.size())
|
||||
return false;
|
||||
return DPRCSFrames[fi];
|
||||
}
|
||||
|
||||
void addGPRCalleeSavedArea1Frame(int fi) {
|
||||
if (fi >= 0) {
|
||||
int Size = GPRCS1Frames.size();
|
||||
if (fi >= Size) {
|
||||
Size *= 2;
|
||||
if (fi >= Size)
|
||||
Size = fi+1;
|
||||
GPRCS1Frames.resize(Size);
|
||||
}
|
||||
GPRCS1Frames[fi] = true;
|
||||
}
|
||||
}
|
||||
void addGPRCalleeSavedArea2Frame(int fi) {
|
||||
if (fi >= 0) {
|
||||
int Size = GPRCS2Frames.size();
|
||||
if (fi >= Size) {
|
||||
Size *= 2;
|
||||
if (fi >= Size)
|
||||
Size = fi+1;
|
||||
GPRCS2Frames.resize(Size);
|
||||
}
|
||||
GPRCS2Frames[fi] = true;
|
||||
}
|
||||
}
|
||||
void addDPRCalleeSavedAreaFrame(int fi) {
|
||||
if (fi >= 0) {
|
||||
int Size = DPRCSFrames.size();
|
||||
if (fi >= Size) {
|
||||
Size *= 2;
|
||||
if (fi >= Size)
|
||||
Size = fi+1;
|
||||
DPRCSFrames.resize(Size);
|
||||
}
|
||||
DPRCSFrames[fi] = true;
|
||||
}
|
||||
}
|
||||
|
||||
unsigned createJumpTableUId() {
|
||||
return JumpTableUId++;
|
||||
}
|
||||
|
@ -127,7 +127,6 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
||||
case ARM::LR:
|
||||
if (Reg == FramePtr)
|
||||
FramePtrSpillFI = FI;
|
||||
AFI->addGPRCalleeSavedArea1Frame(FI);
|
||||
GPRCS1Size += 4;
|
||||
break;
|
||||
case ARM::R8:
|
||||
@ -136,16 +135,12 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
||||
case ARM::R11:
|
||||
if (Reg == FramePtr)
|
||||
FramePtrSpillFI = FI;
|
||||
if (STI.isTargetIOS()) {
|
||||
AFI->addGPRCalleeSavedArea2Frame(FI);
|
||||
if (STI.isTargetIOS())
|
||||
GPRCS2Size += 4;
|
||||
} else {
|
||||
AFI->addGPRCalleeSavedArea1Frame(FI);
|
||||
else
|
||||
GPRCS1Size += 4;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
AFI->addDPRCalleeSavedAreaFrame(FI);
|
||||
DPRCSSize += 8;
|
||||
}
|
||||
}
|
||||
@ -171,8 +166,9 @@ void Thumb1FrameLowering::emitPrologue(MachineFunction &MF) const {
|
||||
|
||||
// Adjust FP so it point to the stack slot that contains the previous FP.
|
||||
if (HasFP) {
|
||||
int FramePtrOffset = MFI->getObjectOffset(FramePtrSpillFI) + GPRCS1Size;
|
||||
AddDefaultPred(BuildMI(MBB, MBBI, dl, TII.get(ARM::tADDrSPi), FramePtr)
|
||||
.addFrameIndex(FramePtrSpillFI).addImm(0)
|
||||
.addReg(ARM::SP).addImm(FramePtrOffset / 4)
|
||||
.setMIFlags(MachineInstr::FrameSetup));
|
||||
if (NumBytes > 508)
|
||||
// If offset is > 508 then sp cannot be adjusted in a single instruction,
|
||||
|
@ -573,11 +573,7 @@ Thumb1RegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,
|
||||
int Offset = MF.getFrameInfo()->getObjectOffset(FrameIndex) +
|
||||
MF.getFrameInfo()->getStackSize() + SPAdj;
|
||||
|
||||
if (AFI->isGPRCalleeSavedArea1Frame(FrameIndex))
|
||||
Offset -= AFI->getGPRCalleeSavedArea1Offset();
|
||||
else if (AFI->isGPRCalleeSavedArea2Frame(FrameIndex))
|
||||
Offset -= AFI->getGPRCalleeSavedArea2Offset();
|
||||
else if (MF.getFrameInfo()->hasVarSizedObjects()) {
|
||||
if (MF.getFrameInfo()->hasVarSizedObjects()) {
|
||||
assert(SPAdj == 0 && MF.getTarget().getFrameLowering()->hasFP(MF) &&
|
||||
"Unexpected");
|
||||
// There are alloca()'s in this function, must reference off the frame
|
||||
|
@ -215,6 +215,13 @@ void llvm::emitT2RegPlusImmediate(MachineBasicBlock &MBB,
|
||||
unsigned DestReg, unsigned BaseReg, int NumBytes,
|
||||
ARMCC::CondCodes Pred, unsigned PredReg,
|
||||
const ARMBaseInstrInfo &TII, unsigned MIFlags) {
|
||||
if (NumBytes == 0 && DestReg != BaseReg) {
|
||||
BuildMI(MBB, MBBI, dl, TII.get(ARM::tMOVr), DestReg)
|
||||
.addReg(BaseReg, RegState::Kill)
|
||||
.addImm((unsigned)Pred).addReg(PredReg).setMIFlags(MIFlags);
|
||||
return;
|
||||
}
|
||||
|
||||
bool isSub = NumBytes < 0;
|
||||
if (isSub) NumBytes = -NumBytes;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user