windows驱动开发学习1

Windows系统是一种分层结构:

总体分为用户态(Ring3)和内核态(Ring0)。所有应用程序都是运行在用户态,是最低特权级。设备驱动层属于内核态。

分层结构使得各个模块之间相互耦合,减少关联。

驱动分类:

①内核扩展驱动(硬件无关联)

②即插即用驱动(特定硬件关联)

③文件系统驱动(接受文件I/O,将请求转化为存储设备或网络设备的I/O请求)

驱动工作路径:bus->os->driver->device

NT、WDM、WDF区别联系:

NT驱动模型:NT式驱动程序模型是一种比较老式的驱动程序模型,适用于现有的Windows系统。NT驱动框架主要是由驱动入口函数,若干分发函数,驱动卸载函数组成。程序开发者可以编写一个完全不支持硬件工作的驱动程序,却可以将代码运行在内核模式中。安全中用的最多的就是NT模型。

WDM驱动程序模型(Windows Driver Model):WDM式驱动程序在NT式驱动程序的基础上,还必须:

1、包括wdm.h头文件,不是ntddk.h(wdm.h是ntddk.h的一部分)

2、被设计为一种WDM驱动程序类型,如总线驱动、功能驱动,过滤驱动等;

3、创建设备对线属于WDM设备对象类型(物理设备对象、功能设备对象、过滤设备对象);

4、支持即插即用;

5、支持电源管理;

6、支持Windows管理规范

WDF驱动程序模型(Windows Driver Foundation):WDF驱动框架对WDM进行了一次封装,提供IO model ,pnp和电源管理模型;且提供了一些与操作系统相关的处理函数。 WDF驱动程序包括两个类型,一个是内核级的,称为KMDF(Kernel-Mode Driver Framework),为SYS文件;另一个是用户级的,称为UMDF(User-Mode Driver Framework),为DLL文件。

发布了13 篇原创文章 · 获赞 2 · 访问量 402

猜你喜欢

转载自blog.csdn.net/z17805008775/article/details/100508006