为什么80%的码农都做不了架构师?>>>   

一、准备工作

1 系统环境:Win10系统

2 开发工具:VS2015

3 驱动开发工具:WDK10

4 Windows SDK:SDK10(安装的时候必须全部勾选安装,否则编译会出现缺少waring.h等头文件之类的错误)

5 VM虚拟机:VMware WorkStation 12

Win10、WDK10、SDK10的版本必须一致我的用的都是15063版本。

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

http://download.csdn.net/detail/qing666888/9468506

注意事项:

关闭 、主机 客户机 防火墙 、 互相ping都能ping通。

二、具体操作步骤

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

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

上面的\\.\pipe\com_1可以改\\.\pipe\com_2,我就不改了后面名字可以随便取的,完成配置后虚拟机设备配置就多了一个串行端口的设备。因为打印机用了端口1。所以设备里面显示的是串行端口2,重新启动虚拟机系统后,会发现设备管理里面多了一个COM2的串口设备(如果想设置成端口1,把打印机设备删了在添加串口设备)。

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

以管理员身份,在虚拟机命令行模式下运行如下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)。

我们使用下面的语句即可:

      bcdedit /debug on

      bcdedit /dbgsettings serial debugport:2 baudrate:115200

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

因为VS2015可以调试x86 x64两种驱动,根据被调试系统选择不同的文件拷贝到虚拟机安装,我的是64位的选择x64

4、VS2015开发工具配置

在VS2015的菜单栏点击DRIVER--TEST--CONFIGURE DEVICES,选择增加新设备,如下图:

或者换个地方配置,从工程属性里面进行配置。右键工程属性配置从这也可以进行测试设备的配置:

配置界面,下面两个选项第一项由VS2015帮我们创建一个WDKuser测试账户,自动打开测试模式等。第二个是使用我们自己配置的参数。由于上面我们已经配置了串口参数 、设置了调试模式所以我们选择第二个就行了。

如下配置在内核模式中,选择串口、配置好波特率、勾上2个选项、管道名称、端口号(我们上面配置的COM2)。

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

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

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

自己动手丰衣足食,自己在网上弄了个源码改了下弄成可以加载64位的驱动的版本了。

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

[cpp] view plain copy

  1. Windows Registry Editor Version 5.00
  2. [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Debug Print Filter]
  3. "DEFAULT"=dword:0000000f

2)还有自己编译出来的驱动要使用编译的Debug版本来测试,使用KdPrint打印需要显示的调试信息。下面是在Win10 64位的虚拟机中用此安装程序,加载64位的驱动以及用DebugView查看驱动打印消息的截图结果。DebugView中需要勾选Capture Kernel选项。

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

如果你第五部已经完成了,并且在DebugView中已经能够输出调试的打印信息了,辣么骚年你已经离成功只有一部之遥了

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

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

在文件中添加测试代码。

[cpp] view plain copy

  1. #include <ntifs.h>
  2. VOID DriverUnload(PDRIVER_OBJECT objDriver)
  3. {
  4. // 避免编译器关于未引用参数的警告
  5. UNREFERENCED_PARAMETER(objDriver);
  6. // 什么也不做,只打印一行字符串
  7. KdPrint(("My Dirver is Ending..."));
  8. }
  9. NTSTATUS DriverEntry(PDRIVER_OBJECT objDriver, PUNICODE_STRING strRegPath)
  10. {
  11. // 避免编译器关于未引用参数的警告
  12. UNREFERENCED_PARAMETER(strRegPath);
  13. // 打印一行字符串,并注册驱动卸载函数,以便于驱动卸载
  14. KdPrint(("My  Dirver Is Starting!\r\n"));
  15. objDriver->DriverUnload = DriverUnload;
  16. return STATUS_SUCCESS;
  17. }

编译,报错,没有关系,这些都是因为安全警告等级太高了,我们可以降低编译器警告等级的方式解决:

执行编译,编译的时候选择Debug模式,选择X64的选项(因为我们的虚拟机使用的是64位的系统,不能够运行x86的驱动,如果你编译出来的是x86的驱动,用上的工具安装是可以,但是启动失败提示阻止运行之类的)。编译成功后,按照上面的第五步进行安装测试。

不知不觉感觉已经写了好长了。。。。抽口烟压压精。好吧我不抽烟的。。。。。继续。如果上述的驱动成功编译出来了。辣么现在我们开始附加虚拟机的内核进行调试了。

首先把虚拟机的系统内核附加到VS2015,具体步骤见下图:

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

点击附加,然后出现下图界面,点击一下全部中断。

然后系统就断下了,虚拟机的系统我们鼠标已经点不了,现在系统处于挂起状态了。见下图

现在我们可以到源代码中下断点了。我就随便下个断点了,见图:

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

最后一步了。使用我们刚刚建立的驱动工程编译出来的.sys驱动文件拷贝到虚拟机中。用第五步的工具进行安装、启动。启动的时候自动触发VS2015中的下的断点。至此可以像平时我们调试程序一样进行单步调试了。

注意事项:1、一定要拷贝Debug版本的进行调试。

2、拷贝到虚拟机中的.sys文件一定要是你源码编译出来的。

3、如果改动了源码后一定要重新拷贝一份新的驱动文件到虚拟机中调试,否则无法触发断点的。

三、关于驱动签名

增加一点关于驱动签名的吧,有很多小伙伴编译成功后,驱动安装的时候一直弹出下面的这个图片,驱动没有签名被系统阻止安装,解决方案百度上面说的基本是每次开机都进入启动设置中----禁用驱动签名强制、bcdedit  nointegritychecks on 或者 loadoptions DDISABLE_INTEGRITY_CHECKS等。这些方法都是以前的方法基本都没什么用了。

