diff options
| -rw-r--r-- | llvm/lib/Target/Mips/MipsFrameLowering.cpp | 34 | ||||
| -rw-r--r-- | llvm/lib/Target/Mips/MipsFrameLowering.h | 3 | 
2 files changed, 37 insertions, 0 deletions
diff --git a/llvm/lib/Target/Mips/MipsFrameLowering.cpp b/llvm/lib/Target/Mips/MipsFrameLowering.cpp index 6dd251c0547..2cad2a6264a 100644 --- a/llvm/lib/Target/Mips/MipsFrameLowering.cpp +++ b/llvm/lib/Target/Mips/MipsFrameLowering.cpp @@ -98,3 +98,37 @@ bool MipsFrameLowering::hasFP(const MachineFunction &MF) const {    return MF.getTarget().Options.DisableFramePointerElim(MF) ||        MFI->hasVarSizedObjects() || MFI->isFrameAddressTaken();  } + +uint64_t MipsFrameLowering::estimateStackSize(const MachineFunction &MF) const { +  const MachineFrameInfo *MFI = MF.getFrameInfo(); +  const TargetRegisterInfo &TRI = *MF.getTarget().getRegisterInfo(); + +  int64_t Offset = 0; + +  // Iterate over fixed sized objects. +  for (int I = MFI->getObjectIndexBegin(); I != 0; ++I) +    Offset = std::max(Offset, -MFI->getObjectOffset(I)); + +  // Conservatively assume all callee-saved registers will be saved. +  for (const uint16_t *R = TRI.getCalleeSavedRegs(&MF); *R; ++R) { +    unsigned Size = TRI.getMinimalPhysRegClass(*R)->getSize(); +    Offset = RoundUpToAlignment(Offset + Size, Size); +  } + +  unsigned MaxAlign = MFI->getMaxAlignment(); + +  // Check that MaxAlign is not zero if there is a stack object that is not a +  // callee-saved spill. +  assert(!MFI->getObjectIndexEnd() || MaxAlign); + +  // Iterate over other objects. +  for (unsigned I = 0, E = MFI->getObjectIndexEnd(); I != E; ++I) +    Offset = RoundUpToAlignment(Offset + MFI->getObjectSize(I), MaxAlign); + +  // Call frame. +  if (MFI->adjustsStack() && hasReservedCallFrame(MF)) +    Offset = RoundUpToAlignment(Offset + MFI->getMaxCallFrameSize(), +                                std::max(MaxAlign, getStackAlignment())); + +  return RoundUpToAlignment(Offset, getStackAlignment()); +} diff --git a/llvm/lib/Target/Mips/MipsFrameLowering.h b/llvm/lib/Target/Mips/MipsFrameLowering.h index ed7b7fe76c2..df52d92da83 100644 --- a/llvm/lib/Target/Mips/MipsFrameLowering.h +++ b/llvm/lib/Target/Mips/MipsFrameLowering.h @@ -34,6 +34,9 @@ public:                                           const MipsSubtarget &ST);    bool hasFP(const MachineFunction &MF) const; + +protected: +  uint64_t estimateStackSize(const MachineFunction &MF) const;  };  /// Create MipsInstrInfo objects.  | 

