第1章Linux设备驱动简介一

        以 Linux 为代表的自由操作系统的很多优点之一,是它们的内部是开放给所有人看的.操作系统,它的代码只局限于少数的程序员,现在已准备好让任何具备必要技能的人来检查, 理解以及修改. Linux 已经帮助使操作系统民主化.  Linux 内核保留有大量的复杂的代码,那些想要成为内核 hacker 的人需要一个入口点, 这样他们可以进入代码中, 不会被代码的复杂性压倒. 通常, 设备驱动提供这样的门路.

        驱动程序在 Linux 内核里扮演着特殊的角色.它们是截然不同的"黑盒子",  使硬件的特殊的一部分响应定义好的内部编程接口. 它们完全隐藏了设备工作的细节.用户的活动通过一套标准化的调用来进行,这些调用与特别的驱动是独立的;设备驱动的角色就是将这些调用映射到作用于实际硬件的和设备相关的操作上.这个编程接口是这样, 驱动可以与内核的其他部分分开建立,并在需要时在运行时"插入".这种模块化使得 Linux 驱动易写, 以致于目前有几百个驱动可用.

        硬件供应商, 通过为产品开发 Linux 驱动, 可以给产品的潜在市场增加大量的正在扩张的 Linux用户基数. 还有 Linux 系统的开放源码性质意味着如果驱动编写者愿意, 驱动源码能够快速地散布到几百万用户.

        每一个驱动都是不同的, 作为一个驱动编写者,需要深入理解特定设备.但是大部分的原则和基本技术对所有驱动都是一样的.

        在学习编写驱动时, 通常会发现大量有关 Linux 内核的东西. 这会帮助你理解你的机器是如何工作的, 以及为什么事情不是如你所愿的快, 或者不是如你所要的进行.我们会逐步介绍新概念, 由非常简单的驱动开始并建立它们; 每一个新概念都伴有例子代码, 这样的代码不需要特别的硬件来测试.

1.1. 驱动程序的角色

        尽管说一个驱动是"灵活"的, 听起来有些奇怪,因为它强调了一个驱动程序的角色是提供机制, 而不是策略.

        机制和策略的区分是其中一个在 Unix 设计背后的最好观念. 编程问题可以划分为 两个部分:" 提供什么能力"(机制) 和 "如何使用这些能力"(策略).如果这两方面由程序的不同部分来表达, 或者甚至由不同的程序共同表达,  软件包是非常容易开发和适应特殊的需求.

        例如, 图形显示的 Unix 管理划分为 X 服务器, 它理解硬件以及提供了统一的接口给用户程序, 还有窗口和会话管理器,它实现了一个特别的策略, 而对硬件一无所知.可以在不同的硬件上使用相同的窗口管理器, 而且不同的用户可以在同一台工作站上运行不同的配置. 甚至完全不同的桌面环境, 例如 KDE(桌面环境Kool Desktop Environment) 和 GNOME(Linux下的桌面环境),可以在同一系统中共存.另一个例子是 TCP/IP 网络的分层结构: 操作系统提供 socket 抽象层, 它对要传送的数据而言不实现策略, 而不同的服务器负责各种服务( 以及它们的相关策略). 而且, 一个服务器, 例如 ftpd 提供文件传输机制, 同时用户可以使用任何喜欢的客户端;无论命令行还是图形客户端都存在, 并且任何人都能编写一个新的用户接口来传输文件.

        在驱动相关的地方,机制和策略之间的同样的区分都适用. 软驱驱动是不含策略的--它的角色仅仅是将磁盘表现为一个数据块的连续阵列.系统的更高级部分提供了策略, 例如谁可以存取软驱驱动, 这个软驱是直接存取还是要通过一个文件系统, 以及用户是否可以加载文件系统到这个软驱.因为不同的环境常常需要不同的使用硬件的方式,尽可能对策略透明是非常重要的.

        在编写驱动时,应当特别注意这个基础的概念: 编写内核代码来存取硬件,但是不能强加特别的策略给用户, 因为不同的用户有不同的需求.驱动应当做到使硬件可用,将所有关于如何使用硬件的事情留给应用程序.一个驱动, 这样, 就是灵活的,如果它提供了对硬件能力的存取, 没有增加约束. 然而, 有时必须作出一些策略的决定. 例如, 一个
数字 I/O 驱动也许只提供对硬件的字符存取, 以便避免额外的代码处理单个位.

        也可以从不同的角度看驱动:是一个存在于应用程序和实际设备之间的软件层.  驱动的这种特权的角色允许驱动开发者严密地选择设备应该如何表现: 不同的驱动可以提供不同的能力, 甚至是同一个设备. 实际的驱动设计应当是在许多不同考虑中的平衡. 例如,一个单个设备可能由不同的程序并发使用, 驱动程序员有完全的自由来决定如何处理并发性.能在设备上实现内存映射而不依赖它的硬件能力,或者你能提供一个用户库来帮助应用程序员在可用的原语之上实现新策略, 等等.一个主要的考虑是在展现给用户尽可能多的选项, 和你不得不花费的编写驱动的时间之间做出平衡,还有需要保持事情简单以避免错误潜入.

        对策略透明的驱动有一些典型的特征. 这些包括支持同步和异步操作,可以多次打开的能力, 利用硬件全部能力, 没有软件层来"简化事情"或者提供策略相关的操作.这样的驱动不但对他们的最终用户好用, 而且证明也是易写易维护的. 成为策略透明的实际是一个共同的目标, 对软件设计者来说.

        许多设备驱动, 确实, 是与用户程序一起发行的, 以便帮助配置和存取目标设备.这些程序包括简单的工具到完全的图形应用. 

        但是, 应当理解,用户程序是一个软件包的构成部分,并且就算是对策略透明的软件包在发行时也会带有配置文件, 来对底层的机制应用缺省的动作。


猜你喜欢

转载自blog.csdn.net/xiezhi123456/article/details/80828805
今日推荐