WIN10 + VS2015 + WDK10 + SDK10 + VM虚拟机驱动开发调试环境搭建

1、准备工做

1 系统环境:Win10系统

2 开发工具:VS2015

3 驱动开发工具:WDK10

 Windows SDK :SDK10(VS2015中能够勾选安装)

5 VM虚拟机     : VMware WorkStation 12



win10 64位下驱动安装工具下载地址(此工具只在上述环境下测试过,请在虚拟机中测试过再在真实环境下安装不然蓝屏本身负责)



注意事项:
关闭 、主机 客户机 防火墙 、 互相ping都能ping通。


2、具体操做步骤


工具安装就不说了,不会的百度一下。只说一下一些关键的地方
 

一、安装好虚拟机后,给虚拟机增长一个串口设备。具体操做见图:






完成配置后虚拟机设备配置就多了一个串行端口的设备。由于打印机用了端口1。因此设备里面显示的是串行端口(若是想设置成端口1,把打印机设备删了在添加串口设备)。

二、配置虚拟机系统为调试模式


     以管理员身份,在虚拟机命令行模式下运行以下2个命令开启。

     bcdedit /debug on
      bcdedit /dbgsettings serial debugport:n baudrate:115200

      where  n  is the number of a COM port on the virtual machine.(n时虚拟机的一个COM端口号。就是设备显示的串行端口2,n就是端口2)。


三、把WDK10的虚拟机调试驱动拷贝到虚拟机中安装。






由于VS2015能够调试x86 x64两种驱动因此两个都拷贝到虚拟机安装。

四、VS2015开发工具配置

在VS2015的菜单栏点击DRIVER--TEST--CONFIGURE DEVICES会报错估计是VS2015的Bug求大神指点。如图

 


这里不行咱们换个地方配置,从工程属性里面进行配置。右键工程属性配置从这也能够进行测试设备的配置:安全



配置界面,下面两个选项第一项由VS2015帮咱们建立一个WDKuser测试帐户,自动打开测试模式等。第二个是使用咱们本身配置的参数。因为上面咱们已经配置了串口参数 、设置了调试模式因此咱们选择第二个就好了。ide



以下配置在内核模式中,选择串口、配置好波特率、勾上2个选项、管道名称、端口号。函数




出现上述红色框字样则说明配置已经成功了。(不要开启全局代理软件,不然会出现链接不上的问题)。工具



五、使用工具安装调试64位驱动

网上下的下面的驱动安装软件貌似64位的都用不了。开发工具



本身动手丰衣足食大笑,本身在网上弄了个源码改了下弄成能够加载64位的驱动的版本了。测试



使用DebugView打印内核调试信息是开发驱动的很是重要的手段,但DebugView默认在WINDOWS 10下却没法获取内核的调试日志,驱动调用KdPint/DbgPrint等的打印结果是没法被DebugView给捕捉到的。设置方法以下(复制下面的代码到txt文件。改后缀为.reg后执行,而后重启电脑):spa

 

[cpp]  view plain  copy
 
  在CODE上查看代码片 派生到个人代码片
  1. Windows Registry Editor Version 5.00  
  2.   
  3. [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Debug Print Filter]  
  4. "DEFAULT"=dword:0000000f  

 


还有本身编译出来的驱动要使用编译的Debug版原本测试,Release版本是不会执行KdPrint/DbgPint函数的。.net

下面是在Win10 64位的虚拟机中用此安装程序,加载64位的驱动以及用DebugView查看驱动打印消息的截图结果。命令行



六、在VS2015中下断点进行调试

若是你第五部已经完成了,而且在DebugView中已经可以输出调试的打印信息了,辣么骚年你已经离成功只有一部之遥了大笑debug


建立一个驱动工程,WDK10提供的模板中根本没有提供NT驱动模板,咱们如何建立NT驱动呢?
解决:其实虽然没有提供NT模板,可是咱们能够创建WDM空模板工程,而后再本身添加文件,编译,获得的也就是NT驱动了。


驱动工程中会帮你创建一个inf文件,NT是使用不到的,能够直接删除。咱们直接添加一个MyDriver.c

在文件中添加测试代码。

 

[cpp]  view plain  copy
 
  在CODE上查看代码片 派生到个人代码片
  1. #include <ntifs.h>   
  2.   
  3. VOID DriverUnload(PDRIVER_OBJECT objDriver)  
  4. {  
  5.     // 避免编译器关于未引用参数的警告  
  6.     UNREFERENCED_PARAMETER(objDriver);  
  7.   
  8.     // 什么也不作,只打印一行字符串  
  9.     KdPrint(("My Dirver is Ending..."));  
  10. }  
  11.   
  12. NTSTATUS DriverEntry(PDRIVER_OBJECT objDriver, PUNICODE_STRING strRegPath)  
  13. {  
  14.     // 避免编译器关于未引用参数的警告  
  15.     UNREFERENCED_PARAMETER(strRegPath);  
  16.   
  17.     // 打印一行字符串,并注册驱动卸载函数,以便于驱动卸载  
  18.     KdPrint(("My  Dirver Is Starting!\r\n"));  
  19.   
  20.     objDriver->DriverUnload = DriverUnload;  
  21.   
  22.     return STATUS_SUCCESS;  
  23. }  


编译,报错,没有关系,这些都是由于安全警告等级过高了,咱们能够下降编译器警告等级的方式解决:

 



执行编译,编译的时候选择Debug模式,X64的选项。编译成功后,按照上面的第五步进行基本测试能够。


不知不觉感受已经写了好长了。。。。奋斗抽口烟压压精。好吧我不抽烟的。。。。。继续
若是上述的驱动成功编译出来了。辣么如今咱们开始附加虚拟机的内核进行调试了。
首先把虚拟机的系统内核附加到VS2015,具体步骤见下图:


选中内核调试模式、选本身配置的那个电脑、选中下面列表中内核。见下图


点击附加,而后出现下图界面,点击一下所有中断。


而后系统就断下了,虚拟机的系统咱们鼠标已经点不了,如今系统处于挂起状态了。见下图


如今咱们能够到源代码中下断点了。我就随便下个断点了,见图:


而后咱们在下面的Debugger Immediate Winddow窗口的 Kd>  一行输入命令   g     让系统运行起来。这样虚拟机中的系统又能够点击了。

最后一步了。使用咱们刚刚创建的驱动工程编译出来的.sys驱动文件拷贝到虚拟机中。用第五步的工具进行安装、启动。启动的时候自动触发VS2015中的下的断点。至此能够像平时咱们调试程序同样进行单步调试了。
注意事项:一、必定要拷贝Debug版本的进行调试。
                  二、拷贝到虚拟机中的.sys文件必定要是你源码编译出来的。若是改动了源码后必定要从新拷贝一份新的驱动文件到虚拟机中调试。不然没法触发断点的。


3、结束语

       本人也是刚开始研究驱动开发,上述若是有什么不对的请你们指点、共同交流。至此整个调试过程已经结束。能够开始过游戏驱动保护开发了。感谢你们支持。。。。大笑

原文地址: http://blog.csdn.net/qing666888/article/details/50858272
相关文章
相关标签/搜索