aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-05-15 05:49:58 +0000
committerChris Lattner <sabre@nondot.org>2005-05-15 05:49:58 +0000
commit5fae9ccd399e6fc7fc94d89a1adda517c12ed64b (patch)
tree18b93c88df4da9c866ffc52dd42fe61cc1e78be5
parent381e88799ec4ba0ccf194fcce99542a0b4852da1 (diff)
downloadexternal_llvm-5fae9ccd399e6fc7fc94d89a1adda517c12ed64b.zip
external_llvm-5fae9ccd399e6fc7fc94d89a1adda517c12ed64b.tar.gz
external_llvm-5fae9ccd399e6fc7fc94d89a1adda517c12ed64b.tar.bz2
Teach reginfo how to deal with ADJSTACKPTRri, allowing us to generate:
add %ESP, 20 jmp %EDX # TAIL CALL instead of: add %ESP, -8 add %ESP, 28 jmp %EDX # TAIL CALL git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22047 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Target/X86/X86RegisterInfo.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/lib/Target/X86/X86RegisterInfo.cpp b/lib/Target/X86/X86RegisterInfo.cpp
index a1ec6dc..08920cc 100644
--- a/lib/Target/X86/X86RegisterInfo.cpp
+++ b/lib/Target/X86/X86RegisterInfo.cpp
@@ -544,6 +544,9 @@ void X86RegisterInfo::emitEpilogue(MachineFunction &MF,
PI->getOperand(0).getReg() == X86::ESP) {
NumBytes -= PI->getOperand(1).getImmedValue();
MBB.erase(PI);
+ } else if (PI->getOpcode() == X86::ADJSTACKPTRri) {
+ NumBytes += PI->getOperand(1).getImmedValue();
+ MBB.erase(PI);
}
}