免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3309 | 回复: 9
打印 上一主题 下一主题

编写驱动模块的时候,出现问题如何调试呢? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-02-25 20:50 |只看该作者 |倒序浏览
我在看宋宝华的《linux设备驱动开发详解》,看字符设备驱动那一节的时候,照着抄了书上的代码6.17。然后编译也通过了。
insmod globalmem.ko
然后 mknod /dev/globalmem c 252 0
可我在运行命令:echo "hello" > /dev/globalmem的时候,总是报错:
bash:echo:write error:Bad address.
我也不知道问题出在什么地方。也不知道怎么调试。
想问一下,编写模块的时候出现问题怎么调试啊。

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
2 [报告]
发表于 2009-02-25 22:28 |只看该作者

回复 #1 szjrabbit 的帖子

最简单的用printk来看调试信息,也可以用gdb

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
3 [报告]
发表于 2009-02-26 16:02 |只看该作者
在内核模块中加上printk吧,这是最常用的。按照程序的流程,通过不同的位置printk,就可以定位程序的问题

论坛徽章:
0
4 [报告]
发表于 2009-02-27 06:03 |只看该作者

回复 #2 dreamice 的帖子

用gdb咋调内核驱动啊?那不是把整个内核都中断了吗?

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
5 [报告]
发表于 2009-02-27 09:40 |只看该作者

回复 #4 llzzccc 的帖子

只调试你这个模块,可以查看一下相关资料

论坛徽章:
0
6 [报告]
发表于 2009-02-27 11:43 |只看该作者

回复 #2 dreamice 的帖子

可是 有时候,出现oops直接就死机了,这种情况下怎么定位错误呢?

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
7 [报告]
发表于 2009-02-27 12:19 |只看该作者

回复 #6 szjrabbit 的帖子

根据oops来定位,会提示你在哪个函数中导致的oop,然后你跟踪一下这个函数,一步一步确定出错源。

论坛徽章:
5
8 [报告]
发表于 2009-02-27 13:12 |只看该作者
原帖由 dreamice 于 2009/2/27 12:19 发表
根据oops来定位,会提示你在哪个函数中导致的oop,然后你跟踪一下这个函数,一步一步确定出错源。


提示出错函数的相对位置, 比如 function_abc 0x10/0x50
就是在总目标代码0x50长度的0x10位置处。

再在原代码大概位置处检查语句。我是这么定位的。

不过根据这个相对位置,没办法精确对应原代码。

谁有好办法吗

论坛徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
9 [报告]
发表于 2009-02-27 13:17 |只看该作者

回复 #8 yidou 的帖子

一般来说能看个大概,具体点的话,要结合反汇编来看,前提是要对汇编有一定的熟悉,才知道这一行汇编对应到C代码中的哪一行了

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
10 [报告]
发表于 2009-02-27 14:14 |只看该作者
LDD3中第3章说明了用GDB调试的方法,不过能调试的信息有限。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP