Linux 字符设备,从应用程序调用 read() 开始,到驱动的 read() 函数,中间经历了什么过程?
本人在 Linux 内核下设计过几个字符设备,从 “怎么用” 的这个角度来讲,略懂一些。
但是有一次,我被问到 “从应用程序系统调用开始,是怎么到达你的驱动函数的”?我瞬间语塞,不知道怎么回答。
于是我把这个问题转到 SegmentFault 吧,询问有无大牛能够回答,或者能够告诉我上哪里找答案、要看学习那些资料以了解这一点呢?
谢谢~~
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
如果你要讲原理,这里可以讲很多,我这里只讲一下你从代码上查找的方法,
1,在你设备注册上加打印。
2,在你的open函数中加打印,
3, 在你的调用read函数中加打印,
如果在这三个过程中,没有打印输出,则可能是没有执行到,但要排除一种可能,就是系统的打印条件比较高,你的输出优先级比较低,这个可以修改
这样就可以知道你的调用了。
原理就是上面的三个步骤。
1 : 可以使用 dump_stack() 查看调用的函数经过.
2 : struct cdev 是所有字符设备的基类,里面抽象出了大量字符设备共有的特性,
struct cdev {
}
设备文件被打开,会生成 一个 Inode对象, inode 与 这个cdev有关联的关系,通过这个inode可以得到
这个cdev,得到这个cdev之后,就调用 file_operations中对应的函数了,
对应的是, 系统调用 open ----->vfs层 open -----> 字符设备提供的file_operations中的对应的函数open.