驱动简介:
从本质上说,驱动是一个软件程序 。它负责在操作系统和硬件设备之间建立通信。
另一个比喻:驱动是硬件的"灵魂 "。硬件插上电脑后只是"肉体 ",驱动被安装后,操作系统才学会如何唤醒它的能力,比如让显卡显示3D画面,让网卡上网。
*Windows系统------驱动包的组成:
一个完整的驱动程序"包",通常由三个部分组成:
1、驱动程序的可执行文件(*.sys)
这是驱动的核心大脑,里面是你写的所有逻辑代码,比如"检测到温度过高,就关闭风扇"。它被编译为.sys格式后,在安装时会位于C:\Windows\System32\drivers\文件夹下。它运行在CPU的Ring0(内核模式),拥有最高权限,负责直接与硬件打交道。
2、驱动程序安装信息文件(*.inf)
这是一个告诉Windows如何安放你的驱动的说明书,它包含:
① 这个驱动适配哪个硬件(硬件ID)
② 驱动文件(*.sys)应该复制到哪里
③ 需要在注册便中写入什么信息来让系统识别这个驱动
3、驱动程序目录文件(*.cat)
这是一个数字身份证(防伪标签)。
它证明了你的驱动文件是经过微软测试和签名的,没有被篡改过。
System32文件夹 为何以32结尾?是否表明其下文件都是32位的?
以32结尾并不代表其下文件都是32位的,这是一个历史遗留的命名问题。
在早期系统中,System表示16位目录,System32则表示32位目录。
后来出了64位Windows,64位系统文件也放在 C: \ Windows \ System32 下。
而把真正的32位系统文件放在:C: \ Windows \ SysWOW64下。
WOW64 = Windows - on - Windows64,负责运行32位程序的子系统。
普通程序(.exe)如何间接使用?
普通程序运行在 Ring 3(用户模式) ,没有权限直接碰
.sys。它们必须通过 Windows API 作为桥梁:
调用 API :比如调用
CreateFile、DeviceIoControl、ReadFile、WriteFile。系统服务分发 :这些 API 会触发一个"系统调用"(如
syscall指令),CPU 从 Ring 3 切换到 Ring 0。I/O 管理器 :Windows 内核收到调用后,会创建一个 IRP(I/O 请求包)。
传递给驱动 :I/O 管理器根据你打开的设备句柄(如
\\.\MyFan),找到对应的设备栈,把 IRP 分发给最上层驱动。逐层传递 :IRP 沿着设备栈向下传递,最终到达你的
.sys驱动中的回调函数(比如EvtIoDeviceControl)。关键点 :
.sys里的函数不是被.exe直接调用 的,而是被 I/O 管理器 通过 IRP 回调 的。可以用一个类比:
应用程序:顾客
Windows API :餐厅的菜单
syscall 指令 + CPU 模式切换 :服务员把菜单送到后厨窗口
I/O 管理器 :后厨的调度主管
你的驱动 (.sys) :炒菜的厨师
顾客(应用程序)不能直接指挥调度主管(I/O 管理器)。顾客只能按照菜单(API)点菜,然后服务员(syscall)把单子送到后厨。调度主管看到单子后,才会安排厨师做菜。
Windows电脑 驱动 笔记
nnsix2026-06-11 10:43
相关推荐
疯狂打码的少年1 小时前
【程序语言与编译】程序设计语言分类(机器/汇编/高级)旅僧1 小时前
机械臂学习笔记(更新中)qingwufeiyang_5302 小时前
Python学习笔记3-项目实战-AI应用智者知已应修善业2 小时前
【proteus 74160实现模60计数器模41计数器】2024-5-27墨白曦煜2 小时前
算法实战笔记:空间换时间的黑魔法——单调栈全景解析(十一)问心无愧05132 小时前
ctf show web入门157 158闪闪发亮的小星星2 小时前
STK-03-通信卫星方向最常遇到的场景.千余2 小时前
【C++】C++继承入门(上):继承语法与基本特性详解问心无愧05132 小时前
ctf show web入门159