编写驱动模块的时候,出现问题如何调试呢?

发布于 2022-09-18 19:20:48 字数 290 浏览 65 评论 0

我在看宋宝华的《linux设备驱动开发详解》,看字符设备驱动那一节的时候,照着抄了书上的代码6.17。然后编译也通过了。
insmod globalmem.ko
然后 mknod /dev/globalmem c 252 0
可我在运行命令:echo "hello" > /dev/globalmem的时候,总是报错:
bash:echo:write error:Bad address.
我也不知道问题出在什么地方。也不知道怎么调试。
想问一下,编写模块的时候出现问题怎么调试啊。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(9

夜深人未静 2022-09-25 19:20:48

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

┼── 2022-09-25 19:20:48

在内核模块中加上printk吧,这是最常用的。按照程序的流程,通过不同的位置printk,就可以定位程序的问题

挽心 2022-09-25 19:20:48

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

旧竹 2022-09-25 19:20:48

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

微暖i 2022-09-25 19:20:48

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

辞取 2022-09-25 19:20:48

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

已下线请稍等 2022-09-25 19:20:48

原帖由 dreamice 于 2009/2/27 12:19 发表
根据oops来定位,会提示你在哪个函数中导致的oop,然后你跟踪一下这个函数,一步一步确定出错源。

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

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

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

谁有好办法吗

帥小哥 2022-09-25 19:20:48

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

謸气贵蔟 2022-09-25 19:20:48

LDD3中第3章说明了用GDB调试的方法,不过能调试的信息有限。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文