作者:胡风华 杂项 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)