在Linux内核上进行实时调试最常用的方法和工具为何?我知道例如Linus。反对这种针对Linux内核的调试,或者至少是反对这种调试,因此在那些年里,在这种意义上没有做太多事情,但是老实说,自2000年以来已经过去了很多时间,我很想知道关于Linux的观念是否已改变项目以及当前使用哪些当前方法在Linux内核上进行实时调试(本地或远程)?
欢迎参考有关所提到的技术和工具的演练和教程。
另一种选择是使用ICE / JTAG控制器和GDB。这种“硬件”解决方案特别适用于嵌入式系统,
但例如Qemu提供类似的功能:
用GDB“远程”存根启动QEMU其上“本地主机:1234”:监听qemu -s ...,
qemu -s ...
然后使用GDB打开vmlinux用调试信息编译的内核文件(您可以查看此邮件列表线程,他们在其中讨论了内核的未优化)。
vmlinux
连接GDB和Qemu: target remote localhost:1234
target remote localhost:1234
查看您的 实时 内核:
(gdb) where
不幸的是,到目前为止,使用GDB无法进行用户空间调试(没有任务列表信息,没有MMU重新编程以查看不同的进程上下文,…),但是如果留在内核空间中,那将非常方便。
info threads
编辑:
您可以在此PDF中获取有关该过程的更多详细信息:
使用GDB和QEMU调试Linux系统。