У меня проблема с получением вывода трассировки стека в stderr или с дампом в файл журнала. Я запускаю код в Kubuntu10.04 с компилятором gcc (4.4.3). Проблема в том, что в обычном режиме работы (без GDB) программа не выводит ничего, кроме «Ошибка сегментации». Я хочу вывести вывод обратной трассировки, как в приведенных ниже инструкциях печати. Когда я запускаю gdb с моим приложением, оно обращается к оператору printf / fprintf / (вызов функции), а затем выдает сбой со следующим оператором:
669 {
(gdb)
670 printf("Testing for stability.\n");
(gdb)
Program received signal SIGTRAP, Trace/breakpoint trap.
0x00007ffff68b1f45 in puts () from /lib/libc.so.6
Странно то, что это работает, если я вызываю функцию в том же файле, который дает сбой, работает нормально и выдает правильные результаты. Но если программа выходит из строя в функции вне этого файла, она не печатает никаких выходных данных.
Таким образом, оператор printf, дамп файла или вызов функции не обрабатываются. Я использую следующий пример кода:
void bt_sighandler(int sig, siginfo_t *info,
void *secret) {
void *trace[16];
char **messages = (char **)NULL;
int i, trace_size = 0;
ucontext_t *uc = (ucontext_t *)secret;
/* Do something useful with siginfo_t */
if (sig == SIGSEGV)
printf("Got signal %d, faulty address is %p, "
"from %p\n", sig, info->si_addr,
uc->uc_mcontext.gregs[0]);
else
printf("Got signal %d#92; \n", sig);
trace_size = backtrace(trace, 16);
/* overwrite sigaction with caller's address */
trace[1] = (void *) uc->uc_mcontext.gregs[0];
messages = backtrace_symbols(trace, trace_size);
/* skip first stack frame (points here) */
printf("[bt] Execution path:#92; \n");
for (i=1; i<trace_size; ++i)
printf("[bt] %s#92; \n", messages[i]);
exit(0);
}
int main() {
/* Install our signal handler */
struct sigaction sa;
sa.sa_sigaction = (void *)bt_sighandler;
sigemptyset (&sa.sa_mask);
sa.sa_flags = SA_RESTART | SA_SIGINFO;
sigaction(SIGSEGV, &sa, NULL);
sigaction(SIGUSR1, &sa, NULL);
/* Do something */
printf("%d#92; \n", func_b());
}
Заранее спасибо за любую помощь.