在 Linux 下写 C/C++ 程序的程序员,时常与 Core Dump 相见。在内存越界访问,收到不能处理的信号,除零等错误出现时,我们精心或不精心写就的程序就直接一命呜呼了,Core Dump 是 Linux 仁慈地留下的程序的尸体,帮助程序员们解决了一个又一个问题。
有时配置不给力,Linux 直接毁尸灭迹,没有了 Core 文件;又有时,刚好磁盘空间不足,Core文件写不下了。没有 Core 文件的时候,如何知道程序在什么地方出错了呢?addr2line 就在这时派上用场。
这是一个示例程序,func 函数返回参数 a 除以参数 b 的结果。这里使用 0 作为除数,结果就是程序因为除以 0 导致错误,直接中断了。
test.c
#include < stdio.h >
int func(int a, int b)
{
return a / b;
}
int main()
{
int x = 10;
int y = 0;
printf("%d / %d = %dn", x, y, func(x, y));
return 0;
}
编译:-o 指定输出文件名,-g 会有调试信息。
gcc -o test -g test.c
执行
./test
提示执行错误

输入 dmesg 命令,查看 log,提示如下:
traps: test[2184] trap divide error ip:400534 sp:7ffee5779a90 error:0 in test[400000+1000]
ip 字段后面的数字就是 test 程序出错时所程序执行的位置。使用 addr2line 就可以 将 400534 地址转换出对应的文件及行数 :

可知,程序在执行到 test.c 文件第五行的时候,执行出错,我们检查第五行代码。
return a / b;
这里除 0 肯定是不行的,addr2line 帮助我们找到了错误位置。
-
嵌入式
+关注
关注
5186文章
20146浏览量
328814 -
内存
+关注
关注
9文章
3173浏览量
76115 -
FreeRTOS
+关注
关注
14文章
497浏览量
66354 -
DEBUG
+关注
关注
3文章
95浏览量
21256
发布评论请先 登录
在wsl2中安装的idf,在monitor时会报错的原因?
调用rt_timer_check函数就报错,为什么?
调用rt_timer_check函数就报错怎么解决?
单片机运行一段时间死机,为什么?
在V5.1.0版本中,lfs文件系统使用ulog文件后端保存文件, 遇到了使用cat命令读取文件错误怎么解决?
如何在开发板子上安装addr2line工具?
C语言在ARM中函数调用时栈变化的过程
在wsl2中安装的idf,在monitor报错的原因?如何解决?
当On Line Debug时,会无缘无故的离线是为什么?
C语言在ARM中函数调用时,栈是如何变化的?
NCV8402ADDR2G,原装正品,价格美丽
Linux中addr2line用法介绍
linux下调试core dump的方法
RVBacktrace RISC-V极简栈回溯组件

如何用addr2line去debug
评论