summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorAnton Korobeynikov <asl@math.spbu.ru>2009-08-03 08:14:30 +0000
committerAnton Korobeynikov <asl@math.spbu.ru>2009-08-03 08:14:30 +0000
commit03056efe01f4c606cb62a4805af461e6a65c53ef (patch)
tree8120244066a694f259e7bdd8858d912c7597a891 /llvm/lib
parent7d80ab15935f183522fee60dcfa5d538ff8be0b9 (diff)
downloadbcm5719-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.cpp4
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!");
OpenPOWER on IntegriCloud