GDB无法debug的错误

  • Post author:
  • Post category:其他




GDB无法debug的错误



一、输出错误信息描述

Warning: opening /proc/PID/mem file for lwp 707.707 failed: No such file or directory (2)

Warning:

Cannot insert breakpoint 1.

Cannot access memory at address 0x806950



二、解决方法

方法:修改 GDB 的二进制,让他支持 ptrace。

步骤如下:



  1. /usr/bin

    文件目录下找到

    gdb

    二进制文件,如图所示:

    在这里插入图片描述
  2. 将其复制到电脑桌面,因为后续需要使用逆向工具

    IDA

    软件对其进行分析。
  3. 下载免费的IDA工具,

    IDA官方下载地址



  4. IDA

    打开之前复制到桌面的

    gdb

    二进制文件,在左上角的

    Search

    选项卡中找到,

    Text...

    选项,如下图所示:

    在这里插入图片描述
  5. 在弹出的搜索框中输入

    linux_proc_xfer_memory_partial

    进行查找,如图所示:

    在这里插入图片描述
  6. 检索内容如下:

    在这里插入图片描述
  7. 记录下上图红框中的地址值:335C30
  8. 然后手动定位到该地址所在的代码段,如图:

    在这里插入图片描述
  9. 记录下上图中的地址值:335C7D
  10. 在Linux命令行窗口中,输入并执行如下代码(注意命令中的跳转指令地址替换你的对应地址,我的是:0x335C7D)
sudo echo -ne '\x90\x90' | sudo dd of=/usr/bin/gdb seek=$((0x335C7D)) bs=1 count=2 conv=notrunc
  1. 依次在Linux命令行窗口中输入如下指令:
gdb
file yourBinFileName(这里要替换成你要测试的二进制文件名)
b main
run

最后,输入 y 回车后就行了。

以上步骤都正常操作完毕之后,gdb 将正常工作。上面提示让设置永久生效,可以将 set debuginfod enabled on 写进 .gdbinit。在 home 目录下 vim .gdbinit,把 “set debuginfod enabled on” 粘进去后保存即可。

参考文献:

作者:吉安娜拉格纳罗斯 https://www.bilibili.com/read/cv20701507 出处:bilibili



版权声明:本文为weixin_46229691原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。