diff options
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/WinException.cpp | 15 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/PrologEpilogInserter.cpp | 13 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86FrameLowering.cpp | 24 | ||||
| -rw-r--r-- | llvm/lib/Target/X86/X86FrameLowering.h | 7 | 
4 files changed, 28 insertions, 31 deletions
| diff --git a/llvm/lib/CodeGen/AsmPrinter/WinException.cpp b/llvm/lib/CodeGen/AsmPrinter/WinException.cpp index 083aacb3fc5..0314ab065d5 100644 --- a/llvm/lib/CodeGen/AsmPrinter/WinException.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/WinException.cpp @@ -34,6 +34,7 @@  #include "llvm/Support/ErrorHandling.h"  #include "llvm/Support/FormattedStream.h"  #include "llvm/Target/TargetFrameLowering.h" +#include "llvm/Target/TargetLowering.h"  #include "llvm/Target/TargetLoweringObjectFile.h"  #include "llvm/Target/TargetOptions.h"  #include "llvm/Target/TargetRegisterInfo.h" @@ -301,9 +302,17 @@ int WinException::getFrameIndexOffset(int FrameIndex,                                        const WinEHFuncInfo &FuncInfo) {    const TargetFrameLowering &TFI = *Asm->MF->getSubtarget().getFrameLowering();    unsigned UnusedReg; -  if (Asm->MAI->usesWindowsCFI()) -    return *TFI.getFrameIndexReferenceFromSP(*Asm->MF, FrameIndex, UnusedReg, -                                             /*AllowSPAdjustment*/ true); +  if (Asm->MAI->usesWindowsCFI()) { +    int Offset = +        TFI.getFrameIndexReferencePreferSP(*Asm->MF, FrameIndex, UnusedReg, +                                           /*IgnoreSPUpdates*/ true); +    assert(UnusedReg == +           Asm->MF->getSubtarget() +               .getTargetLowering() +               ->getStackPointerRegisterToSaveRestore()); +    return Offset; +  } +    // For 32-bit, offsets should be relative to the end of the EH registration    // node. For 64-bit, it's relative to SP at the end of the prologue.    assert(FuncInfo.EHRegNodeEndOffset != INT_MAX); diff --git a/llvm/lib/CodeGen/PrologEpilogInserter.cpp b/llvm/lib/CodeGen/PrologEpilogInserter.cpp index 33935c421a3..ca30af92e5e 100644 --- a/llvm/lib/CodeGen/PrologEpilogInserter.cpp +++ b/llvm/lib/CodeGen/PrologEpilogInserter.cpp @@ -1094,17 +1094,8 @@ void PEI::replaceFrameIndices(MachineBasicBlock *BB, MachineFunction &Fn,                 "DBG_VALUE machine instruction");          unsigned Reg;          MachineOperand &Offset = MI->getOperand(i + 1); -        int refOffset; -        // First try to get an offset relative to SP. If that's not -        // possible use whatever the target usually uses. -        auto SPOffset = TFI->getFrameIndexReferenceFromSP( -            Fn, MI->getOperand(i).getIndex(), Reg, /*AllowSPAdjustment*/ false); -        if (SPOffset) -          refOffset = *SPOffset; -        else -          refOffset = TFI->getFrameIndexReference( -              Fn, MI->getOperand(i).getIndex(), Reg); - +        int refOffset = TFI->getFrameIndexReferencePreferSP( +            Fn, MI->getOperand(i).getIndex(), Reg, /*IgnoreSPUpdates*/ false);          Offset.setImm(Offset.getImm() + refOffset);          MI->getOperand(i).ChangeToRegister(Reg, false /*isDef*/);          continue; diff --git a/llvm/lib/Target/X86/X86FrameLowering.cpp b/llvm/lib/Target/X86/X86FrameLowering.cpp index 2be00ca1707..83446336fd7 100644 --- a/llvm/lib/Target/X86/X86FrameLowering.cpp +++ b/llvm/lib/Target/X86/X86FrameLowering.cpp @@ -1433,12 +1433,10 @@ static bool isFuncletReturnInstr(MachineInstr *MI) {  unsigned  X86FrameLowering::getPSPSlotOffsetFromSP(const MachineFunction &MF) const {    const WinEHFuncInfo &Info = *MF.getWinEHFuncInfo(); -  // getFrameIndexReferenceFromSP has an out ref parameter for the stack -  // pointer register; pass a dummy that we ignore    unsigned SPReg; -  int Offset = *getFrameIndexReferenceFromSP(MF, Info.PSPSymFrameIdx, SPReg, -                                             /*AllowSPAdjustment*/ true); -  assert(Offset >= 0); +  int Offset = getFrameIndexReferencePreferSP(MF, Info.PSPSymFrameIdx, SPReg, +                                              /*IgnoreSPUpdates*/ true); +  assert(Offset >= 0 && SPReg == TRI->getStackRegister());    return static_cast<unsigned>(Offset);  } @@ -1722,11 +1720,11 @@ int X86FrameLowering::getFrameIndexReference(const MachineFunction &MF, int FI,    return Offset + FPDelta;  } -// Simplified from getFrameIndexReference keeping only StackPointer cases -Optional<int> -X86FrameLowering::getFrameIndexReferenceFromSP(const MachineFunction &MF, -                                               int FI, unsigned &FrameReg, -                                               bool AllowSPAdjustment) const { +int +X86FrameLowering::getFrameIndexReferencePreferSP(const MachineFunction &MF, +                                                 int FI, unsigned &FrameReg, +                                                 bool IgnoreSPUpdates) const { +    const MachineFrameInfo *MFI = MF.getFrameInfo();    // Does not include any dynamic realign.    const uint64_t StackSize = MFI->getStackSize(); @@ -1765,14 +1763,14 @@ X86FrameLowering::getFrameIndexReferenceFromSP(const MachineFunction &MF,    if (MFI->isFixedObjectIndex(FI) && TRI->needsStackRealignment(MF) &&        !STI.isTargetWin64()) -    return None; +    return getFrameIndexReference(MF, FI, FrameReg);    // If !hasReservedCallFrame the function might have SP adjustement in the    // body.  So, even though the offset is statically known, it depends on where    // we are in the function.    const TargetFrameLowering *TFI = MF.getSubtarget().getFrameLowering(); -  if (!AllowSPAdjustment && !TFI->hasReservedCallFrame(MF)) -    return None; +  if (!IgnoreSPUpdates && !TFI->hasReservedCallFrame(MF)) +    return getFrameIndexReference(MF, FI, FrameReg);    // We don't handle tail calls, and shouldn't be seeing them either.    assert(MF.getInfo<X86MachineFunctionInfo>()->getTCReturnAddrDelta() >= 0 && diff --git a/llvm/lib/Target/X86/X86FrameLowering.h b/llvm/lib/Target/X86/X86FrameLowering.h index 192ec0e8b5f..4a01014ee54 100644 --- a/llvm/lib/Target/X86/X86FrameLowering.h +++ b/llvm/lib/Target/X86/X86FrameLowering.h @@ -100,10 +100,9 @@ public:    int getFrameIndexReference(const MachineFunction &MF, int FI,                               unsigned &FrameReg) const override; -  Optional<int> -  getFrameIndexReferenceFromSP(const MachineFunction &MF, int FI, -                               unsigned &FrameReg, -                               bool AllowSPAdjustment) const override; +  int getFrameIndexReferencePreferSP(const MachineFunction &MF, int FI, +                                     unsigned &FrameReg, +                                     bool IgnoreSPUpdates) const override;    MachineBasicBlock::iterator    eliminateCallFramePseudoInstr(MachineFunction &MF, MachineBasicBlock &MBB, | 

