Gdb和objdump使用参考文档

1、本教程的目的

  GDB可以查询kernel coredump或者应用层段错误的方法。

2、Kernel GDB

2.2 使Kernel支持gdb的编译

以Realtek为例,需要开启CONFIG_DEBUG_INFO宏进行编译。见Kernel的主Makefile,此宏主要打开-g选项。

2.3 Kernel的gdb反查symbol方法

步骤:
1 设置环境变量
2 找到生成的kernel  elf镜像,使用gdb反查相应地址对应的具体代码。

3、User层 GDB

3.1 编译说明

默认编译是不会带gdb信息的,如果直接使用gdb命令去反查,会提示“no debugging symbols found”,表示reload镜像中不包含gdb的编译信息。

在rc/Makefile中 增加-g选项,如果有STRIP选项一定要屏蔽掉,否则不带symbol信息,再重新gdb查看,发现已经带了symbol信息。

3.2 GDB使用简述

用法同kernel的用法。

3.3 Objdump

环境变量设置同gdb,使用objdump不需要特别的编译

rsdk-linux-objdump -d reload > dumpinfo

意思是将reload (这个必须是elf可执行镜像)反汇编到dumpinfo文件中,如图可以查看具体的地址所对应的函数。


本文章由作者:佐须之男 整理编辑,原文地址: Gdb和objdump使用参考文档
本站的文章和资源来自互联网或者站长的原创,按照 CC BY -NC -SA 3.0 CN协议发布和共享,转载或引用本站文章应遵循相同协议。如果有侵犯版权的资 源请尽快联系站长,我们会在24h内删除有争议的资源。欢迎大家多多交流,期待共同学习进步。

相关推荐