好像是空项目,然后自己配制VS能编译Keil参数,就像那个X86 X64两选项那种自己加一个自己配制 |
|
|
|
是这样子的,要对应版本 |
|
微软在”WDK7600“以后就不再提供独立嘚内核驱动开发包了而是必须首先安装微软集成开发环境VisualStudio,然后再从微软官网下载集成的WDK开发包、或者离线安装包但是安装后Visual Studio就集驱動程序开发,VS能编译Keil安装,部署和调试于一身使得Windows驱动程序开发会变得更容易。对于Windows 10和Visual Studio2015驱动开发WDK环境变量的配置与其它版本的Windows和WDK环境的配置有很大不同。本人也是苦苦探索了近一周的时间才配好
设备驱动程序是硬件设备连接到计算机系统的软件接口,任何设备都必須有相应的驱动程序才能在计算机系统上正常工作设备驱动程序的优劣直接关系到整个系统的性能和稳定性,因此设计和开发稳定高效的驱动程序具有重要意义。
Model)为基础的但是,如果使用DDK来开发WDM其开发难度之大,根本不能奢望像用户模式应用程序开发那样容易洇此,一般用户都是使用WinDriver、DriverStudio之类的第三方工具为改善这种局面,从Vista开始微软推出了新的驱动程序开发环境WDF(Windows Driver Foundation )。WDF(WindowsDriver Model)的基础上发展而来的支持面向对象、事件驱动的驱动程序开发,提供了比WDM更高层次抽象的高度灵活、可扩展、可诊断的驱动程序框架WDF框架管理了大多数与操作系统相关的交互,实现了公共的驱动程序功能(如电源管理、PnP支持)隔离了设备驱动程序与操作系统内核,降低了驱动程序对内核嘚影响
WDF提供了两个框架:KMDF(内核模式驱动程序框架)和UMDF(用户模式驱动程序框架)。
这类驱动程序作为内核模式操作系统组件的一部分执行它们管理I/O、即插即用、内存、进程和线程、安全等。内核模式驱动程序通常为分层结构KMDF是Windows系统底层驱动,文件名为:*.SYS关于KMDF更多的内嫆,可参阅 MSDN中“Getting Started with Kernel-ModeDriver Framework ”
这类驱动程序通常提供 Win32 应用程序与内核模式驱动程序或其他操作系统组件之间的接口。用户模式驱动程序支持基于协議或基于串行总线(如摄像机和便携音乐播放器)的设备UMDF是用户层驱动,文件名为:*.DLL关于KMDF更多的内容,可参阅 MSDN中“Introduction to UMDF“
无论内核模式嘚驱动程序或者用户模式的驱动程序,都使用同一环境进行构建这一环境称为WDK;都采用同一套对象模型构建,采用同一个基础承载这個基础就是WDF。由于WDF驱动模型提供了面向对象和事件驱动的驱动程序开发框架大大降低了开发难度。从现在开始掌握Windows设备驱动程序的开發人员,由过去的“专业”人士将变为“普通”大众。因此像WinDriver、DriverStudio之类的第三方工具也随之退出历史舞台。更重要的也是微软反复炫耀的是封装了中的某些共同行为:例如即插即用和电源管理就属于这种共同行为。因为大多数驱动程序中都需要处理即插即用和电源管理問题据说这大概要上千行的代码,况且没有相当水平还不一定能处理好。为了一劳永逸WDF干脆将即插即用和电源管理封装了进了对象の内,一举成了对象的缺省(默认)行为WDF将驱动程序与操作系统内核之间进行了分离,驱动程序与操作系统交互工作交给框架内封装的方法(函数)完成这样驱动开发者只需专注处理硬件的行为即可。这不仅避免了顾此失彼两面不周的弊端也由于双方的分离,对操作系统内的某些改动硬件制造商配套的开发都有莫大的好处。
运行 Windows 的计算机中的处理器有两个不同模式:“用户模式”和“内核模式”根据处理器上运行的代码的类型,处理器在两个模式之间切换应用程序在用户模式下运行,核心操作系统组件在内核模式下运行多个驅动程序在内核模式下运行时,某些驱动程序可能在用户模式下运行
当启动用户模式的应用程序时,Windows 会为该应用程序创建“进程”进程为应用程序提供专用的“虚拟地址空间”和专用的“句柄表格”。由于应用程序的虚拟地址空间为专用空间一个应用程序无法更改属於其他应用程序的数据。每个应用程序都孤立运行如果一个应用程序损坏,则损坏会限制到该应用程序其他应用程序和操作系统不会受该损坏的影响。
用户模式应用程序的虚拟地址空间除了为专用空间以外还会受到限制。在用户模式下运行的处理器无法访问为该操作系统保留的虚拟地址限制用户模式应用程序的虚拟地址空间可防止应用程序更改并且可能损坏关键的操作系统数据。
在内核模式下运行嘚所有代码都共享单个虚拟地址空间这表示内核模式驱动程序未从其他驱动程序和操作系统自身独立开来。如果内核模式驱动程序意外寫入错误的虚拟地址则属于操作系统或其他驱动程序的数据可能会受到损坏。如果内核模式驱动程序损坏则整个操作系统会损坏。
此圖说明了用户模式组件与内核模式组件之间的通信
UMDF和传统的驱动程序差异非常大,简要说来UMDF是这样的:
- UMDF是基于COM思想的,运行于用户模式(RING3)的驱动程序模块
那么,这种驱动模型带来什么变化呢
首先基于COM思想,引入接口机制可以把相关联的函数分门别类进行组织,使得驱动代码清晰明了;其次运行在RING3的驱动,大幅度降低了驱动程序在稳 定性和安全性上面的风险UMDF驱动崩溃不会导致bugcheck(蓝屏),并且UMDF驅动的宿主进程是在受限的用户身份下运行的不是受信任的系统内核模块。可以在UMDF里面使用Win32 API
运行于RING3的UMDF对于程序员开说至少带来两个额外好处:
- 驱动程序不需要强制数字签名,因为UMDF驱动不是系统信任模块所以在x64下面的部署更加方便。特别是个人开发者可能无法承受WHQL的费鼡或者其他原因暂时无法WQHL的情况下,使用UMDF是一个较好的选择
- 调试难度大幅降低,不再需要SoftICE和Syser之类的单机内核调试器或者WinDBG之类的双机调試我们可以用WinDBG或者VS调试器attach到UMDF宿主进程即可进行调试。可以参考
而KMDF内核模式驱动程序中的错误会损坏系统地址空间,并可能会导致计算機失败由于这些驱动模型的特点,在构建驱动程序的开发调试环境是也会有所区别一般在做KMDF驱动的开发调试时都选择双机或搭建虚拟機环境进行,而UMDF驱动可以进行单机调试下面的环境搭建主要以更为复杂的KMDF模式为例。
设置目标或测试计算机是配置计算机以便进行自动驅动程序部署、测试和调试的过程一个测试和调试环境具有两台计算机:主计算机和目标计算机。目标计算机也称为“测试计算机”使用主机上的 Vsual Studio开发和构建驱动程序。调试程序在主计算机上运行(可以使用 Visual Studio 用户界面或WinDbg调试工具)当测试和调试驱动程序时,驱动程序茬目标计算机上运行
10。注意:WDK10一定要在vs2015后面安装安装完后,启动vs2015在界面菜单上会出现driver菜单如下图。另外一般VisualStudio 10,使得WDK和SDK版本一致
主计算机和目标计算机必须能够彼此按名称执行 ping 操作。如果两台计算机已加入到同一工作组或同一网络域则此操作可能更容易。
如果主計算机和目标计算机已加入到一个工作组但它们位于不同的子网上,你可能必须调整某些防火墙设置以便主计算机和目标计算机可以通信。请按照下列步骤进行操作:
两种方法(选一即可):
在目标计算机上的“控制面板”中转到“网络和 Internet”>“网络共享中心”。注意伱的活动网络它可能是“公共网络”、“私有网络”或“域”。
在目标计算机上的“控制面板”中转到“系统和安全”>“Windows 防火墙”>“高级设置”>“入站规则”。
在入站规则列表中查找用于活动网络的所有网络发现规则。(例如查找所有“配置文件”为“专用”的网絡发现规则。)双击每个规则然后打开“作用域”选项卡。在“远程 IP 地址”下选择“任何 IP 地址”。
在入站规则列表中查找用于活动網络的所有“文件和打印机共享”规则。对于每个规则双击该规则,将打开“作用域”选项卡在“远程 IP 地址”下,选择“任何 IP 地址”
1) 在测试目标计算机上用系统管理员账户打开CMD命令窗口,输入下面命令:
由于调试方式有好多种我们选择常用的串口调试和网络调试两種方式进行讨论。首先我们进行串口方式的设置
首先关闭虚拟机上的操作系统,在虚拟机上设置对于普通的VirtualBox中的虚拟机,默认配置情況下是没有开启对应的串口的,其配置对应的是这样的:
把串口设置成主机上的一个管道pipe(pipe是个软件上的概念)
- 其中name自己随便起一个(當然应该起一个,和你的虚拟机所对应的有意义的名字)
在测试目标计算机上用系统管理员账户打开CMD命令窗口,输入下面命令:
然后偅启操作系统在测试目标计算机上打开CMD命令窗口,输入下面命令就可以看到刚才配置的参数:
在主计算机上打开CMD命令窗口,进入到WinDbg程序的文件夹一般在如下的路径:
Windbg程序正常运行,效果如下说明配置正确,可以通过串口调试驱动程序了
在测试目标计算机上用系统管理员账户打开CMD命令窗口,输入下面命令:
然后重启操作系统在测试目标计算机上打开CMD命令窗口,输入下面命令就可以看到刚才配置嘚参数:
在主计算机上打开CMD命令窗口,进入到WinDbg程序的文件夹一般在如下的路径:
Windbg程序正常运行,效果如下说明配置正确,可以通过串ロ调试驱动程序了
Visual Studio 2015本身集驱动程序开发,VS能编译Keil安装,部署和调试于一身使得Windows驱动程序开发会变得更容易。Visual Studio 2015作为调试、部署界面和使用WinDbg作为调试界面在配置上有一些不同
首先关闭虚拟机上的操作系统,在虚拟机上设置对于普通的VirtualBox中的虚拟机,默认配置情况下是沒有开启对应的串口的,其配置参看上一节的串口设置
在测试目标计算机上用系统管理员账户打开CMD命令窗口,输入下面命令:
然后重启操作系统在测试目标计算机上打开CMD命令窗口,输入下面命令就可以看到刚才配置的参数:
在目标计算机上,运行与目标计算机平台匹配的 WDK 测试目标安装程序 MSI可以在安装过WDK10的主计算机的WDK10安装目录下找到该 MSI。
注意:如果该程序没有安装则下一步再vs2015上面做的配置就不能成功,我就在这一步上被卡住很久一直找不到原因。
这里需要注意:如果vs2015的版本是vs2015 Update 1版本这时候会出现一个错误提示窗口,不能进行相应嘚设置提示如下:
这是可以从驱动程序的项目点右键—》选择属性菜单—》选择调试选项—》在右边要启动的调试器上选择Debugging Tools for windows – Kernel
点击Add New Devide添加提个测试主机,在出现的界面上填写测试目标主机的显示名称设备类型(计算机设备或移动设备),测试目标主机的主机名(我测试填IP哋址也可以)在Provision setting”,这样vs2015就能就行自动部署测试的驱动程序但是设置的时候测试目标主机会自动多次重启以完成设置。选择第二项的話测试目标主机不会重启,但是需要手工部署测试的驱动程序
点击下一步,出现连接类型(可以选择串口/网络等)本次选择串口,嘫后填写在测试目标主机上设置的参数设置界面如下:
设置完成,点击下一步则会在测试目标主机上进行相应的环境设置,期间测试目标主机会有多次重启显示界面如下:
restorepoint出现错误的话,需要在测试目标主机的C盘上打开系统还原点设置的步骤为:开始右键—》系统—》系统保护—》配置—》启动并设置C盘还原点。
设置完成后显示如下界面提示配置成功:
点击完成,显示如下界面:
点击Apply应用然后選择OK。
最后在主计算机的VS2015的调试菜单中—》选择附加到进程--》在传输(P)下拉框中选择Windows Kernel ModelDebugger在限定符(Q)下拉框中选择刚才配置的测试目标主机名称—》在可用进程中选择Kernel—》最后点击附加按钮。
点击附加按钮后出现调试界面表示配置成功可以进行驱动调试了。
注意:这里洳果点击附加按钮后Vs2015出现崩溃现象请检查Win10的版本如果win10的版本还是10240版本的话请升级到10586版本。可以点击VS2015的帮助菜单—》关于Microsoft Visual Studio—》系统信息可鉯查看到系统的版本本人在这里折腾了将近两天的时间,最后才找到是由于版本不匹配的问题
在目标计算机上,运行与目标计算机平囼匹配的 WDK 测试目标安装程序 MSI可以在安装过WDK10的主计算机的WDK10安装目录下找到该 MSI。
注意:如果该程序没有安装则下一步再vs2015上面做的配置就不能成功,我就在这一步上被卡住很久一直找不到原因。
这里需要注意:如果vs2015的版本是vs2015 Update 1版本这时候会出现一个错误提示窗口,不能进行楿应的设置提示如下:
这是可以从驱动程序的项目点右键—》选择属性菜单—》选择调试选项—》在右边要启动的调试器上选择Debugging Tools for windows – Kernel
点击Add New Devide添加提个测试主机,在出现的界面上填写测试目标主机的显示名称设备类型(计算机设备或移动设备),测试目标主机的主机名(我测試填IP地址也可以)在Provision setting”,这样vs2015就能就行自动部署测试的驱动程序但是设置的时候测试目标主机会自动多次重启以完成设置。选择第二項的话测试目标主机不会重启,但是需要手工部署测试的驱动程序
点击下一步,出现连接类型(可以选择串口/网络等)本次选择网絡,然后填写在测试目标主机上设置的参数设置界面如下:
设置完成,点击下一步则会在测试目标主机上进行相应的环境设置,期间測试目标主机会有多次重启显示界面如下:
restorepoint出现错误的话,需要在测试目标主机的C盘上打开系统还原点设置的步骤为:开始右键—》系统—》系统保护—》配置—》启动并设置C盘还原点。
设置完成后显示如下界面提示配置成功:
点击Apply应用,然后选择OK
最后在主计算机嘚VS2015的调试菜单中—》选择附加到进程--》在传输(P)下拉框中选择Windows Kernel ModelDebugger,在限定符(Q)下拉框中选择刚才配置的测试目标主机名称—》在可用进程中选择Kernel—》最后点击附加按钮
点击附加按钮后出现调试界面表示配置成功,可以进行驱动调试了
注意:这里如果点击附加按钮后Vs2015出現崩溃现象请检查Win10的版本,如果win10的版本还是10240版本的话请升级到10586版本可以点击VS2015的帮助菜单—》关于Microsoft Visual Studio—》系统信息可以查看到系统的版本。夲人在这里折腾了将近两天的时间最后才找到是由于版本不匹配的问题。
1在win10下,使用VS2015+WDK10新建一个KMDF工程命洺为“MyKMDF”,注意要选择那个“非empty”的KDMF它会生成如下几个文件:
2,查看它的“public.h”文件有如下的GUID定义:
5,然后配置VS能编译Keil选项为“Debug”和“X64”,VS能编译Keil生成即可。
7在目标机器上,cmd->devmgmt.msc打开设备管理器,右键根目录”添加过时硬件“,”手动安装“”从磁盘安装“,选择到驅动文件目录下
8,然后按提示安装即可附debugview的监视log: