当前位置:Linux教程 - Linux综合 - Linux内核调试工具:Kdb应用指南(4)

Linux内核调试工具:Kdb应用指南(4)

  作者:胡风华     杂项    id:指令反汇编     格式:id <vaddr>     从vaddr开始的地址反汇编指令。     cpu:切换到另一个CPU     格式:cpu <cpunum>     这条命令仅仅在SMP结构下有用,它切换到由cpunum指定的CPU。     ps:显示所有活动的进程     格式:ps     显示当前的活动的进程。包括pid、父进程pid、CPU号、当前状态,以及对应的线程。     reboot:重新启动机器     格式:reboot     在某些情况下,内核无法返回到正常工作状态,这时可以利用reboot重新启动机器。注意在重启机器前,它不进行任何状态保存的工作。     sections:列出内核中所有已知的段的信息     格式:sections     列出模块和内核的所有已知的段的信息。首先是模块信息,最后是内核信息。包括模块名和一个或者多个段的信息。段信息包括段名、段起始地址、段结束地址和段标识。本命令仅仅是为外部调试器而设立的。     sr:激活SysRq代码,也就是调用MAGIC_SYSRQ函数     格式:sr <sysrq key>     将sysrq key字符作为参数传递给SysRq函数进行处理,就像你已经键入了SysRq键和该字符一样。如果要使用这个命令,需要在配置内核时,选择Magic SysRq Key。然后在新内核启动后,使用如下命令激活SysRq功能。     #echo “1” > /proc/sys/kernel/sysrq     这是一个功能强大的命令,它使得在kdb中可以使用操作系统提供的SysRq处理函数。     lsmod:列出内核中加载的所有模块     格式:lsmod     显示所有模块的信息。包括模块名、模块大小、模块结构地址、引用计数,以及被哪个模块所引用。     rmmod:卸载一个模块     格式:rmmod <modname>     将由modname指定的模块从内核中卸载。     ll:对链表中的每个元素重复执行命令     格式:ll <addr> <link-offset> <cmd>     它对以地址addr开头的链表的头link-offset个元素,重复执行cmd命令。     help和?:显示帮助信息。     格式:help 或者?     显示kdb的命令以及简单的用法。     提高调试效率    kdb是一个强大的内核调试工具,gdb需要两台机器通过串口才能进行调试,而kdb只需要一台机器即可进行调试,对于普通用户来说,是非常方便的。对于编写内核程序(譬如可加载模块)的程序员来说,kdb提供的这些命令使得调试工作难度大大降低,使得调试效率得以提高。另外对于内核感兴趣的人可以使用kdb来查看内核的数据结构和运行状态,从而加深对内核的理解。不足之处是kdb无法提供源码级的调试,要求程序员有一定的汇编程序基础。但总的来说,kdb提供了一种强有力的内核调试手段,笔者在开发内核模块时,使用kdb进行调试,在较短的时间内完成了调试任务。

(出处:http://www.sheup.com)