驱动篇——开发环境配置
写在前面
此系列是本人一个字一个字码出来的,包括示例和实验截图。由于系统内核的复杂性,故可能有错误或者不全面的地方,如有错误,欢迎批评指正,本教程将会长期更新。 如有好的建议,欢迎反馈。码字不易,如果本篇文章有帮助你的,如有闲钱,可以打赏支持我的创作。如想转载,请把我的转载信息附在文章后面,并声明我的个人信息和本人博客地址即可,但必须事先通知我。
你如果是从中间插过来看的,请仔细阅读 羽夏看Win系统内核——简述 ,方便学习本教程。
看此教程之前,问一个问题,你明确学驱动的目的了吗? 没有的话就不要继续了,请重新学习 羽夏看Win系统内核——驱动篇 里面的内容。
🔒 华丽的分割线 🔒
开发环境配置
Microsoft
官方提供了指导,点击 该链接 转到官方指导页面。
怎么装VS
和Windows 11 SDK
我就不赘述了。注意,如果你没有装Windows 11 SDK
,直接安装Windows 11 WDK
,驱动的关键头文件你会没有。
接下来说一下怎么装Windows 11 WDK
,下载好后运行,你会看到如下情况:
选择好安装目录,点击继续,然后会到下图所示情况,选中否,它会收集你的一些信息:
最后按照正常操作就行了,最后会弹出安装插件的窗体(忘了截图了,和正常安装VS
插件一样的窗体),点击Modify
。这个插件会提供一些编写驱动的模板,这东西至关重要,帮我们减少了大量的配置人力。
安装好之后,我们进行一个测试。开启VS
,选择新建项目,如果编写在XP
下面的驱动的话,注意选择Empty WDM Driver
,如下图所示:
后面就像正常新建项目一样起个名字新建就行,你就会得到一个新的空项目。然后添加一个源文件,如下图所示:
为什么要用C
,而不用C++
呢?C++
虽然更加强大,提供类的功能。但C
更加简单,对于我们来说就足够了,除非你用其开发大型驱动程序。
新建完毕后,我们用下面的代码:
#include <ntddk.h> //驱动程序必备头文件
NTSTATUS UnloadDriver(PDRIVER_OBJECT DriverObject)
{
DbgPrint("Chapter Driver By WingSummer,Unloaded Successfully!");
}
NTSTATUS DriverEntry(PDRIVER_OBJECT DriverObject, PUNICODE_STRING RegistryPath)
{
DbgPrint("Chapter Driver By WingSummer,Loaded Successfully!");
DriverObject->DriverUnload = UnloadDriver;
return STATUS_SUCCESS;
}
DbgPrint
意思是输出调试信息,那我为什么要用英文而不用中文呢?因为中文在WinDbg
进行源码调试的时候,中文会乱码,所以用英文更好些,但调试信息输出的中文并不会乱码。DriverEntry
是驱动程序的入口,和正常的C语言程序的main
函数是一样的,只是入口的参数不一样。其它的细节将会在下一篇进行讲解,就把代码复制到VS
就行了。
代码写好了,我们需要对工程进行配置,否则驱动XP
用不了:
🚀 更改目标平台,否则XP报无效驱动程序 🚀
🚀 用不到,关掉它 🚀
🚀 用不到,关掉它 🚀
设置好后,我们就可以编译了。然而理想很美好,现实很残酷。编译失败了:
报错说明需要缓解了Spectre漏洞的库
这个东西,不知道是干啥的。但我们必须安装上,否则驱动编译不了啊。好,启动Visual Studio Installer
,修改它,安装如下图所示文件:
安装好,重启VS
,打开原先我们建好的项目,继续编译,结果又报错,不过错误不是原来的了:
对于这个错误,我们只需要设置一个就可以解决,如下图所示:
设置完毕后,再编译一下,编译通过,成功生成了驱动文件。然后我们把它拖到虚拟机中,利用驱动加载工具来试一试驱动是否可用:
发现DebugView
正常显示我们想要输出的调试字符串,证明驱动正常工作。以上的配置过程也就完成了一半。
调试环境配置
调试是十分重要的一个环节。那么我们如何进行调试呢?打开WinDbg
的设置,需要添加你开发驱动的工程目录,如下图所示:
这个添加的符号目录因自己的开发驱动的位置而异,不要盲目把我的目录给添加上。然后点击确定。注意,更改需要调试器处于空闲非调试状态才能设置。
然后我们在上面的源代码中,添加一个手动断点,如下所示:
#include <ntddk.h>
NTSTATUS UnloadDriver(PDRIVER_OBJECT DriverObject)
{
DbgPrint("Chapter Driver By WingSummer,Unloaded Successfully!");
}
NTSTATUS DriverEntry(PDRIVER_OBJECT DriverObject, PUNICODE_STRING RegistryPath)
{
DbgPrint("Chapter Driver By WingSummer,Loaded Successfully!");
DriverObject->DriverUnload = UnloadDriver;
_asm
{
int 3;
}
return STATUS_SUCCESS;
}
再重新编译,拖到虚拟机中进行注册和运行,就会触发这个断点,WinDbg
就会接管并自动弹出一个窗体用来显示调试源代码:
帮助文档
网上有最新版的WDK
文档,但文档主要是针对Win10
开发驱动的,有很多API
是XP
没有的。请到 羽夏看Win系统内核——简述 下载WDK
帮助文档。然后下载成功解压,并运行Docs.msi
安装程序进行安装即可。最后的帮助文档效果如下图所示:
综上,环境就配置完毕了,本文结束。
下一篇
本文来自博客园,作者:寂静的羽夏 ,一个热爱计算机技术的菜鸟
转载请注明原文链接:https://www.cnblogs.com/wingsummer/p/15489823.html