msvcr90: Don't forward exception constructors to msvcrt.
This commit is contained in:
parent
2dd332789b
commit
8b21fefbf6
|
@ -18,17 +18,58 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
#include "stdio.h"
|
#include "stdio.h"
|
||||||
#include "windef.h"
|
#include "windef.h"
|
||||||
#include "winbase.h"
|
#include "winbase.h"
|
||||||
|
|
||||||
|
#ifdef __i386__
|
||||||
|
|
||||||
|
#define THISCALL(func) __thiscall_ ## func
|
||||||
|
#define __thiscall __stdcall
|
||||||
|
#define DEFINE_THISCALL_WRAPPER(func,args) \
|
||||||
|
extern void THISCALL(func)(void); \
|
||||||
|
__ASM_GLOBAL_FUNC(__thiscall_ ## func, \
|
||||||
|
"popl %eax\n\t" \
|
||||||
|
"pushl %ecx\n\t" \
|
||||||
|
"pushl %eax\n\t" \
|
||||||
|
"jmp " __ASM_NAME(#func) __ASM_STDCALL(args) )
|
||||||
|
|
||||||
|
extern void *call_thiscall_func;
|
||||||
|
__ASM_GLOBAL_FUNC(call_thiscall_func,
|
||||||
|
"popl %eax\n\t"
|
||||||
|
"popl %edx\n\t"
|
||||||
|
"popl %ecx\n\t"
|
||||||
|
"pushl %eax\n\t"
|
||||||
|
"jmp *%edx\n\t")
|
||||||
|
|
||||||
|
#define call_func1(func,this) ((void* (WINAPI*)(void*,void*))&call_thiscall_func)(func,this)
|
||||||
|
#define call_func2(func,this,a) ((void* (WINAPI*)(void*,void*,const void*))&call_thiscall_func)(func,this,(const void*)(a))
|
||||||
|
#define call_func3(func,this,a,b) ((void* (WINAPI*)(void*,void*,const void*,const void*))&call_thiscall_func)(func,this,(const void*)(a),(const void*)(b))
|
||||||
|
|
||||||
|
#else /* __i386__ */
|
||||||
|
|
||||||
|
#define __thiscall __cdecl
|
||||||
|
#define DEFINE_THISCALL_WRAPPER(func,args) /* nothing */
|
||||||
|
|
||||||
|
#define call_func1(func,this) func(this)
|
||||||
|
#define call_func2(func,this,a) func(this,a)
|
||||||
|
#define call_func3(func,this,a,b) func(this,a,b)
|
||||||
|
|
||||||
|
#endif /* __i386__ */
|
||||||
|
|
||||||
typedef void (__cdecl *MSVCRT__se_translator_function)(unsigned int code, struct _EXCEPTION_POINTERS *info);
|
typedef void (__cdecl *MSVCRT__se_translator_function)(unsigned int code, struct _EXCEPTION_POINTERS *info);
|
||||||
|
|
||||||
static void* (__cdecl *MSVCRT_operator_new)(size_t);
|
static void* (__cdecl *MSVCRT_operator_new)(size_t);
|
||||||
static void (__cdecl *MSVCRT_operator_delete)(void*);
|
static void (__cdecl *MSVCRT_operator_delete)(void*);
|
||||||
static MSVCRT__se_translator_function (__cdecl *MSVCRT__set_se_translator)(MSVCRT__se_translator_function);
|
static MSVCRT__se_translator_function (__cdecl *MSVCRT__set_se_translator)(MSVCRT__se_translator_function);
|
||||||
|
static void* (__thiscall *MSVCRT_exception_ctor)(void*, const char**);
|
||||||
|
static void* (__thiscall *MSVCRT_exception_ctor_noalloc)(void*, char**, int);
|
||||||
|
static void* (__thiscall *MSVCRT_exception_copy_ctor)(void*, const void*);
|
||||||
|
static void (__thiscall *MSVCRT_exception_dtor)(void*);
|
||||||
|
|
||||||
static void init_cxx_funcs(void)
|
static void init_cxx_funcs(void)
|
||||||
{
|
{
|
||||||
|
@ -40,6 +81,10 @@ static void init_cxx_funcs(void)
|
||||||
MSVCRT_operator_delete = (void*)GetProcAddress(hmod, "??3@YAXPEAX@Z");
|
MSVCRT_operator_delete = (void*)GetProcAddress(hmod, "??3@YAXPEAX@Z");
|
||||||
MSVCRT__set_se_translator = (void*)GetProcAddress(hmod,
|
MSVCRT__set_se_translator = (void*)GetProcAddress(hmod,
|
||||||
"?_set_se_translator@@YAP6AXIPEAU_EXCEPTION_POINTERS@@@ZP6AXI0@Z@Z");
|
"?_set_se_translator@@YAP6AXIPEAU_EXCEPTION_POINTERS@@@ZP6AXI0@Z@Z");
|
||||||
|
MSVCRT_exception_ctor = (void*)GetProcAddress(hmod, "??0exception@@QEAA@AEBQEBD@Z");
|
||||||
|
MSVCRT_exception_ctor_noalloc = (void*)GetProcAddress(hmod, "??0exception@@QEAA@AEBQEBDH@Z");
|
||||||
|
MSVCRT_exception_copy_ctor = (void*)GetProcAddress(hmod, "??0exception@@QEAA@AEBV0@@Z");
|
||||||
|
MSVCRT_exception_dtor = (void*)GetProcAddress(hmod, "??1exception@@UEAA@XZ");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -47,6 +92,10 @@ static void init_cxx_funcs(void)
|
||||||
MSVCRT_operator_delete = (void*)GetProcAddress(hmod, "??3@YAXPAX@Z");
|
MSVCRT_operator_delete = (void*)GetProcAddress(hmod, "??3@YAXPAX@Z");
|
||||||
MSVCRT__set_se_translator = (void*)GetProcAddress(hmod,
|
MSVCRT__set_se_translator = (void*)GetProcAddress(hmod,
|
||||||
"?_set_se_translator@@YAP6AXIPAU_EXCEPTION_POINTERS@@@ZP6AXI0@Z@Z");
|
"?_set_se_translator@@YAP6AXIPAU_EXCEPTION_POINTERS@@@ZP6AXI0@Z@Z");
|
||||||
|
MSVCRT_exception_ctor = (void*)GetProcAddress(hmod, "??0exception@@QAE@ABQBD@Z");
|
||||||
|
MSVCRT_exception_ctor_noalloc = (void*)GetProcAddress(hmod, "??0exception@@QAE@ABQBDH@Z");
|
||||||
|
MSVCRT_exception_copy_ctor = (void*)GetProcAddress(hmod, "??0exception@@QAE@ABV0@@Z");
|
||||||
|
MSVCRT_exception_dtor = (void*)GetProcAddress(hmod, "??1exception@@UAE@XZ");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,3 +165,35 @@ MSVCRT__se_translator_function CDECL MSVCR90__set_se_translator(MSVCRT__se_trans
|
||||||
{
|
{
|
||||||
return MSVCRT__set_se_translator(func);
|
return MSVCRT__set_se_translator(func);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ??0exception@std@@QAE@ABQBD@Z */
|
||||||
|
/* ??0exception@std@@QEAA@AEBQEBD@Z */
|
||||||
|
DEFINE_THISCALL_WRAPPER(exception_ctor, 8)
|
||||||
|
void* __thiscall exception_ctor(void *this, const char **name)
|
||||||
|
{
|
||||||
|
return call_func2(MSVCRT_exception_ctor, this, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ??0exception@std@@QAE@ABQBDH@Z */
|
||||||
|
/* ??0exception@std@@QEAA@AEBQEBDH@Z */
|
||||||
|
DEFINE_THISCALL_WRAPPER(exception_ctor_noalloc, 12)
|
||||||
|
void* __thiscall exception_ctor_noalloc(void *this, char **name, int noalloc)
|
||||||
|
{
|
||||||
|
return call_func3(MSVCRT_exception_ctor_noalloc, this, name, noalloc);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ??0exception@std@@QAE@ABV01@@Z */
|
||||||
|
/* ??0exception@std@@QEAA@AEBV01@@Z */
|
||||||
|
DEFINE_THISCALL_WRAPPER(exception_copy_ctor, 8)
|
||||||
|
void* __thiscall exception_copy_ctor(void *this, const void *rhs)
|
||||||
|
{
|
||||||
|
return call_func2(MSVCRT_exception_copy_ctor, this, rhs);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ??1exception@std@@UAE@XZ */
|
||||||
|
/* ??1exception@std@@UEAA@XZ */
|
||||||
|
DEFINE_THISCALL_WRAPPER(exception_dtor, 4)
|
||||||
|
void __thiscall exception_dtor(void *this)
|
||||||
|
{
|
||||||
|
call_func1(MSVCRT_exception_dtor, this);
|
||||||
|
}
|
||||||
|
|
|
@ -12,12 +12,12 @@
|
||||||
@ cdecl -arch=win64 ??0bad_typeid@std@@QEAA@AEBV01@@Z(ptr ptr) msvcrt.??0bad_typeid@@QEAA@AEBV0@@Z
|
@ cdecl -arch=win64 ??0bad_typeid@std@@QEAA@AEBV01@@Z(ptr ptr) msvcrt.??0bad_typeid@@QEAA@AEBV0@@Z
|
||||||
@ thiscall -arch=i386 ??0bad_typeid@std@@QAE@PBD@Z(ptr str) msvcrt.??0bad_typeid@@QAE@PBD@Z
|
@ thiscall -arch=i386 ??0bad_typeid@std@@QAE@PBD@Z(ptr str) msvcrt.??0bad_typeid@@QAE@PBD@Z
|
||||||
@ cdecl -arch=win64 ??0bad_typeid@std@@QEAA@PEBD@Z(ptr str) msvcrt.??0bad_typeid@@QEAA@PEBD@Z
|
@ cdecl -arch=win64 ??0bad_typeid@std@@QEAA@PEBD@Z(ptr str) msvcrt.??0bad_typeid@@QEAA@PEBD@Z
|
||||||
@ thiscall -arch=i386 ??0exception@std@@QAE@ABQBD@Z(ptr ptr) msvcrt.??0exception@@QAE@ABQBD@Z
|
@ thiscall -arch=i386 ??0exception@std@@QAE@ABQBD@Z(ptr ptr) exception_ctor
|
||||||
@ cdecl -arch=win64 ??0exception@std@@QEAA@AEBQEBD@Z(ptr ptr) msvcrt.??0exception@@QEAA@AEBQEBD@Z
|
@ cdecl -arch=win64 ??0exception@std@@QEAA@AEBQEBD@Z(ptr ptr) exception_ctor
|
||||||
@ thiscall -arch=i386 ??0exception@std@@QAE@ABQBDH@Z(ptr ptr long) msvcrt.??0exception@@QAE@ABQBDH@Z
|
@ thiscall -arch=i386 ??0exception@std@@QAE@ABQBDH@Z(ptr ptr long) exception_ctor_noalloc
|
||||||
@ cdecl -arch=win64 ??0exception@std@@QEAA@AEBQEBDH@Z(ptr ptr long) msvcrt.??0exception@@QEAA@AEBQEBDH@Z
|
@ cdecl -arch=win64 ??0exception@std@@QEAA@AEBQEBDH@Z(ptr ptr long) exception_ctor_noalloc
|
||||||
@ thiscall -arch=i386 ??0exception@std@@QAE@ABV01@@Z(ptr ptr) msvcrt.??0exception@@QAE@ABV0@@Z
|
@ thiscall -arch=i386 ??0exception@std@@QAE@ABV01@@Z(ptr ptr) exception_copy_ctor
|
||||||
@ cdecl -arch=win64 ??0exception@std@@QEAA@AEBV01@@Z(ptr ptr) msvcrt.??0exception@@QEAA@AEBV0@@Z
|
@ cdecl -arch=win64 ??0exception@std@@QEAA@AEBV01@@Z(ptr ptr) exception_copy_ctor
|
||||||
@ thiscall -arch=i386 ??0exception@std@@QAE@XZ(ptr) msvcrt.??0exception@@QAE@XZ
|
@ thiscall -arch=i386 ??0exception@std@@QAE@XZ(ptr) msvcrt.??0exception@@QAE@XZ
|
||||||
@ cdecl -arch=win64 ??0exception@std@@QEAA@XZ(ptr) msvcrt.??0exception@@QEAA@XZ
|
@ cdecl -arch=win64 ??0exception@std@@QEAA@XZ(ptr) msvcrt.??0exception@@QEAA@XZ
|
||||||
@ thiscall -arch=i386 ??1__non_rtti_object@std@@UAE@XZ(ptr) msvcrt.??1__non_rtti_object@@UAE@XZ
|
@ thiscall -arch=i386 ??1__non_rtti_object@std@@UAE@XZ(ptr) msvcrt.??1__non_rtti_object@@UAE@XZ
|
||||||
|
@ -26,8 +26,8 @@
|
||||||
@ cdecl -arch=win64 ??1bad_cast@std@@UEAA@XZ(ptr) msvcrt.??1bad_cast@@UEAA@XZ
|
@ cdecl -arch=win64 ??1bad_cast@std@@UEAA@XZ(ptr) msvcrt.??1bad_cast@@UEAA@XZ
|
||||||
@ thiscall -arch=i386 ??1bad_typeid@std@@UAE@XZ(ptr) msvcrt.??1bad_typeid@@UAE@XZ
|
@ thiscall -arch=i386 ??1bad_typeid@std@@UAE@XZ(ptr) msvcrt.??1bad_typeid@@UAE@XZ
|
||||||
@ cdecl -arch=win64 ??1bad_typeid@std@@UEAA@XZ(ptr) msvcrt.??1bad_typeid@@UEAA@XZ
|
@ cdecl -arch=win64 ??1bad_typeid@std@@UEAA@XZ(ptr) msvcrt.??1bad_typeid@@UEAA@XZ
|
||||||
@ thiscall -arch=i386 ??1exception@std@@UAE@XZ(ptr) msvcrt.??1exception@@UAE@XZ
|
@ thiscall -arch=i386 ??1exception@std@@UAE@XZ(ptr) exception_dtor
|
||||||
@ cdecl -arch=win64 ??1exception@std@@UEAA@XZ(ptr) msvcrt.??1exception@@UEAA@XZ
|
@ cdecl -arch=win64 ??1exception@std@@UEAA@XZ(ptr) exception_dtor
|
||||||
@ cdecl -arch=arm ??1type_info@@UAA@XZ(ptr) msvcrt.??1type_info@@UAA@XZ
|
@ cdecl -arch=arm ??1type_info@@UAA@XZ(ptr) msvcrt.??1type_info@@UAA@XZ
|
||||||
@ thiscall -arch=i386 ??1type_info@@UAE@XZ(ptr) msvcrt.??1type_info@@UAE@XZ
|
@ thiscall -arch=i386 ??1type_info@@UAE@XZ(ptr) msvcrt.??1type_info@@UAE@XZ
|
||||||
@ cdecl -arch=win64 ??1type_info@@UEAA@XZ(ptr) msvcrt.??1type_info@@UEAA@XZ
|
@ cdecl -arch=win64 ??1type_info@@UEAA@XZ(ptr) msvcrt.??1type_info@@UEAA@XZ
|
||||||
|
|
Loading…
Reference in New Issue