下面提供两个可用方法:

1)使用过期签名(下载个过期签名给驱动签上,把系统时间改到签名有效期内)。签名有版权问题东西就不提供了,自己到看雪能搜到。

2)使用UPGDSED(可以同时关闭PathGuard跟驱动强制签名)使用说明见下:

下载地址:https://github.com/hfiref0x/UPGDSED

管理员权限运行patch.exe,按照提示输入大写的CONTINUE按回车确认,patch完成后输入Enter退出,重启系统用另外一个启动项启动系统。本人在windows10 企业版(15063)测试成功,可以不开启测试签名模式下加载64位驱动。

四、结束语

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

转载于:https://my.oschina.net/u/1777508/blog/1827909

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

  1. linux设备驱动开发之环境搭建(基于exynos4412)

    第一章 linux设备驱动开发之环境搭建(基于exynos4412) 目录 第一章 linux设备驱动开发之环境搭建(基于exynos4412) 1.搭建开发板运行环境 1.1.交叉开发模式 安装交叉 ...

  2. auto.js id为参数滑动_【Autojs教程】02Autojs PC端开发调试环境搭建

    [Autojs教程]02-Autojs PC端开发调试环境搭建 写在前面 本篇教程算是保姆级教程了,希望以此能吸引更多感兴趣的同学学习Autojs,也希望大家能因此碰撞出更多的奇思妙想 关注微信公众号 ...

  3. JZ2440驱动开发之环境搭建

    作为Linux驱动开发的小白搭建整个开发环境是至关重要的一步,鄙人是从裸机程序直接跳转到驱动里面来的,裸机到驱动的衔接没怎么看,所以在刚开始驱动的时候搭环境遇到了大麻烦,不过还是在坚持中挺过来了,还得 ...

  4. 基于Kubernetes1.20.1版本开发调试环境搭建

    接下来的一段时间将要学习Kubernetes源码,为了更好的查看源码和调试程序,因此搭建了一个Kubernetes开发调试环境,该环境可以结合断点调试理解代码的运行过程. 准备虚拟机并安装必要软件 $ ...

  5. vs安装 c语言编译环境,Visual Studio Code安装与C/C++开发调试环境搭建

    目录 简介 VSCode安装 VSCode语言设置 安装开发套件 构建C/C++编译环境 安装Clang 安装MinGW VSCode工程配置 launch.json tasks.json 测试 简介 ...

  6. Window XP驱动开发(二) 环境搭建(VS2008+WDK+DDKWzard)及示例源码分析

    郁闷,做了WCE嵌入式驱动这么久还没热身够,又被调到做window xp下的驱动开发.没办法.只能受令了. 现在就开始自己的学习之旅吧. 转载请标明是引用于 http://blog.csdn.net/ ...

  7. Clion远程Linux开发调试环境搭建

    在我以前的文章中介绍了如何使用QT搭建Linux开发环境                                ​​​​​​​        ​​​​​​​        ​​​​​​​    ...

  8. Rust开发调试环境搭建Windows

    Rust Windows环境搭建 2019年02月18日 13:48:31 6日Simmp 阅读数 1672 该文章主要讲述在windows10+vscode下如何构建一个完整的rust编译调试环境, ...

  9. stm32运行java虚拟机_windows下的基于Eclipse的STM32开发调试环境搭建

    这段时间在玩STM32,但官方库的代码也确实是有点多,记忆力有点不太好了.突然就想起了以前用Eclipse的那个代码提示功能,谷歌了一段时间, (一)安装编译环境 1.下载和安装JAVA虚拟机 因为E ...

最新文章

  1. 全网最全数据分析师干货-python篇
  2. cba篮球暂停次数和时间_中国篮球即将来袭!202021赛季CBA赛程时间表
  3. BUUCTF-misc另外一个世界 8个二进制数为一组转ASC码
  4. extern c用法解析
  5. 深入理解计算机系统学后感,深入理解计算机系统(读书笔记)
  6. Pod详解-生命周期-概述
  7. HDU5187 zhx#39;s contest(计数问题)
  8. 回顾2009,展望2010
  9. 怎样才能成为优秀的前端工程师
  10. session的简单理解和使用
  11. Fedora 25-64位操作系统中安装配置Hyperledger Fabric过程
  12. actionSupport类
  13. Win10镜像安装pytorch-gpu版
  14. 金蝶K3老单据下推老单据并修改字段名(以销售订单下推销售出库单为例,后台操作部分)
  15. 【C语言】指针的算术运算
  16. TCP BBR - 一键安装最新内核并开启 TCP BBR
  17. 电脑怎么装linux系统
  18. 微软官网方法制作win10u盘启动
  19. 中国LVDT RVDT传感器市场现状研究分析与发展前景预测报告(2022)
  20. Spring + SpringMVC + Hibernate + Shiro整合

热门文章

  1. 富士康遭黑客巨额勒索 企业如何应对数据安全风险?
  2. 如何把gcc编译工具使用到linux全局
  3. re模块与正则表达式
  4. [译] Swift 中的惰性序列及其原理
  5. JFreeChart_API
  6. 1月份制造业和非制造业PMI双双回升 企稳迹象初显
  7. 快速指南:在DevOps中实现持续交付
  8. .net项目发布到本地IIS
  9. ibatis查询SQL语句返回一个对象,此对象包含一个List属性
  10. linux下mysql root密码忘记修改方法