Device Drivers

Types of Device Drivers

Windows可能会有User-mode的驱动,但是我们只关注Kernel-Mode的驱动。

WDM Drivers

WDM是一种驱动模型,是比较常用的驱动模型。

WDM可以分为以下几类:

  • Bus Drivers

负责检测到连接到该总线的设备的与PnP/Power相关的事件,并且通知IO Manager, PnP Manager, Power Manager。

  • Function Drivers

负责某一具体设备的driver,是狭义上的driver。

Function Driver是唯一了解某类硬件特性,并且与这类硬件直接(通过调用HAL提供的接口)打交道的driver。

  • Filter Drivers

过滤驱动,负责修改或者补充某些特定driver的功能。

Layered Drivers


 

Structure of a Driver

由各种routine构成


 

Driver Objects and Device Objects

加载driver,会调用init routine。

 

对于PnP driver,新的设备plug到系统上时,driver的add device routine会被调用,此时driver可以创建一个Device Object;

对于其他driver,通常driver在init routine时调用IoCreateDevice/IoCreateDeviceSecure创建Device Object;

 

对于应用程序来说,它要操作的是Device,它并不知道该Device相对应的Driver。应用程序如果要操作Device,只能按照文件模型来进行操作,比如Read/Write/IOControl。

而打开文件,必须知道文件的路径,对于Device来说,它们的路径是\Device目录下,这个路径是不能被应用程序访问到的,因此需要创建软链接到\Global??目录下,这样就可以被应用程序打开了。

对于PnP设备来说,它们的路径名是动态生成的GUID表示。

 

Device Object与Driver Object是互相通过指针关联在一起的。

Device Object里面保存device queue,里面保存所有发送到该设备上的IRP数据包;

IO System会将Device Object的device queue中的IRP按照一定的顺序取出,连同Device Object的指针一同传递给Driver Object,由Driver调用相应的routine完成对于IRP的操作。

Opening Devices

因为底层设备对于各个用户态的进程来说,属于“临界区”资源,需要同步各个进程的访问。

所以如果是要向某个设备write数据时,最好是使用exclusive write的权限打开,这样可以阻止别的进程打开这个文件。

但是这样就把整个文件的内容都锁住了,也可以使用LockFile,可以只锁住文件的一部分,而文件的其他部分是允许其他进程访问的。

posted @ 2014-06-09 16:57  Daniel King  阅读(321)  评论(0编辑  收藏  举报