第一个驱动程序

第一个驱动程序

创建空项目

删除.inf文件

关闭将警告视为错误

设置驱动在什么操作系统运行

代码:

cpp 复制代码
#include<ntifs.h>
//卸载函数
VOID DriverUnload(PDRIVER_OBJECT pDriver)
{
	DbgPrint("(mydriver)驱动程序停止运行了。\n");
}


NTSTATUS DriverEntry(PDRIVER_OBJECT pDriver, PUNICODE_STRING RegistryPath)
{


	DbgPrint("(mydriver)驱动开始运行了。\n");
	

	pDriver->DriverUnload = DriverUnload;
	return 0;

}

调试技巧

勾选view ->options->evaluate on hover选项,当你把鼠标移动到某个寄存器、变量、内存地址、表达式上时,windbg会自动对这个内容求值并弹出气泡显示它的值。

使win10驱动在win7下运行

测试发现,在driver setting选项中选择win10,编译生成的sys文件运行在win7下直接蓝屏。我们的代码只是DbgPrint输出了一下,并没有和win10强关联的代码,为什么会蓝屏呢?

接下来分析一下.win10版本的sys和win7版本的.sys

win10和win7的入口函数都是GSDriverEntry,都同样先执行一个___security_init_cookie函数,然后再跳入我们代码里写的DriverEntry函数。

__security_init_cookie 是vs编译器在编译内核驱动或用户态程序时自动插入的一个安全初始化函数,用于设置 GS 安全 Cookie(Security Cookie)。

win7和win10的__security_init_cookie 函数区别很大,下面分析一下:

win7:

cpp 复制代码
win7:
1.	Cookie 未初始化 → 自动用 RDTSC 生成一个随机值
2.	若生成的值为 0 → 使用默认 Cookie
3.	最终写入 complement
4.	完全不会 FailFast
5.	驱动允许自行初始化 Cookie

总结:无论cookie是什么值,都不会蓝屏

win10:

cpp 复制代码
1.	Cookie == 0 → FailFast(蓝屏)
2.	Cookie == 默认弱 cookie(0x0BB40E64E) → FailFast(蓝屏)
3.	不允许用 RDTSC 生成新的 cookie
4.	只在 cookie 合法时写 complement
5.	任何非法 cookie 都导致 int 29h(RtlFailFast)

可以看到win10的sys代码逻辑无论如何都会蓝屏,但 Win10 在加载驱动前,会自动覆盖___security_cookie这个值。但是win7不会写___security_cookie,所以在win7上执行肯定会蓝屏

只要满足:

cpp 复制代码
__security_cookie != 0
__security_cookie != 0xBB40E64E

那么在win7上执行 Win10驱动文件, __security_init_cookie 就不会进入 FailFast(蓝屏)。

因此我尝试:

cpp 复制代码
将 __security_cookie 从 0xBB40E64E 修改为 0xBB40E64F

修改步骤
IDAPRO: file->patch program->changebyte
修改值,最后保存
file->patch program->Apply patches to input file

于是 __security_init_cookie 会顺利进入:

cpp 复制代码
not eax
mov __security_cookie_complement, eax
retn

并成功执行 DriverEntry

但是需要注意的是:修改了Cookie导致改变了 PE Checksum(optional_header.Checksum),所以还需要修复Checksum

cpp 复制代码
PE 的 Checksum 是一个 32 位加法校验和,其算法非常简单粗暴:
把整个文件按 16-bit(WORD)累加,加到 32 位整数里,溢出自动回卷,然后加上文件长度。
所以:
0x00005992改为0x00005992+1=0x00005993

最终成功使win10驱动在win7运行!

相关推荐
小+不通文墨39 分钟前
树莓派4b-wiringpi库的安装和使用
驱动开发·经验分享·笔记·嵌入式硬件·学习
披着假发的程序唐3 小时前
STM32 H743 MPU的配置使用方法
linux·c语言·c++·驱动开发·stm32·单片机·mcu
枳实-叶3 小时前
【Linux驱动开发】第7天:总线-设备-驱动三大核心模型:通俗讲解+完整流程图
linux·驱动开发·流程图
枳实-叶21 小时前
【Linux驱动开发】第6天:互斥锁mutex/自旋锁spinlock+驱动全流程+应用测试程序
linux·驱动开发
nuoxin1141 天前
SSD201-富利威
arm开发·驱动开发·fpga开发·ffmpeg·射频工程
2601_949695591 天前
电脑鼠标一卡一卡的原因是什么?附详细排查步骤
驱动开发·计算机外设·电脑
颖火虫盟主2 天前
规范驱动开发(Spec-Driven Development)
驱动开发
charlie1145141913 天前
嵌入式Linux驱动开发——新 API 字符设备驱动完整教程 - 从设备结构体到应用测试
linux·运维·驱动开发
长安第一美人3 天前
RT-Thread 工业屏驱动开发实战:UART 串口屏协议解析 + 数据实时刷新 + 设备驱动框架完整实现
驱动开发·嵌入式硬件·rt-thread·工业控制·uart通信·串口屏驱动
不怕犯错,就怕不做4 天前
RK3562的CPU如何降频及关闭硬件编解码
linux·驱动开发·嵌入式硬件