小编典典

Linux内核实时调试,如何完成以及使用哪些工具?

linux

在Linux内核上进行实时调试最常用的方法和工具为何?我知道例如Linus。反对这种针对Linux内核的调试,或者至少是反对这种调试,因此在那些年里,在这种意义上没有做太多事情,但是老实说,自2000年以来已经过去了很多时间,我很想知道关于Linux的观念是否已改变项目以及当前使用哪些当前方法在Linux内核上进行实时调试(本地或远程)?

欢迎参考有关所提到的技术和工具的演练和教程。


阅读 520

收藏
2020-06-02

共1个答案

小编典典

另一种选择是使用ICE /
JTAG控制器和GDB。这种“硬件”解决方案特别适用于嵌入式系统,

但例如Qemu提供类似的功能:

  • 用GDB“远程”存根启动QEMU其上“本地主机:1234”:监听qemu -s ...

  • 然后使用GDB打开vmlinux用调试信息编译的内核文件(您可以查看邮件列表线程,他们在其中讨论了内核的未优化)。

  • 连接GDB和Qemu: target remote localhost:1234

  • 查看您的 实时 内核:

    (gdb) where
    

    0 cpu_v7_do_idle () at arch/arm/mm/proc-v7.S:77

    1 0xc0029728 in arch_idle () atarm/mach-realview/include/mach/system.h:36

    2 default_idle () at arm/kernel/process.c:166

    3 0xc00298a8 in cpu_idle () at arch/arm/kernel/process.c:199

    4 0xc00089c0 in start_kernel () at init/main.c:713

不幸的是,到目前为止,使用GDB无法进行用户空间调试(没有任务列表信息,没有MMU重新编程以查看不同的进程上下文,…),但是如果留在内核空间中,那将非常方便。

  • info threads将为您提供不同 CPU 的列表和状态 __

编辑:

您可以在此PDF中获取有关该过程的更多详细信息:

使用GDB和QEMU调试Linux系统

2020-06-02