diff options
author | Anton Korobeynikov <asl@math.spbu.ru> | 2009-08-03 08:14:30 +0000 |
---|---|---|
committer | Anton Korobeynikov <asl@math.spbu.ru> | 2009-08-03 08:14:30 +0000 |
commit | dd93f5eb7196e0235db72c7bac49912410c37a51 (patch) | |
tree | 9e5289845a99d27d30bd935b68c79b04281fcaee | |
parent | 6dde14bc25a0dca2e1ff45753f3f5ae55a4eb109 (diff) |
Create proper frame index for FP
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@77966 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/X86/X86RegisterInfo.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/lib/Target/X86/X86RegisterInfo.cpp b/lib/Target/X86/X86RegisterInfo.cpp index 5817bf0ac6..21f4dc5694 100644 --- a/lib/Target/X86/X86RegisterInfo.cpp +++ b/lib/Target/X86/X86RegisterInfo.cpp @@ -653,9 +653,11 @@ X86RegisterInfo::processFunctionBeforeCalleeSavedScan(MachineFunction &MF, if (hasFP(MF)) { assert((TailCallReturnAddrDelta <= 0) && "The Delta should always be zero or negative"); + const TargetFrameInfo &TFI = *MF.getTarget().getFrameInfo(); // Create a frame entry for the EBP register that must be saved. int FrameIdx = MFI->CreateFixedObject(SlotSize, - (int)SlotSize * -2+ + -(int)SlotSize + + TFI.getOffsetOfLocalArea() + TailCallReturnAddrDelta); assert(FrameIdx == MFI->getObjectIndexBegin() && "Slot for EBP register must be last in order to be found!"); |