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

王朝system·作者佚名  2008-05-19
宽屏版  字体: |||超大  

作者:胡风华

杂项

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进行调试,在较短的时间内完成了调试任务。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有