binutils工具集---addr2line
addr2line是用来将程序地址转换成其所对应的程序源文件及所对应的代码行,也可以得到所对应的函数。
测试代码:
#include<stdio.h>
void test_fun()
{
printf("this fun address is %p\n",test_fun);
}
int main()
{
test_fun();
return 0;
}
addr2line命令测试
linux@ubuntu:/mnt/hgfs/000myShare/binutils$ gcc -g add2line.c -o test
linux@ubuntu:/mnt/hgfs/000myShare/binutils$ ./test
this fun address is 0x804841d
linux@ubuntu:/mnt/hgfs/000myShare/binutils$ addr2line 0x804841d -f -e test
test_fun
/mnt/hgfs/000myShare/binutils/add2line.c:4
linux@ubuntu:/mnt/hgfs/000myShare/binutils$
再来看看addr2line命令的具体用途,当程序崩溃或者出现段错误则用途就很大了,如下测试代码:
1. 测试代码
#include<stdio.h>
void Segmentation_fault()
{
int *p = NULL;
/* 这里会报 Segmentation fault */
*p = 1;
}
int main()
{
/* 调用 */
Segmentation_fault();
return 0;
}
2.编译:添加 -g -o 选项 生成目标文件 Segmentation_fault
$ gcc Segmentation_fault.c -g -o Segmentation_fault
3.运行目标文件
$ ./gcc Segmentation_fault
发生 Segmentation fault 错误
4. 使用dmesg工具显示内核缓冲区系统控制信息
$ dmesg | tail
[ 1494.867524] eth0: no IPv6 routers present
[ 1542.731607] eth0: no IPv6 routers present
[ 1590.887683] eth0: no IPv6 routers present
[ 1639.009094] eth0: no IPv6 routers present
[ 1849.965047] Segmentation_fault[2787]: segfault at 0 ip 080483c4 sp bfa80fb0 error 6 in Segmentation_fault[8048000+1000]
![]()
5.使用addr2line 工具定位 Segmentation fault 具体位置
$ addr2line -e Segmentation_fault 080483c4 -f
./Segmentation_fault.c:7
这里的 7 就是发生Segmentation fault所在行。
还有一些比如安卓调试中会有tombstone分析,这样我们就可以在tombstone文件中根据堆栈指针进行崩溃定位。
2212

被折叠的 条评论
为什么被折叠?



