Backtrace调试

/*
* DUMP使用注意事项:
* 1. 编译选项 -g -funwind-tables -ffunction-sections
* 2. 链接参数 -rdynamic
* 3. 去掉代码优化编译选项 -On 
* 4. 去掉栈指针优化选项 -fomit-frame-pointer
* 5. 动态库地址需要减去load基地址
* 6. 查看命令addr2line -e app.bin(执行文件或so库文件) 0xFFFF(地址)
*/
void dump_backtrace()
{
    void* buffer[200];
    int size = backtrace(buffer, sizeof(buffer));
    printf("\nbacktrace() returned %d addresses\n", size);

    char ** info = backtrace_symbols(buffer, size);
    for (int i=0; i<size; ++i)
        fprintf(stderr, "[%02d] %s\n", i, info[i]);

    free(info);
    exit(0);
}

void dump_library_maps()
{
    printf("dynamic library maps:\n");
    char maps[128] = {0x00};
    snprintf(maps, sizeof(maps), "cat /proc/%d/maps", getpid());
    system(maps);
}

void signal_handler(int signo, siginfo_t *info, void *ptr)
{
    printf("\n=========>>>catch signal %d <<<=========\n", signo);
    printf("trigger address: %p\n\n", info->si_addr);

    printf("************* backtrace ******************\n");
    dump_library_maps();
    printf("\n");
    dump_backtrace();
    printf("***************backtrace end********************\n");
    //signal(signo, SIG_DFL); //恢复默认处理 
    raise(signo);             //再发一次信号 
}

void watch_signal()
{
    //signal(SIGSEGV, signal_handler);
    struct sigaction act;
    sigemptyset(&act.sa_mask);
    act.sa_flags = SA_SIGINFO | SA_RESETHAND;
    act.sa_sigaction = signal_handler;
    sigaction(SIGSEGV, &act, NULL);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值