From cfeb0626ccc6f335d95089bf6c4f7baecdce9c8a Mon Sep 17 00:00:00 2001 From: ptitSeb Date: Thu, 27 Oct 2022 18:42:07 +0200 Subject: Added BOX64_SHOWBT env. var. to have a backtrace on segfault --- src/libtools/signals.c | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'src/libtools') diff --git a/src/libtools/signals.c b/src/libtools/signals.c index 6dcfb8b0..dfc351d6 100755 --- a/src/libtools/signals.c +++ b/src/libtools/signals.c @@ -12,6 +12,7 @@ #include #include #include +#include #include "box64context.h" #include "debug.h" @@ -1007,6 +1008,29 @@ exit(-1); } } } + if(box64_showbt) { + // show native bt + #define BT_BUF_SIZE 100 + int nptrs; + void *buffer[BT_BUF_SIZE]; + char **strings; + nptrs = backtrace(buffer, BT_BUF_SIZE); + strings = backtrace_symbols(buffer, nptrs); + if(strings) { + for (int j = 0; j < nptrs; j++) + printf_log(log_minimum, "NativeBT: %s\n", strings[j]); + free(strings); + } + extern int my_backtrace(x64emu_t* emu, void** buffer, int size); // in wrappedlibc + extern char** my_backtrace_symbols(x64emu_t* emu, uintptr_t* buffer, int size); + nptrs = my_backtrace(emu, buffer, BT_BUF_SIZE); + strings = my_backtrace_symbols(emu, (uintptr_t*)buffer, nptrs); + if(strings) { + for (int j = 0; j < nptrs; j++) + printf_log(log_minimum, "EmulatedBT: %s\n", strings[j]); + free(strings); + } + } #ifdef DYNAREC uint32_t hash = 0; if(db) -- cgit 1.4.1