From: Anton Korobeynikov Date: Sun, 23 Mar 2008 12:32:54 +0000 (+0000) Subject: Remove old-standing obsolete code. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=6aeedfd0f561df2330207907e32ab507d268a9ad;p=oota-llvm.git Remove old-standing obsolete code. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48701 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/X86/X86JITInfo.cpp b/lib/Target/X86/X86JITInfo.cpp index cb16c6c26b9..1c8d214ddbf 100644 --- a/lib/Target/X86/X86JITInfo.cpp +++ b/lib/Target/X86/X86JITInfo.cpp @@ -260,20 +260,30 @@ extern "C" { CFI(".cfi_endproc\n") ); #else - void X86CompilationCallback2(void); + void X86CompilationCallback2(intptr_t *StackPtr, intptr_t RetAddr); _declspec(naked) void X86CompilationCallback(void) { __asm { + push ebp + mov ebp, esp push eax push edx push ecx + and esp, -16 + mov eax, dword ptr [ebp+4] + mov dword ptr [esp+4], eax + mov dword ptr [esp], ebp call X86CompilationCallback2 + mov esp, ebp + sub esp, 12 pop ecx pop edx pop eax + pop ebp ret } } + #endif // _MSC_VER #else // Not an i386 host @@ -288,16 +298,8 @@ extern "C" { /// function stub when we did not know the real target of a call. This function /// must locate the start of the stub or call site and pass it into the JIT /// compiler function. -#ifdef _MSC_VER -extern "C" void X86CompilationCallback2() { - assert(sizeof(size_t) == 4); // FIXME: handle Win64 - intptr_t *RetAddrLoc = (intptr_t *)_AddressOfReturnAddress(); - RetAddrLoc += 4; // skip over ret addr, edx, eax, ecx - intptr_t RetAddr = *RetAddrLoc; -#else extern "C" void X86CompilationCallback2(intptr_t *StackPtr, intptr_t RetAddr) { intptr_t *RetAddrLoc = &StackPtr[1]; -#endif assert(*RetAddrLoc == RetAddr && "Could not find return address on the stack!");