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 | 03056efe01f4c606cb62a4805af461e6a65c53ef (patch) | |
tree | 8120244066a694f259e7bdd8858d912c7597a891 /llvm/lib | |
parent | 7d80ab15935f183522fee60dcfa5d538ff8be0b9 (diff) | |
download | bcm5719-llvm-03056efe01f4c606cb62a4805af461e6a65c53ef.tar.gz bcm5719-llvm-03056efe01f4c606cb62a4805af461e6a65c53ef.zip |
Create proper frame index for FP
llvm-svn: 77966
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Target/X86/X86RegisterInfo.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/llvm/lib/Target/X86/X86RegisterInfo.cpp b/llvm/lib/Target/X86/X86RegisterInfo.cpp index 5817bf0ac64..21f4dc5694c 100644 --- a/llvm/lib/Target/X86/X86RegisterInfo.cpp +++ b/llvm/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!"); |