Make sure there is enough room for RA. getStackSize needs to be cleaned up but

we will do that when we implement the full save/restore.

Patch by Reed Kotler.

llvm-svn: 164051
This commit is contained in:
Akira Hatanaka 2012-09-17 20:02:42 +00:00
parent ee23ae264b
commit 9068706bb6
1 changed files with 4 additions and 0 deletions

View File

@ -35,6 +35,8 @@ void Mips16FrameLowering::emitPrologue(MachineFunction &MF) const {
DebugLoc dl = MBBI != MBB.end() ? MBBI->getDebugLoc() : DebugLoc();
uint64_t StackSize = MFI->getStackSize();
StackSize += 16; // need to allocate space for RA. Clean this up later
// when we fix the save/restore instruction. TBD..
// No need to allocate space on the stack.
if (StackSize == 0 && !MFI->adjustsStack()) return;
@ -52,6 +54,8 @@ void Mips16FrameLowering::emitEpilogue(MachineFunction &MF,
DebugLoc dl = MBBI->getDebugLoc();
uint64_t StackSize = MFI->getStackSize();
StackSize += 16; // need to allocate space for RA. Clean this up later
// when we fix the save/restore instruction. TBD..
if (!StackSize)
return;