通过栈信息进行反汇编查问题的简易实现方式

程序运行中,经常会出现类似段错误、信号量错误等方面的问题,导致程序崩溃。
针对这一类问题,解决的方法有很多,如coredump, gdb等;
这里,我介绍一种简单的方式,可以在程序崩溃的时候捕捉到栈信息,代码如下:

01.void Dump(int signum)

02.{

  1. void *array[10];

  2. size_t size;

  3. char **strings;

  4. size_t i;

  5. char log[128];

  6. signal(signum, SIG_DFL);

  7. size = backtrace(array, 10);

  8. strings = (char **) backtrace_symbols(array, size);

  9. GetFreeMemory();

  10. fprintf(stderr, “widebright received SIGNUM = %d! Stack trace:size = %d\n”, signum, size);

  11. for (i = 0; i < size; i++)

  12. {

  13.    fprintf(stderr, "%d %s \n", i, strings);
    
  14. }

  15. free(strings);

20.}

22.static int InstallSEGVHandler(void)

23.{

  1. struct sigaction siga;

  2. siga.sa_handler = AkDump;

  3. siga.sa_flags = 0;

  4. memset(&siga.sa_mask, 0, sizeof(sigset_t));

  5. sigaction(SIGSEGV, &siga, NULL);

  6. sigaction(SIGILL, &siga, NULL);

  7. sigaction(SIGTERM, &siga, NULL);

  8. sigaction(SIGILL, &siga, NULL);

  9. sigaction(SIGABRT, &siga, NULL);

  10. sigaction(SIGFPE, &siga, NULL);

  11. return 1;

38.}
复制代码
当程序出现段错误之类的错误时,系统会发出相应的信号量(具体信号量请查找Linux信号量之SIGNAL),
同时可以抓取并打印信号量的值以及相应的栈信息,栈信息类似如下:
0 ./mainapp [0xcc80]
1 /lib/libc.so.6(__default_sa_restorer_v2+0) [0x40451580]
2 /usr/lib/libakaudiocodec.so(raac_DecodeNoiselessData+0x4b4) [0x400c7fc0]
3 /usr/lib/libakaudiocodec.so(AACDecode+0x468) [0x400c16e0]
4 /usr/lib/libakaudiocodec.so(_SD_AAC_Decode+0x2d8) [0x400c2278]
5 /usr/lb/libakaudiocodec.so(_SD_Decode+0x64) [0x400bf560]
6 ./mainapp [0x23734]
7 /lib/libpthread.so.0 [0x405719bc]
8 /lib/libc.so.6(clone+0x88) [0x404fcc58]

  捕获到栈信息后,使用objdump工具将应用进行反汇编,如:arm-none-linux-gnueabi-objdump  -S mainapp > a

最后便可用栈信息打印出来的地址( ./mainapp [0x23734]–),到a文件中进行定位,找到出现问题的函数接口。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值