X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/4f609ec53a6525146e68a4751ae29f8b0a8228a0..c5071b3b404fbbfc84172a08fb4086bc5ce97fc9:/src/xbt/backtrace_linux.c diff --git a/src/xbt/backtrace_linux.c b/src/xbt/backtrace_linux.c index d7e6d49292..81c62510b2 100644 --- a/src/xbt/backtrace_linux.c +++ b/src/xbt/backtrace_linux.c @@ -12,6 +12,7 @@ #include "xbt/str.h" #include "xbt/module.h" /* xbt_binary_name */ #include "xbt_modinter.h" /* backtrace initialization headers */ +#include /* end of "useless" inclusions */ extern char **environ; /* the environment, as specified by the opengroup */ @@ -365,3 +366,33 @@ void xbt_ex_setup_backtrace(xbt_ex_t * e) //FIXME: This code could be greatly im free(backtrace_syms); free(cmd); } + +int xbt_libunwind_backtrace(void* bt[XBT_BACKTRACE_SIZE], int size){ + + int i = 0; + for(i=0; i < size; i++) + bt[i] = NULL; + + i=0; + + unw_cursor_t c; + unw_context_t uc; + + unw_getcontext (&uc); + unw_init_local (&c, &uc); + + unw_word_t ip; + + unw_step(&c); + + while(unw_step(&c) >= 0 && i < size){ + + unw_get_reg(&c, UNW_REG_IP, &ip); + bt[i] = (void*)(long)ip; + i++; + + } + + return i; + +}