forked from OSchip/llvm-project
ARM: Use range-based for loops in frame lowering.
No functional change. llvm-svn: 205602
This commit is contained in:
parent
96bd2a1490
commit
f92e8f5a8b
|
@ -316,10 +316,9 @@ void ARMFrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||
MachineBasicBlock::iterator Pos = ++GPRCS1Push;
|
||||
BuildMI(MBB, Pos, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||
.addCFIIndex(CFIIndex);
|
||||
for (std::vector<CalleeSavedInfo>::const_iterator I = CSI.begin(),
|
||||
E = CSI.end(); I != E; ++I) {
|
||||
unsigned Reg = I->getReg();
|
||||
int FI = I->getFrameIdx();
|
||||
for (const auto &Entry : CSI) {
|
||||
unsigned Reg = Entry.getReg();
|
||||
int FI = Entry.getFrameIdx();
|
||||
switch (Reg) {
|
||||
case ARM::R8:
|
||||
case ARM::R9:
|
||||
|
@ -382,10 +381,9 @@ void ARMFrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||
BuildMI(MBB, Pos, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
|
||||
.addCFIIndex(CFIIndex);
|
||||
}
|
||||
for (std::vector<CalleeSavedInfo>::const_iterator I = CSI.begin(),
|
||||
E = CSI.end(); I != E; ++I) {
|
||||
unsigned Reg = I->getReg();
|
||||
int FI = I->getFrameIdx();
|
||||
for (const auto &Entry : CSI) {
|
||||
unsigned Reg = Entry.getReg();
|
||||
int FI = Entry.getFrameIdx();
|
||||
switch (Reg) {
|
||||
case ARM::R8:
|
||||
case ARM::R9:
|
||||
|
@ -419,10 +417,9 @@ void ARMFrameLowering::emitPrologue(MachineFunction &MF) const {
|
|||
}
|
||||
} while (DPRCSPush->getOpcode() == ARM::VSTMDDB_UPD);
|
||||
|
||||
for (std::vector<CalleeSavedInfo>::const_iterator I = CSI.begin(),
|
||||
E = CSI.end(); I != E; ++I) {
|
||||
unsigned Reg = I->getReg();
|
||||
int FI = I->getFrameIdx();
|
||||
for (const auto &Entry : CSI) {
|
||||
unsigned Reg = Entry.getReg();
|
||||
int FI = Entry.getFrameIdx();
|
||||
if ((Reg >= ARM::D0 && Reg <= ARM::D31) &&
|
||||
(Reg < ARM::D8 || Reg >= ARM::D8 + AFI->getNumAlignedDPRCS2Regs())) {
|
||||
unsigned DwarfReg = MRI->getDwarfRegNum(Reg, true);
|
||||
|
@ -1205,12 +1202,9 @@ bool ARMFrameLowering::restoreCalleeSavedRegisters(MachineBasicBlock &MBB,
|
|||
static unsigned GetFunctionSizeInBytes(const MachineFunction &MF,
|
||||
const ARMBaseInstrInfo &TII) {
|
||||
unsigned FnSize = 0;
|
||||
for (MachineFunction::const_iterator MBBI = MF.begin(), E = MF.end();
|
||||
MBBI != E; ++MBBI) {
|
||||
const MachineBasicBlock &MBB = *MBBI;
|
||||
for (MachineBasicBlock::const_iterator I = MBB.begin(),E = MBB.end();
|
||||
I != E; ++I)
|
||||
FnSize += TII.GetInstSizeInBytes(I);
|
||||
for (auto &MBB : MF) {
|
||||
for (auto &MI : MBB)
|
||||
FnSize += TII.GetInstSizeInBytes(&MI);
|
||||
}
|
||||
return FnSize;
|
||||
}
|
||||
|
@ -1223,21 +1217,21 @@ static unsigned estimateRSStackSizeLimit(MachineFunction &MF,
|
|||
const TargetFrameLowering *TFI) {
|
||||
const ARMFunctionInfo *AFI = MF.getInfo<ARMFunctionInfo>();
|
||||
unsigned Limit = (1 << 12) - 1;
|
||||
for (MachineFunction::iterator BB = MF.begin(),E = MF.end(); BB != E; ++BB) {
|
||||
for (MachineBasicBlock::iterator I = BB->begin(), E = BB->end();
|
||||
I != E; ++I) {
|
||||
for (unsigned i = 0, e = I->getNumOperands(); i != e; ++i) {
|
||||
if (!I->getOperand(i).isFI()) continue;
|
||||
for (auto &MBB : MF) {
|
||||
for (auto &MI : MBB) {
|
||||
for (unsigned i = 0, e = MI.getNumOperands(); i != e; ++i) {
|
||||
if (!MI.getOperand(i).isFI())
|
||||
continue;
|
||||
|
||||
// When using ADDri to get the address of a stack object, 255 is the
|
||||
// largest offset guaranteed to fit in the immediate offset.
|
||||
if (I->getOpcode() == ARM::ADDri) {
|
||||
if (MI.getOpcode() == ARM::ADDri) {
|
||||
Limit = std::min(Limit, (1U << 8) - 1);
|
||||
break;
|
||||
}
|
||||
|
||||
// Otherwise check the addressing mode.
|
||||
switch (I->getDesc().TSFlags & ARMII::AddrModeMask) {
|
||||
switch (MI.getDesc().TSFlags & ARMII::AddrModeMask) {
|
||||
case ARMII::AddrMode3:
|
||||
case ARMII::AddrModeT2_i8:
|
||||
Limit = std::min(Limit, (1U << 8) - 1);
|
||||
|
|
Loading…
Reference in New Issue