common: stack trace: make clang happy with func ptrs
Tested that it builds with: gcc 6.1.1, STATIC=OFF,i686 gcc 6.1.1, STATIC=OFF,armv7h clang 3.8, STATIC=OFF,i686 clang 3.8, STATIC=OFF,armv7h gcc 6.1.1, STATIC=ON,i686 clang 3.8, STATIC=ON,i686 Also tested that stack trace is generated fine on exception on: i686, gcc 6.1.1, STATIC=OFF (didn't bother testing all the other platforms/configs) This should fix the build problem on OSX (#871, #901), but I don't have OSX, so I could only test Clang on Linux.
This commit is contained in:
parent
4dce26bba4
commit
fa85cd845f
1 changed files with 29 additions and 9 deletions
|
@ -38,14 +38,33 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// from http://stackoverflow.com/questions/11665829/how-can-i-print-stack-trace-for-caught-exceptions-in-c-code-injection-in-c
|
// from http://stackoverflow.com/questions/11665829/how-can-i-print-stack-trace-for-caught-exceptions-in-c-code-injection-in-c
|
||||||
|
|
||||||
|
// The decl of __cxa_throw in /usr/include/.../cxxabi.h uses
|
||||||
|
// 'std::type_info *', but GCC's built-in protype uses 'void *'.
|
||||||
|
#ifdef __clang__
|
||||||
|
#define CXA_THROW_INFO_T std::type_info
|
||||||
|
#else // !__clang__
|
||||||
|
#define CXA_THROW_INFO_T void
|
||||||
|
#endif // !__clang__
|
||||||
|
|
||||||
#ifdef STATICLIB
|
#ifdef STATICLIB
|
||||||
#define CXA_THROW __wrap___cxa_throw
|
#define CXA_THROW __wrap___cxa_throw
|
||||||
extern "C" void __real___cxa_throw(void *ex, void *info, void (*dest)(void*));
|
extern "C"
|
||||||
#else
|
__attribute__((noreturn))
|
||||||
|
void __real___cxa_throw(void *ex, CXA_THROW_INFO_T *info, void (*dest)(void*));
|
||||||
|
#else // !STATICLIB
|
||||||
#define CXA_THROW __cxa_throw
|
#define CXA_THROW __cxa_throw
|
||||||
#endif
|
extern "C"
|
||||||
|
typedef
|
||||||
|
#ifdef __clang__ // only clang, not GCC, lets apply the attr in typedef
|
||||||
|
__attribute__((noreturn))
|
||||||
|
#endif // __clang__
|
||||||
|
void (cxa_throw_t)(void *ex, CXA_THROW_INFO_T *info, void (*dest)(void*));
|
||||||
|
#endif // !STATICLIB
|
||||||
|
|
||||||
extern "C" void CXA_THROW(void *ex, void *info, void (*dest)(void*))
|
extern "C"
|
||||||
|
__attribute__((noreturn))
|
||||||
|
void CXA_THROW(void *ex, CXA_THROW_INFO_T *info, void (*dest)(void*))
|
||||||
{
|
{
|
||||||
|
|
||||||
int status;
|
int status;
|
||||||
|
@ -53,12 +72,13 @@ extern "C" void CXA_THROW(void *ex, void *info, void (*dest)(void*))
|
||||||
tools::log_stack_trace((std::string("Exception: ")+((!status && dsym) ? dsym : (const char*)info)).c_str());
|
tools::log_stack_trace((std::string("Exception: ")+((!status && dsym) ? dsym : (const char*)info)).c_str());
|
||||||
free(dsym);
|
free(dsym);
|
||||||
|
|
||||||
#ifdef STATICLIB
|
#ifndef STATICLIB
|
||||||
|
#ifndef __clang__ // for GCC the attr can't be applied in typedef like for clang
|
||||||
|
__attribute__((noreturn))
|
||||||
|
#endif // !__clang__
|
||||||
|
cxa_throw_t *__real___cxa_throw = (cxa_throw_t*)dlsym(RTLD_NEXT, "__cxa_throw");
|
||||||
|
#endif // !STATICLIB
|
||||||
__real___cxa_throw(ex, info, dest);
|
__real___cxa_throw(ex, info, dest);
|
||||||
#else
|
|
||||||
static void (*const rethrow)(void*, void*, void(*)(void*)) __attribute__((noreturn)) = (void(*)(void*, void*, void(*)(void*)))dlsym(RTLD_NEXT, "__cxa_throw");
|
|
||||||
rethrow(ex, info, dest);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
|
|
Loading…
Reference in a new issue