LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 1192|回复: 1

请问如何调试内核的驱动程序

[复制链接]
发表于 2007-11-13 09:52:53 | 显示全部楼层 |阅读模式
一般人都是用printk来调试,但是在块设备驱动程序中,很多情况下,我如果想跟踪bio的执行情况,在bio的end_read或者end_write函数中加入一个printk语句的话,因为内核每次都会发起大量的bio请求,调试的时候就会打印大量的信息。这样的话就很不方便跟踪程序流程了。
另外有人说由于驱动程序是内核的一部分,所以不能作为一个单独的进程,不能通过设断点的方法调试。  
  请问大家在调试内核驱动程序的时候用的是什么方法啊?
发表于 2007-11-15 00:03:36 | 显示全部楼层
一般情况下是在相应的drive或是能够设置触发条件的地方设置printk。通用代码由于调用的次数太多,很容易冲掉其他地方的log,一般不用设置printk。如果你确实对某断代码持怀疑态度,可以自己写一个driver,监控输入输出条件。这样可以快速测试你需要的所有测试用例。另外一个选择是寻找已有的需要调用通用代码的模块,分析是否可以在一些回调函数中添加log。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表