diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/CodeGen/PrologEpilogInserter.cpp | 6 | ||||
| -rw-r--r-- | lib/Target/CellSPU/SPURegisterInfo.cpp | 12 | ||||
| -rw-r--r-- | lib/Target/PowerPC/PPCRegisterInfo.cpp | 10 | ||||
| -rw-r--r-- | lib/Target/X86/X86RegisterInfo.cpp | 35 | ||||
| -rw-r--r-- | lib/Target/XCore/XCoreRegisterInfo.cpp | 10 | 
5 files changed, 28 insertions, 45 deletions
| diff --git a/lib/CodeGen/PrologEpilogInserter.cpp b/lib/CodeGen/PrologEpilogInserter.cpp index 2d54cd4..27cb566 100644 --- a/lib/CodeGen/PrologEpilogInserter.cpp +++ b/lib/CodeGen/PrologEpilogInserter.cpp @@ -24,7 +24,6 @@  #include "llvm/CodeGen/MachineLoopInfo.h"  #include "llvm/CodeGen/MachineInstr.h"  #include "llvm/CodeGen/MachineFrameInfo.h" -#include "llvm/CodeGen/MachineModuleInfo.h"  #include "llvm/CodeGen/MachineRegisterInfo.h"  #include "llvm/CodeGen/RegisterScavenging.h"  #include "llvm/Target/TargetMachine.h" @@ -59,11 +58,6 @@ bool PEI::runOnMachineFunction(MachineFunction &Fn) {    FrameIndexVirtualScavenging = TRI->requiresFrameIndexScavenging(Fn);    FrameConstantRegMap.clear(); -  // Get MachineModuleInfo so that we can track the construction of the -  // frame. -  if (MachineModuleInfo *MMI = getAnalysisIfAvailable<MachineModuleInfo>()) -    Fn.getFrameInfo()->setMachineModuleInfo(MMI); -    // Calculate the MaxCallFrameSize and HasCalls variables for the function's    // frame information. Also eliminates call frame pseudo instructions.    calculateCallsInformation(Fn); diff --git a/lib/Target/CellSPU/SPURegisterInfo.cpp b/lib/Target/CellSPU/SPURegisterInfo.cpp index ad034eb..ffac581 100644 --- a/lib/Target/CellSPU/SPURegisterInfo.cpp +++ b/lib/Target/CellSPU/SPURegisterInfo.cpp @@ -451,11 +451,11 @@ void SPURegisterInfo::emitPrologue(MachineFunction &MF) const    MachineBasicBlock &MBB = MF.front();   // Prolog goes in entry BB    MachineBasicBlock::iterator MBBI = MBB.begin();    MachineFrameInfo *MFI = MF.getFrameInfo(); -  MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); +  MachineModuleInfo &MMI = MF.getMMI();    DebugLoc dl = MBBI != MBB.end() ? MBBI->getDebugLoc() : DebugLoc();    // Prepare for debug frame info. -  bool hasDebugInfo = MMI && MMI->hasDebugInfo(); +  bool hasDebugInfo = MMI.hasDebugInfo();    MCSymbol *FrameLabel = 0;    // Move MBBI back to the beginning of the function. @@ -473,7 +473,7 @@ void SPURegisterInfo::emitPrologue(MachineFunction &MF) const      FrameSize = -(FrameSize + SPUFrameInfo::minStackSize());      if (hasDebugInfo) {        // Mark effective beginning of when frame pointer becomes valid. -      FrameLabel = MMI->getContext().CreateTempSymbol(); +      FrameLabel = MMI.getContext().CreateTempSymbol();        BuildMI(MBB, MBBI, dl, TII.get(SPU::DBG_LABEL)).addSym(FrameLabel);      } @@ -516,7 +516,7 @@ void SPURegisterInfo::emitPrologue(MachineFunction &MF) const      }      if (hasDebugInfo) { -      std::vector<MachineMove> &Moves = MMI->getFrameMoves(); +      std::vector<MachineMove> &Moves = MMI.getFrameMoves();        // Show update of SP.        MachineLocation SPDst(MachineLocation::VirtualFP); @@ -535,7 +535,7 @@ void SPURegisterInfo::emitPrologue(MachineFunction &MF) const        }        // Mark effective beginning of when frame pointer is ready. -      MCSymbol *ReadyLabel = MMI->getContext().CreateTempSymbol(); +      MCSymbol *ReadyLabel = MMI.getContext().CreateTempSymbol();        BuildMI(MBB, MBBI, dl, TII.get(SPU::DBG_LABEL)).addSym(ReadyLabel);        MachineLocation FPDst(SPU::R1); @@ -552,7 +552,7 @@ void SPURegisterInfo::emitPrologue(MachineFunction &MF) const        // Insert terminator label        BuildMI(MBB, MBBI, dl, TII.get(SPU::DBG_LABEL)) -        .addSym(MMI->getContext().CreateTempSymbol()); +        .addSym(MMI.getContext().CreateTempSymbol());      }    }  } diff --git a/lib/Target/PowerPC/PPCRegisterInfo.cpp b/lib/Target/PowerPC/PPCRegisterInfo.cpp index 9363aa8..52d87cd 100644 --- a/lib/Target/PowerPC/PPCRegisterInfo.cpp +++ b/lib/Target/PowerPC/PPCRegisterInfo.cpp @@ -1280,9 +1280,9 @@ PPCRegisterInfo::emitPrologue(MachineFunction &MF) const {    MachineBasicBlock &MBB = MF.front();   // Prolog goes in entry BB    MachineBasicBlock::iterator MBBI = MBB.begin();    MachineFrameInfo *MFI = MF.getFrameInfo(); -  MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); +  MachineModuleInfo &MMI = MF.getMMI();    DebugLoc dl; -  bool needsFrameMoves = (MMI && MMI->hasDebugInfo()) || +  bool needsFrameMoves = MMI.hasDebugInfo() ||         !MF.getFunction()->doesNotThrow() ||         UnwindTablesMandatory; @@ -1442,13 +1442,13 @@ PPCRegisterInfo::emitPrologue(MachineFunction &MF) const {      }    } -  std::vector<MachineMove> &Moves = MMI->getFrameMoves(); +  std::vector<MachineMove> &Moves = MMI.getFrameMoves();    // Add the "machine moves" for the instructions we generated above, but in    // reverse order.    if (needsFrameMoves) {      // Mark effective beginning of when frame pointer becomes valid. -    FrameLabel = MMI->getContext().CreateTempSymbol(); +    FrameLabel = MMI.getContext().CreateTempSymbol();      BuildMI(MBB, MBBI, dl, TII.get(PPC::DBG_LABEL)).addSym(FrameLabel);      // Show update of SP. @@ -1489,7 +1489,7 @@ PPCRegisterInfo::emitPrologue(MachineFunction &MF) const {      }      if (needsFrameMoves) { -      ReadyLabel = MMI->getContext().CreateTempSymbol(); +      ReadyLabel = MMI.getContext().CreateTempSymbol();        // Mark effective beginning of when frame pointer is ready.        BuildMI(MBB, MBBI, dl, TII.get(PPC::DBG_LABEL)).addSym(ReadyLabel); diff --git a/lib/Target/X86/X86RegisterInfo.cpp b/lib/Target/X86/X86RegisterInfo.cpp index 3238cce..32f28a5 100644 --- a/lib/Target/X86/X86RegisterInfo.cpp +++ b/lib/Target/X86/X86RegisterInfo.cpp @@ -297,9 +297,7 @@ X86RegisterInfo::getCalleeSavedRegs(const MachineFunction *MF) const {    bool ghcCall = false;    if (MF) { -    const MachineFrameInfo *MFI = MF->getFrameInfo(); -    const MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); -    callsEHReturn = (MMI ? MMI->callsEHReturn() : false); +    callsEHReturn = MF->getMMI().callsEHReturn();      const Function *F = MF->getFunction();      ghcCall = (F ? F->getCallingConv() == CallingConv::GHC : false);    } @@ -348,12 +346,8 @@ X86RegisterInfo::getCalleeSavedRegs(const MachineFunction *MF) const {  const TargetRegisterClass* const*  X86RegisterInfo::getCalleeSavedRegClasses(const MachineFunction *MF) const {    bool callsEHReturn = false; - -  if (MF) { -    const MachineFrameInfo *MFI = MF->getFrameInfo(); -    const MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); -    callsEHReturn = (MMI ? MMI->callsEHReturn() : false); -  } +  if (MF) +    callsEHReturn = MF->getMMI().callsEHReturn();    static const TargetRegisterClass * const CalleeSavedRegClasses32Bit[] = {      &X86::GR32RegClass, &X86::GR32RegClass, @@ -443,14 +437,14 @@ BitVector X86RegisterInfo::getReservedRegs(const MachineFunction &MF) const {  /// or if frame pointer elimination is disabled.  bool X86RegisterInfo::hasFP(const MachineFunction &MF) const {    const MachineFrameInfo *MFI = MF.getFrameInfo(); -  const MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); +  const MachineModuleInfo &MMI = MF.getMMI();    return (NoFramePointerElim ||            needsStackRealignment(MF) ||            MFI->hasVarSizedObjects() ||            MFI->isFrameAddressTaken() ||            MF.getInfo<X86MachineFunctionInfo>()->getForceFramePointer() || -          (MMI && MMI->callsUnwindInit())); +          MMI.callsUnwindInit());  }  bool X86RegisterInfo::canRealignStack(const MachineFunction &MF) const { @@ -800,14 +794,13 @@ void X86RegisterInfo::emitCalleeSavedFrameMoves(MachineFunction &MF,                                                  MCSymbol *Label,                                                  unsigned FramePtr) const {    MachineFrameInfo *MFI = MF.getFrameInfo(); -  MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); -  if (!MMI) return; +  MachineModuleInfo &MMI = MF.getMMI();    // Add callee saved registers to move list.    const std::vector<CalleeSavedInfo> &CSI = MFI->getCalleeSavedInfo();    if (CSI.empty()) return; -  std::vector<MachineMove> &Moves = MMI->getFrameMoves(); +  std::vector<MachineMove> &Moves = MMI.getFrameMoves();    const TargetData *TD = MF.getTarget().getTargetData();    bool HasFP = hasFP(MF); @@ -874,9 +867,9 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {    MachineFrameInfo *MFI = MF.getFrameInfo();    const Function *Fn = MF.getFunction();    const X86Subtarget *Subtarget = &MF.getTarget().getSubtarget<X86Subtarget>(); -  MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); +  MachineModuleInfo &MMI = MF.getMMI();    X86MachineFunctionInfo *X86FI = MF.getInfo<X86MachineFunctionInfo>(); -  bool needsFrameMoves = (MMI && MMI->hasDebugInfo()) || +  bool needsFrameMoves = MMI.hasDebugInfo() ||                            !Fn->doesNotThrow() || UnwindTablesMandatory;    uint64_t MaxAlign  = MFI->getMaxAlignment(); // Desired stack alignment.    uint64_t StackSize = MFI->getStackSize();    // Number of bytes to allocate. @@ -935,7 +928,7 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {    //        REG < 64                    => DW_CFA_offset + Reg    //        ELSE                        => DW_CFA_offset_extended -  std::vector<MachineMove> &Moves = MMI->getFrameMoves(); +  std::vector<MachineMove> &Moves = MMI.getFrameMoves();    const TargetData *TD = MF.getTarget().getTargetData();    uint64_t NumBytes = 0;    int stackGrowth = -TD->getPointerSize(); @@ -959,7 +952,7 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {      if (needsFrameMoves) {        // Mark the place where EBP/RBP was saved. -      MCSymbol *FrameLabel = MMI->getContext().CreateTempSymbol(); +      MCSymbol *FrameLabel = MMI.getContext().CreateTempSymbol();        BuildMI(MBB, MBBI, DL, TII.get(X86::DBG_LABEL)).addSym(FrameLabel);        // Define the current CFA rule to use the provided offset. @@ -987,7 +980,7 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {      if (needsFrameMoves) {        // Mark effective beginning of when frame pointer becomes valid. -      MCSymbol *FrameLabel = MMI->getContext().CreateTempSymbol(); +      MCSymbol *FrameLabel = MMI.getContext().CreateTempSymbol();        BuildMI(MBB, MBBI, DL, TII.get(X86::DBG_LABEL)).addSym(FrameLabel);        // Define the current CFA to use the EBP/RBP register. @@ -1027,7 +1020,7 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {      if (!HasFP && needsFrameMoves) {        // Mark callee-saved push instruction. -      MCSymbol *Label = MMI->getContext().CreateTempSymbol(); +      MCSymbol *Label = MMI.getContext().CreateTempSymbol();        BuildMI(MBB, MBBI, DL, TII.get(X86::DBG_LABEL)).addSym(Label);        // Define the current CFA rule to use the provided offset. @@ -1099,7 +1092,7 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {    if ((NumBytes || PushedRegs) && needsFrameMoves) {      // Mark end of stack pointer adjustment. -    MCSymbol *Label = MMI->getContext().CreateTempSymbol(); +    MCSymbol *Label = MMI.getContext().CreateTempSymbol();      BuildMI(MBB, MBBI, DL, TII.get(X86::DBG_LABEL)).addSym(Label);      if (!HasFP && NumBytes) { diff --git a/lib/Target/XCore/XCoreRegisterInfo.cpp b/lib/Target/XCore/XCoreRegisterInfo.cpp index 1631e73..ab71d05 100644 --- a/lib/Target/XCore/XCoreRegisterInfo.cpp +++ b/lib/Target/XCore/XCoreRegisterInfo.cpp @@ -67,12 +67,8 @@ unsigned XCoreRegisterInfo::getNumArgRegs(const MachineFunction *MF)    return array_lengthof(XCore_ArgRegs);  } -bool XCoreRegisterInfo::needsFrameMoves(const MachineFunction &MF) -{ -  const MachineFrameInfo *MFI = MF.getFrameInfo(); -  MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); -  return (MMI && MMI->hasDebugInfo()) || -          !MF.getFunction()->doesNotThrow() || +bool XCoreRegisterInfo::needsFrameMoves(const MachineFunction &MF) { +  return MF.getMMI().hasDebugInfo() || !MF.getFunction()->doesNotThrow() ||            UnwindTablesMandatory;  } @@ -412,7 +408,7 @@ void XCoreRegisterInfo::emitPrologue(MachineFunction &MF) const {    MachineBasicBlock &MBB = MF.front();   // Prolog goes in entry BB    MachineBasicBlock::iterator MBBI = MBB.begin();    MachineFrameInfo *MFI = MF.getFrameInfo(); -  MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); +  MachineModuleInfo *MMI = &MF.getMMI();    XCoreFunctionInfo *XFI = MF.getInfo<XCoreFunctionInfo>();    DebugLoc dl = MBBI != MBB.end() ? MBBI->getDebugLoc() : DebugLoc(); | 
