常见死机定位方法gdb addr2line objdump

这里记录总结,自己学习定位死机问题的思路方法。(2022/05/18 23:21)
再牛逼的梦想,也抵不住傻逼般的坚持!

前言:
学习背景:为什么要了解学习定位死机问题的方法?
三种方法对比:三种方法的区别,优缺点。
如下可能不完善,会逐步完善。在解决问题中成长

方法一:gdb 通过coredump文件定位死机问题 (案例讲解–栈地址被踩问题分析)
1) 执行 test程序
./xxx-gdb test (gdb + 可执行进程文件)
2) 加载动态库路径
set solib-absolute-prefix /opt/arm-sgmstar-gnueabihf-9.1.0-202007/gcc-sigmastar-9.1.0-2020.07-x86_64_arm-linux-gnueabihf/arm-linux-gnueabihf/libc/
set solib-search-path /opt/arm-sgmstar-gnueabihf-9.1.0-202007/gcc-sigmastar-9.1.0-2020.07-x86_64_arm-linux-gnueabihf/arm-linux-gnueabihf/lib
(新增查询动态库路径方法:a.which+xxx-gdb b.在a查询到的目录的上级目录中查找sysroot目录下的lib确认有c++,libc等等动态库)
3) 加载coredump文件,还原事发现场
core-file core.pid(core-file + 产生的core文件)
4) 栈追溯(backtrace)
bt
5) 反汇编
disassemble
6)其他
a. f x(fram x;x:第x个函数栈帧)(可利用disassemble对该函数进行反汇编,利用info r查看当前寄存器值)
同过info r可查看到sp栈帧,可通过x/1024xw + sp地址,向上查看1024的地址数据信息
通过(gdb) source ./findBackTrace(自己编写的py小脚本)加载脚本。findBackTrace sp count startText endText 查找指定sp之上count大小的地址中在代码段的地址。 其中findBackTrace 脚本由于篇幅限制,可查看另外一篇文章https://blog.csdn.net/Bgm_Nilbb/article/details/131069755?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22131069755%22%2C%22source%22%3A%22Bgm_Nilbb%22%7D
b. info threads(线程简要信息呈现)
c. t x(thread x;切换至某个线程中去, x:线程号)
d. thread apply all bt(打印所有线程回溯)
e. info proc mappings(打印进程的各个段;包括起始地址,终止地址等)
f. info sharedlibrary (查看动态库加载情况)
g.info locals(查看当前帧中的局部变量)
h.info r(查看当前寄存器值)
方法二:addr2line
xxx-addr2line -e test -psfC 00334526
运行结果:地址在代码中的位置
参数解析:
xxx: 不同工具链需要用对应的addr2line工具
-e:
test:可执行文件
-psfC:
00334526:堆栈地址

方法三:objdump
xxx-objdump -Sz file >> bgm.txt
运行结果:反汇编file文件(之后可以通过查找EPC、LR等地址的临近地址,分析死机位置)
(linux kernel死机位置查询,可执行文件一般是vmlinux)
参数解析:
xxx:不同工具链需要用对应的objdump工具
-Sz:
file:需要反编译的文件

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: addr2line是一个Linux下的常见工具,用来将程序的地址转换为文件名和行号等位置信息。这个工具通常用在程序崩溃时进行调试,以便追踪问题出现的位置,帮助程序猿进行修复。 如果想使用addr2line,首先需要下载与安装。通常这个工具会随着编译器一起安装,所以在一般的Linux系统中这个工具是默认安装的。如果想自己手动安装,可以使用Linux系统自带的包管理器进行下载和安装,具体安装方法如下: 1. 打开终端,使用管理员权限登录 2. 输入命令 sudo apt-get update,进行包列表更新 3. 输入命令 sudo apt-get install binutils,进行addr2line安装(如果系统已经安装过binutils,则这个步骤可以省略不操作) 安装后即可使用addr2line进行调试,具体操作方法可以参考相关手册或在线教程。需要注意的是,使用addr2line可能需要一定的Linux系统及程序调试方面的知识储备,建议有一定经验的程序员进行操作。 ### 回答2: addr2line是一个用于将程序计数器地址(PC)转换为源文件和行号的GNU工具。它通常用于调试和跟踪代码中错误时查找源代码和行号。它可以通过GNU binutils包来安装和使用。在大多数Linux发行版中,binutils都已经安装,因此addr2line可以直接使用。 要下载addr2line,可以通过访问GNU binutils网站来获得它的源代码并手动构建和安装。对于大多数用户来说,最简单的方法是使用操作系统的包管理器来安装binutils。例如,在Ubuntu上可以使用apt-get命令,CentOS和Fedora上可以使用yum命令。 安装完成后,可以使用以下命令来调用addr2lineaddr2line -e <binaryfile> <address> 其中,binaryfile是要分析的二进制文件的路径,address是程序计数器地址。addr2line将打印出与给定地址相关联的源文件和行号。 总的来说,addr2line是一个非常实用的工具,可以帮助开发人员在调试代码时更轻松地定位和修复问题。因此,学会下载和使用addr2line对开发人员来说至关重要。 ### 回答3: addr2line是用于将地址转换为行号和文件名的命令行工具。它通常与gdb一起使用,以便在调试过程中确定源代码行号。 要下载addr2line,首先需要安装GNU binutils。地址取决于你的操作系统。在Ubuntu上,可以使用以下命令安装: sudo apt-get install binutils 安装完成后,可以使用以下命令检查addr2line是否可用: addr2line --help 如果命令返回帮助文档,则addr2line已经成功安装。 如果你想在自己的代码中使用addr2line,则需要使用编译器生成调试信息。在GCC编译器中,可以通过以下命令生成调试信息: gcc -g -o myprogram myprogram.c 在将程序编译为可执行文件后,可以使用以下命令将地址转换为文件名和行号: addr2line -e myprogram 0x4005a5 此命令将返回myprogram中地址0x4005a5所在的文件名和行号。 总之,addr2line是一个非常实用的工具,可以帮助开发人员快速解决代码中的问题。安装过程简单,只需确保已安装GNU binutils即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值