Linux Driver 编写思考(2)

driver 应该提供哪些功能呢?

1,  为应用层使用 driver 提供接口;

这个应该是很好理解的,不可能让每个上层软件的作者自己写驱动来访问硬件;所以必须要抽象出一套接口,但是需要哪些接口呢?

Linux 的 driver 实现很有意思,把任何东西都抽象成文件,包括硬件,这样对硬件的操作也就只需提供 vfs 所需的一套接口,当然其实这些接口的类型在很大程度上划分了 driver 的类型,而这些接口也可以提供其它的形式,比如网卡就不提供这些接口;

Open :打开,也就是打开这个设备,这只是抽象的概念,很多硬件设备不存在这样的物理动作,比如门,我们才说打开,当然如果理解所谓“打开心扉”也就很好理解这里的 driver 所抽象出的打开了;先前所说硬件的初始化可以在 probe 函数里面做,当然我想有些动作放在 open 里面做也可以的,但是必须要考虑的是, open 是可能出现许多个进程来访问的,或者你自己要上锁或者你就要考虑可重入性,也就是说如果一些动作只能做一次,那么显然放在 open 里面来做就不合适了。

Close :这个和 open 相反的动作,但是这个 close 是上层才有的一个概念,在驱动里面用来一个叫 release 的接口实现,至于 close 到 release 之间的转换就需要去看看文件系统这层的实现了。

Read :这就是读取数据了,没什么好说,比如串口,比如 touch panel ;

Write :这就是写了,也就是往设备里面写数据;

其它的一些对上的接口 …. 就不讨论了;

而 driver 还必须要提供其它的接口:那就是做为 linux driver 本身说必须要提供的接口,这些接口通常是内核自身所调用的;

那就是

Probe :这个函数很关键,它作为一个桥梁连接设备和 driver ,并且必须要对硬件进行初始化,以便在以后的用户接口调用的时候设备能正常工作;从软件的角度说,许多空间的分配等都在这里做,通过 dev_set_drvdata 和 dev_get_drvdata 设置和获取相应的数据;

Remove :这个函数和上面这个函数是相反的,也就是负责清理扫尾的工作,负责释放数据结构,停止硬件等;

Suspend :这个是在睡眠的时候调用的,在这里就必须要进行功耗控制;

Resume :这个就是唤醒的时候调用的,它需要执行相应的恢复动作,以便硬件能正常工作;

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/27782.html