diff options
Diffstat (limited to 'llvm/lib/Target/PowerPC')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCFrameInfo.cpp | 41 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCFrameInfo.h | 2 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp | 52 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCRegisterInfo.h | 5 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCRegisterInfo.td | 11 | 
5 files changed, 54 insertions, 57 deletions
| diff --git a/llvm/lib/Target/PowerPC/PPCFrameInfo.cpp b/llvm/lib/Target/PowerPC/PPCFrameInfo.cpp index 3823e3f5fa4..453975c2671 100644 --- a/llvm/lib/Target/PowerPC/PPCFrameInfo.cpp +++ b/llvm/lib/Target/PowerPC/PPCFrameInfo.cpp @@ -222,12 +222,25 @@ void PPCFrameInfo::determineFrameLayout(MachineFunction &MF) const {    MFI->setStackSize(FrameSize);  } +// hasFP - Return true if the specified function actually has a dedicated frame +// pointer register. +bool PPCFrameInfo::hasFP(const MachineFunction &MF) const { +  const MachineFrameInfo *MFI = MF.getFrameInfo(); + +  // Naked functions have no stack frame pushed, so we don't have a frame +  // pointer. +  if (MF.getFunction()->hasFnAttr(Attribute::Naked)) +    return false; + +  return DisableFramePointerElim(MF) || MFI->hasVarSizedObjects() || +    (GuaranteedTailCallOpt && MF.getInfo<PPCFunctionInfo>()->hasFastCall()); +} + +  void PPCFrameInfo::emitPrologue(MachineFunction &MF) const {    MachineBasicBlock &MBB = MF.front();   // Prolog goes in entry BB    MachineBasicBlock::iterator MBBI = MBB.begin();    MachineFrameInfo *MFI = MF.getFrameInfo(); -  const PPCRegisterInfo *RegInfo = -    static_cast<const PPCRegisterInfo*>(MF.getTarget().getRegisterInfo());    const PPCInstrInfo &TII =      *static_cast<const PPCInstrInfo*>(MF.getTarget().getInstrInfo()); @@ -266,7 +279,7 @@ void PPCFrameInfo::emitPrologue(MachineFunction &MF) const {    PPCFunctionInfo *FI = MF.getInfo<PPCFunctionInfo>();    bool MustSaveLR = FI->mustSaveLR();    // Do we have a frame pointer for this function? -  bool HasFP = RegInfo->hasFP(MF) && FrameSize; +  bool HasFP = hasFP(MF) && FrameSize;    int LROffset = PPCFrameInfo::getReturnSaveOffset(isPPC64, isDarwinABI); @@ -471,21 +484,19 @@ void PPCFrameInfo::emitPrologue(MachineFunction &MF) const {  void PPCFrameInfo::emitEpilogue(MachineFunction &MF,                                  MachineBasicBlock &MBB) const {    MachineBasicBlock::iterator MBBI = prior(MBB.end()); -  const PPCRegisterInfo *RegInfo = -    static_cast<const PPCRegisterInfo*>(MF.getTarget().getRegisterInfo());    const PPCInstrInfo &TII =      *static_cast<const PPCInstrInfo*>(MF.getTarget().getInstrInfo());    unsigned RetOpcode = MBBI->getOpcode();    DebugLoc dl; -  assert( (RetOpcode == PPC::BLR || -           RetOpcode == PPC::TCRETURNri || -           RetOpcode == PPC::TCRETURNdi || -           RetOpcode == PPC::TCRETURNai || -           RetOpcode == PPC::TCRETURNri8 || -           RetOpcode == PPC::TCRETURNdi8 || -           RetOpcode == PPC::TCRETURNai8) && +  assert((RetOpcode == PPC::BLR || +          RetOpcode == PPC::TCRETURNri || +          RetOpcode == PPC::TCRETURNdi || +          RetOpcode == PPC::TCRETURNai || +          RetOpcode == PPC::TCRETURNri8 || +          RetOpcode == PPC::TCRETURNdi8 || +          RetOpcode == PPC::TCRETURNai8) &&           "Can only insert epilog into returning blocks");    // Get alignment info so we know how to restore r1 @@ -504,7 +515,7 @@ void PPCFrameInfo::emitEpilogue(MachineFunction &MF,    PPCFunctionInfo *FI = MF.getInfo<PPCFunctionInfo>();    bool MustSaveLR = FI->mustSaveLR();    // Do we have a frame pointer for this function? -  bool HasFP = RegInfo->hasFP(MF) && FrameSize; +  bool HasFP = hasFP(MF) && FrameSize;    int LROffset = PPCFrameInfo::getReturnSaveOffset(isPPC64, isDarwinABI); @@ -550,7 +561,7 @@ void PPCFrameInfo::emitEpilogue(MachineFunction &MF,        // call which invalidates the stack pointer value in SP(0). So we use the        // value of R31 in this case.        if (FI->hasFastCall() && isInt<16>(FrameSize)) { -        assert(RegInfo->hasFP(MF) && "Expecting a valid the frame pointer."); +        assert(hasFP(MF) && "Expecting a valid the frame pointer.");          BuildMI(MBB, MBBI, dl, TII.get(PPC::ADDI), PPC::R1)            .addReg(PPC::R31).addImm(FrameSize);        } else if(FI->hasFastCall()) { @@ -574,7 +585,7 @@ void PPCFrameInfo::emitEpilogue(MachineFunction &MF,        }      } else {        if (FI->hasFastCall() && isInt<16>(FrameSize)) { -        assert(RegInfo->hasFP(MF) && "Expecting a valid the frame pointer."); +        assert(hasFP(MF) && "Expecting a valid the frame pointer.");          BuildMI(MBB, MBBI, dl, TII.get(PPC::ADDI8), PPC::X1)            .addReg(PPC::X31).addImm(FrameSize);        } else if(FI->hasFastCall()) { diff --git a/llvm/lib/Target/PowerPC/PPCFrameInfo.h b/llvm/lib/Target/PowerPC/PPCFrameInfo.h index c04d1f51db2..aeaa864e0ab 100644 --- a/llvm/lib/Target/PowerPC/PPCFrameInfo.h +++ b/llvm/lib/Target/PowerPC/PPCFrameInfo.h @@ -37,6 +37,8 @@ public:    void emitPrologue(MachineFunction &MF) const;    void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const; +  bool hasFP(const MachineFunction &MF) const; +    /// targetHandlesStackFrameRounding - Returns true if the target is    /// responsible for rounding up the stack frame (probably at emitPrologue    /// time). diff --git a/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp b/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp index e7293f1140d..0459c7f1ee5 100644 --- a/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp +++ b/llvm/lib/Target/PowerPC/PPCRegisterInfo.cpp @@ -259,19 +259,6 @@ PPCRegisterInfo::getCalleeSavedRegs(const MachineFunction *MF) const {    return Subtarget.isPPC64() ? SVR4_64_CalleeSavedRegs : SVR4_CalleeSavedRegs;  } -// needsFP - Return true if the specified function should have a dedicated frame -// pointer register.  This is true if the function has variable sized allocas or -// if frame pointer elimination is disabled. -// -static bool needsFP(const MachineFunction &MF) { -  const MachineFrameInfo *MFI = MF.getFrameInfo(); -  // Naked functions have no stack frame pushed, so we don't have a frame pointer. -  if (MF.getFunction()->hasFnAttr(Attribute::Naked)) -    return false; -  return DisableFramePointerElim(MF) || MFI->hasVarSizedObjects() || -    (GuaranteedTailCallOpt && MF.getInfo<PPCFunctionInfo>()->hasFastCall()); -} -  static bool spillsCR(const MachineFunction &MF) {    const PPCFunctionInfo *FuncInfo = MF.getInfo<PPCFunctionInfo>();    return FuncInfo->isCRSpilled(); @@ -279,6 +266,8 @@ static bool spillsCR(const MachineFunction &MF) {  BitVector PPCRegisterInfo::getReservedRegs(const MachineFunction &MF) const {    BitVector Reserved(getNumRegs()); +  const TargetFrameInfo *TFI = MF.getTarget().getFrameInfo(); +    Reserved.set(PPC::R0);    Reserved.set(PPC::R1);    Reserved.set(PPC::LR); @@ -324,7 +313,7 @@ BitVector PPCRegisterInfo::getReservedRegs(const MachineFunction &MF) const {      }    } -  if (needsFP(MF)) +  if (TFI->hasFP(MF))      Reserved.set(PPC::R31);    return Reserved; @@ -334,14 +323,6 @@ BitVector PPCRegisterInfo::getReservedRegs(const MachineFunction &MF) const {  // Stack Frame Processing methods  //===----------------------------------------------------------------------===// -// hasFP - Return true if the specified function actually has a dedicated frame -// pointer register.  This is true if the function needs a frame pointer and has -// a non-zero stack size. -bool PPCRegisterInfo::hasFP(const MachineFunction &MF) const { -  const MachineFrameInfo *MFI = MF.getFrameInfo(); -  return MFI->getStackSize() && needsFP(MF); -} -  /// MustSaveLR - Return true if this function requires that we save the LR  /// register onto the stack in the prolog and restore it in the epilog of the  /// function. @@ -583,6 +564,7 @@ PPCRegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,    MachineFunction &MF = *MBB.getParent();    // Get the frame info.    MachineFrameInfo *MFI = MF.getFrameInfo(); +  const TargetFrameInfo *TFI = MF.getTarget().getFrameInfo();    DebugLoc dl = MI.getDebugLoc();    // Find out which operand is the frame index. @@ -622,7 +604,8 @@ PPCRegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,      }    // Replace the FrameIndex with base register with GPR1 (SP) or GPR31 (FP). -  MI.getOperand(FIOperandNo).ChangeToRegister(hasFP(MF) ? PPC::R31 : PPC::R1, +  MI.getOperand(FIOperandNo).ChangeToRegister(TFI->hasFP(MF) ? +                                              PPC::R31 : PPC::R1,                                                false);    // Figure out if the offset in the instruction is shifted right two bits. This @@ -708,6 +691,8 @@ PPCRegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,  void  PPCRegisterInfo::processFunctionBeforeCalleeSavedScan(MachineFunction &MF,                                                        RegScavenger *RS) const { +  const TargetFrameInfo *TFI = MF.getTarget().getFrameInfo(); +    //  Save and clear the LR state.    PPCFunctionInfo *FI = MF.getInfo<PPCFunctionInfo>();    unsigned LR = getRARegister(); @@ -719,9 +704,9 @@ PPCRegisterInfo::processFunctionBeforeCalleeSavedScan(MachineFunction &MF,    bool isPPC64 = Subtarget.isPPC64();    bool isDarwinABI  = Subtarget.isDarwinABI();    MachineFrameInfo *MFI = MF.getFrameInfo(); -  +    // If the frame pointer save index hasn't been defined yet. -  if (!FPSI && needsFP(MF)) { +  if (!FPSI && TFI->hasFP(MF)) {      // Find out what the fix offset of the frame pointer save area.      int FPOffset = PPCFrameInfo::getFramePointerSaveOffset(isPPC64,                                                             isDarwinABI); @@ -736,7 +721,7 @@ PPCRegisterInfo::processFunctionBeforeCalleeSavedScan(MachineFunction &MF,    if (GuaranteedTailCallOpt && (TCSPDelta = FI->getTailCallSPDelta()) < 0) {      MF.getFrameInfo()->CreateFixedObject(-1 * TCSPDelta, TCSPDelta, true);    } -   +    // Reserve a slot closest to SP or frame pointer if we have a dynalloc or    // a large stack, which will require scavenging a register to materialize a    // large offset. @@ -745,7 +730,7 @@ PPCRegisterInfo::processFunctionBeforeCalleeSavedScan(MachineFunction &MF,    //        r0 for now.    if (EnableRegisterScavenging) // FIXME (64-bit): Enable. -    if (needsFP(MF) || spillsCR(MF)) { +    if (TFI->hasFP(MF) || spillsCR(MF)) {        const TargetRegisterClass *GPRC = &PPC::GPRCRegClass;        const TargetRegisterClass *G8RC = &PPC::G8RCRegClass;        const TargetRegisterClass *RC = isPPC64 ? G8RC : GPRC; @@ -766,12 +751,13 @@ PPCRegisterInfo::processFunctionBeforeFrameFinalized(MachineFunction &MF)    // Get callee saved register information.    MachineFrameInfo *FFI = MF.getFrameInfo();    const std::vector<CalleeSavedInfo> &CSI = FFI->getCalleeSavedInfo(); +  const TargetFrameInfo *TFI = MF.getTarget().getFrameInfo();    // Early exit if no callee saved registers are modified! -  if (CSI.empty() && !needsFP(MF)) { +  if (CSI.empty() && !TFI->hasFP(MF)) {      return;    } -   +    unsigned MinGPR = PPC::R31;    unsigned MinG8R = PPC::X31;    unsigned MinFPR = PPC::F31; @@ -858,7 +844,7 @@ PPCRegisterInfo::processFunctionBeforeFrameFinalized(MachineFunction &MF)    // Check whether the frame pointer register is allocated. If so, make sure it    // is spilled to the correct offset. -  if (needsFP(MF)) { +  if (TFI->hasFP(MF)) {      HasGPSaveArea = true;      int FI = PFI->getFramePointerSaveIndex(); @@ -949,10 +935,12 @@ unsigned PPCRegisterInfo::getRARegister() const {  }  unsigned PPCRegisterInfo::getFrameRegister(const MachineFunction &MF) const { +  const TargetFrameInfo *TFI = MF.getTarget().getFrameInfo(); +    if (!Subtarget.isPPC64()) -    return hasFP(MF) ? PPC::R31 : PPC::R1; +    return TFI->hasFP(MF) ? PPC::R31 : PPC::R1;    else -    return hasFP(MF) ? PPC::X31 : PPC::X1; +    return TFI->hasFP(MF) ? PPC::X31 : PPC::X1;  }  void PPCRegisterInfo::getInitialFrameState(std::vector<MachineMove> &Moves) diff --git a/llvm/lib/Target/PowerPC/PPCRegisterInfo.h b/llvm/lib/Target/PowerPC/PPCRegisterInfo.h index 3d2aa6076ce..6e727420777 100644 --- a/llvm/lib/Target/PowerPC/PPCRegisterInfo.h +++ b/llvm/lib/Target/PowerPC/PPCRegisterInfo.h @@ -48,8 +48,6 @@ public:    /// FIXME (64-bit): Should be inlined.    bool requiresRegisterScavenging(const MachineFunction &MF) const; -  bool hasFP(const MachineFunction &MF) const; -    void eliminateCallFramePseudoInstr(MachineFunction &MF,                                       MachineBasicBlock &MBB,                                       MachineBasicBlock::iterator I) const; @@ -65,9 +63,6 @@ public:                                              RegScavenger *RS = NULL) const;    void processFunctionBeforeFrameFinalized(MachineFunction &MF) const; -  void emitPrologue(MachineFunction &MF) const; -  void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const; -    // Debug information queries.    unsigned getRARegister() const;    unsigned getFrameRegister(const MachineFunction &MF) const; diff --git a/llvm/lib/Target/PowerPC/PPCRegisterInfo.td b/llvm/lib/Target/PowerPC/PPCRegisterInfo.td index 8604f54de93..2fbd41bd84a 100644 --- a/llvm/lib/Target/PowerPC/PPCRegisterInfo.td +++ b/llvm/lib/Target/PowerPC/PPCRegisterInfo.td @@ -300,13 +300,13 @@ def GPRC : RegisterClass<"PPC", [i32], 32,        // R31 when the FP is not needed.        // When using the 32-bit SVR4 ABI, r13 is reserved for the Small Data Area        // pointer. -      const PPCSubtarget &Subtarget -        = MF.getTarget().getSubtarget<PPCSubtarget>(); -          +      const PPCSubtarget &Subtarget = MF.getTarget().getSubtarget<PPCSubtarget>(); +      const TargetFrameInfo *TFI = MF.getTarget().getFrameInfo(); +           if (Subtarget.isPPC64() || Subtarget.isSVR4ABI())          return end()-5;  // don't allocate R13, R31, R0, R1, LR -      if (needsFP(MF)) +      if (TFI->hasFP(MF))          return end()-4;  // don't allocate R31, R0, R1, LR        else          return end()-3;  // don't allocate R0, R1, LR @@ -331,7 +331,8 @@ def G8RC : RegisterClass<"PPC", [i64], 64,      }      G8RCClass::iterator      G8RCClass::allocation_order_end(const MachineFunction &MF) const { -      if (needsFP(MF)) +      const TargetFrameInfo *TFI = MF.getTarget().getFrameInfo(); +      if (TFI->hasFP(MF))          return end()-5;        else          return end()-4; | 

