@ -18,6 +18,10 @@
# include <sys/types.h>
# include <sys/types.h>
# include <unistd.h>
# include <unistd.h>
# if DEVELOPER
bool dev_no_backtrace ;
# endif
static struct backtrace_state * backtrace_state ;
static struct backtrace_state * backtrace_state ;
struct log_entry {
struct log_entry {
@ -432,6 +436,7 @@ static void log_crash(int sig)
if ( sig ) {
if ( sig ) {
log_broken ( crashlog , " FATAL SIGNAL %i RECEIVED " , sig ) ;
log_broken ( crashlog , " FATAL SIGNAL %i RECEIVED " , sig ) ;
if ( backtrace_state )
backtrace_full ( backtrace_state , 0 , log_backtrace , NULL ,
backtrace_full ( backtrace_state , 0 , log_backtrace , NULL ,
crashlog ) ;
crashlog ) ;
}
}
@ -457,6 +462,7 @@ static void log_crash(int sig)
if ( sig ) {
if ( sig ) {
fprintf ( stderr , " Fatal signal %u. " , sig ) ;
fprintf ( stderr , " Fatal signal %u. " , sig ) ;
if ( backtrace_state )
backtrace_print ( backtrace_state , 0 , stderr ) ;
backtrace_print ( backtrace_state , 0 , stderr ) ;
}
}
if ( logfile )
if ( logfile )
@ -469,6 +475,9 @@ void crashlog_activate(const char *argv0, struct log *log)
struct sigaction sa ;
struct sigaction sa ;
crashlog = log ;
crashlog = log ;
# if DEVELOPER
if ( ! dev_no_backtrace )
# endif
backtrace_state = backtrace_create_state ( argv0 , 0 , NULL , NULL ) ;
backtrace_state = backtrace_create_state ( argv0 , 0 , NULL , NULL ) ;
sa . sa_handler = log_crash ;
sa . sa_handler = log_crash ;
sigemptyset ( & sa . sa_mask ) ;
sigemptyset ( & sa . sa_mask ) ;