news 2026/4/30 23:56:16

第一个驱动程序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
第一个驱动程序

第一个驱动程序

创建空项目

删除.inf文件

关闭将警告视为错误

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

代码:

#include<ntifs.h>//卸载函数VOIDDriverUnload(PDRIVER_OBJECT pDriver){DbgPrint("(mydriver)驱动程序停止运行了。\n");}NTSTATUSDriverEntry(PDRIVER_OBJECT pDriver,PUNICODE_STRING RegistryPath){DbgPrint("(mydriver)驱动开始运行了。\n");pDriver->DriverUnload=DriverUnload;return0;}




调试技巧

勾选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:

win7:1.Cookie 未初始化 → 自动用 RDTSC 生成一个随机值2.若生成的值为0→ 使用默认 Cookie3.最终写入 complement4.完全不会 FailFast5.驱动允许自行初始化 Cookie 总结:无论cookie是什么值,都不会蓝屏

win10:

1.Cookie==0→ FailFast(蓝屏)2.Cookie==默认弱cookie(0x0BB40E64E)→ FailFast(蓝屏)3.不允许用 RDTSC 生成新的 cookie4.只在 cookie 合法时写 complement5.任何非法 cookie 都导致int29h(RtlFailFast)

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

解决方案思路:修改驱动的 __security_cookie

只要满足:

__security_cookie!=0__security_cookie!=0xBB40E64E

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

因此我尝试:

将 __security_cookie 从0xBB40E64E修改为0xBB40E64F修改步骤 IDAPRO:file->patch program->changebyte 修改值,最后保存 file->patch program->Apply patches to input file

于是 __security_init_cookie 会顺利进入:

noteax mov __security_cookie_complement,eax retn 并成功执行 DriverEntry

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

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

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 0:56:57

W_Mesh_28x:Blender参数化建模终极指南

还在为复杂的3D建模头疼吗&#xff1f;&#x1f680; W_Mesh_28x这款神奇的Blender插件将彻底改变你的建模体验&#xff01;想象一下&#xff0c;只需要调整几个简单的参数&#xff0c;就能创造出完美的几何形状——这就是参数化建模的魅力所在。无论你是设计新手还是资深创作者…

作者头像 李华
网站建设 2026/5/1 7:57:32

Bypass Paywalls Clean:终极内容解锁工具快速上手指南

Bypass Paywalls Clean&#xff1a;终极内容解锁工具快速上手指南 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 在信息获取日益重要的今天&#xff0c;你是否曾因付费墙的阻挡而无法…

作者头像 李华
网站建设 2026/5/1 8:02:24

270M参数撬动百亿市场:Gemma 3微型模型如何重塑边缘AI格局

270M参数撬动百亿市场&#xff1a;Gemma 3微型模型如何重塑边缘AI格局 【免费下载链接】gemma-3-270m 项目地址: https://ai.gitcode.com/hf_mirrors/unsloth/gemma-3-270m 导语 谷歌Gemma 3 270M以2.7亿参数实现行业突破&#xff0c;通过原生微型架构设计与4位量化技…

作者头像 李华
网站建设 2026/5/1 6:16:26

你的QQ空间回忆会消失吗?GetQzonehistory帮你一键永久保存

你的QQ空间回忆会消失吗&#xff1f;GetQzonehistory帮你一键永久保存 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 还记得那些年发过的QQ空间说说吗&#xff1f;从青涩的学生时代到职…

作者头像 李华
网站建设 2026/5/1 6:14:51

揭秘MCP 2025量子编程新增内容:这5项技能你必须提前掌握

第一章&#xff1a;MCP 2025量子编程认证新趋势解读随着量子计算从理论探索逐步迈向工程实现&#xff0c;微软于2025年全面升级其Microsoft Certified Professional&#xff08;MCP&#xff09;认证体系&#xff0c;首次将量子编程作为核心能力模块纳入技术人才评估标准。这一变…

作者头像 李华