使用QEMU+GDB调试Linux驱动程序

前提:

QEMU中已经添加了设备支持,能够正常insmod/rmmod xxx.ko,然后才能有接下来的调试。

step1:打开如下编译选项然后编译Linux内核

CONFIG_DEBUG_INFO = y,

CONFIG_RANDOMIZE_MEMORY =n,

CONFIG_KGDB = y

CONFIG_GDB_SCRIPTS = y

编译后会生成bzImage、vmlinux、vmlinux-gdb.py。

然后在本地~/目录创建.gdbinit文件,并在文件中添加如下指令

add-auto-load-safe-path  /Linux/scripts/gdb/vmliunx-gdb.py

step2: 编译要调试的xxx.ko

这里需要注意编译时需要在Makefile中添加-g参数。比如我这里编译后生成xxx.ko

step3:Qemu启动

Qemu的启动参数中加 -s,并在使用上述生成的bzImage来启动qemu,启动后insmod xxx.ko后可以在/sys/module/xxx/sections目录中分别查看其.text/.data/.bss

step4:运行gdb

在本地进到Linux kernel目录,执行如下命令:

gdb vmlinux

target remot :1234

lx-symbols  xxx.ko(或者add-symbol-file xxx.ko  -s .data  -s .bss )

step5: 调试xxx.ko

首先在gdb中设置设置断点,然后continue;

在qemu中执行testcase,然后便可以发现停留在断点处。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张帅峰_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值