惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Help Net Security
Help Net Security
G
Google Developers Blog
雷峰网
雷峰网
WordPress大学
WordPress大学
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
Engineering at Meta
Engineering at Meta
Security Latest
Security Latest
T
Threat Research - Cisco Blogs
AWS News Blog
AWS News Blog
F
Full Disclosure
C
Cybersecurity and Infrastructure Security Agency CISA
T
The Exploit Database - CXSecurity.com
J
Java Code Geeks
U
Unit 42
C
Cyber Attacks, Cyber Crime and Cyber Security
V
V2EX
C
Cisco Blogs
博客园 - 司徒正美
Project Zero
Project Zero
L
LINUX DO - 热门话题
阮一峰的网络日志
阮一峰的网络日志
Blog — PlanetScale
Blog — PlanetScale
Scott Helme
Scott Helme
A
About on SuperTechFans
Hugging Face - Blog
Hugging Face - Blog
S
Securelist
小众软件
小众软件
aimingoo的专栏
aimingoo的专栏
S
Schneier on Security
G
GRAHAM CLULEY
酷 壳 – CoolShell
酷 壳 – CoolShell
Cyberwarzone
Cyberwarzone
MongoDB | Blog
MongoDB | Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
博客园 - 叶小钗
T
Threatpost
Recorded Future
Recorded Future
C
CXSECURITY Database RSS Feed - CXSecurity.com
宝玉的分享
宝玉的分享
N
News and Events Feed by Topic
人人都是产品经理
人人都是产品经理
The Register - Security
The Register - Security
S
Security Archives - TechRepublic
博客园 - Franky
N
News | PayPal Newsroom
Simon Willison's Weblog
Simon Willison's Weblog
S
SegmentFault 最新的问题
W
WeLiveSecurity
A
Arctic Wolf
B
Blog

博客园 - 夜来风雨香

【整理】C#文件操作大全(SamWang)<转> c# 文件及目录操作类 BIOS设置之UEFI/Legacy BIOS切换图文详解 UEFI+GPT引导实践篇(一):切换到UEFI启动,准备安装介质 UEFI+GPT引导实践篇(二):UEFI引导安装64位Win7/Win8 UEFI+GPT引导基础篇(一):什么是GPT,什么是UEFI? 预装WIN8系统的电脑安装WIN7的方法 串口 COM口 TTL RS-232 RS-485 区别 释疑 DataGridView导出到Excel的三个方法 WinForm DataGridView分页功能 C#GridViewExport帮助类,美化导出 C#EXCEL 操作类--C#DataToExcel帮助类 C#EXCEL 操作类--C#ExcelHelper操作类 VS2010 项目引用了DLL文件,也写了Using,但是编译时提示:未能找到类型或命名空间名称 <转> FPGA Verilog HDL 系列实例--------步进电机驱动控制 C++使用VARIANT实现二维数组的操作 USB编程研究之二(常见设备类型的GUID) C++——CString用法大全 C++ 如何有效地使用对话框
VS2010+VMWare8+VisualDDK1.5.6 创建并调试你的第一个驱动程序 - 完全教程
夜来风雨香 · 2014-04-18 · via 博客园 - 夜来风雨香

本文描述了如何使用Visual Studio+VMMare+VisualDDK来创建、编译和调试你的第一个驱动程序。本文提供在开发和调试工具的环境下详细的操作步骤,而无需太多的关心这些环境背后所做的事情。如果你想学习更多驱动程序开发的API,可以参考 Online WDK help

本教程我们会创建以下驱动测序并且在虚拟机上测试它:

  • 一个超级简单的驱动,加载时打印一条信息

如果你有另外一台实体机,你就不用安装虚拟机了。不过,你可能需要COM连接或者一个火线连接两台机子。

必备软件

开始写驱动之前,你需要准备一些软件(点击超链接直接下载)。

  • VMWare,虚拟机软件,用于运行用于调试的虚拟机。
  • Windows安装镜像,用来给虚拟机装系统。建议使用XP或Windows7(如果你内存大一点,建议Windows7)。要是没有你可以找人拷或者到msdn.itellyou.cn下载
  • Visual Studio 2010,用来写代码
  • Windows Driver Kit (WDK) 7.1.0,用于Windows驱动开发的工具包
  • VisualDDK,将WDK和VS结合配置好的一个可视化VS插件

如果你不知道ISO镜像怎么使用,下载一个UltraISO然后去找下相关用法。

准备工作

  • 第一步是安装虚拟机软件。这个过程很简单,只需要按照步骤一步一步来。
  • 然后是创建一个虚拟机,以VMWare Workstation 8为例。

  • 在虚拟机上安装支持软件并创建快照。

  • 安装Visual Studio 2010,装过了就跳过。不过要注意的是,你的VS要至少包括C++和C#两个模块,如果不全,请重新安装。
  • 安装VAX(可选)。VAX只是要来方便你写C++代码的。

  • 安装Windows Driver Kit(WDK)。

    • 用UltraISO加载WDK的镜像。(下文H: 表示虚拟光驱的盘符)
    • 选择要安装的功能,建议配置如下:
    • 安装目录就选择默认目录,改了的话你自己记住在哪儿。
    • 然后就开始安装了

  • 安装32位的Windows调试工具(DDK)。

    • 在WDK的ISO目录底下找到H:\Debuggers\setup_x86.exe开始安装。完全安装即可。(Visual Studio是一个32位的软件,所以不能使用64位的调试工具)。

  • 安装和配置VisualDDK

  • 配置虚拟机

    • 网络配置。依次选择菜单VM-Settings,打开配置页。选择Network Adapter,将配置改为Bridge或者NAT。

      然后测试你的网络连接,主机ping虚拟机,虚拟机ping主机应该能互通。

    • 复制 C:\Program Files (x86)\VisualDDK\target\vminstall.exe 到虚拟机上运行(如果正确安装了VMTools,可以直接复制粘贴的,如果不行,重新安装VMTools或使用VMWare 的网络功能拷贝该文件)。

    • 点击安装,提示重启(虚拟机),点是就可以了。重启后,关闭虚拟机(没错,关掉它)。

使用向导创建驱动

  1. 以管理员权限运行Visual Studio(右击-以管理员权限运行)

  2. 点击文件-新建-项目,打开新建项目向导,选择C++下的VisualDDK,

    注意:项目位置不可以包含空格,不可以包含中文,否则你会很悲剧(无法生成解决方案)

  3. 选择一个Pnp的驱动,其他配置默认

  1. 现在打开你的源代码,看到的应该是以下效果

  2. 生成解决方案。选择菜单生成-生成解决方案。

    如果没有错误,证明生成成功了。生成成功后,你可以右击项目,点击"在Windows资源管理器中打开文件夹",进入生成目录(如objchk_win7_x86\i386)可以看到成功生成的sys驱动文件。

  3. 如果不需要调试,运行该sys文件就可以使用驱动了(安装方式你得自己研究)。下面介绍调试的方法(调试会自动帮你安装驱动程序)。

调试你的驱动

  1. 运行VisualDDK安装目录下的vmmon.exe或vmmon64.exe(如果你是64位系统)。当然,你也可以在开始菜单处搜索到这两个程序。

  2. 这时候启动虚拟机,不要进入系统,停在操作系统选择菜单上!此时你的VMMonitor和虚拟机画面应该是这样的:

    注意,这步至关重要,如果你看到的PID字段上那个图标不是绿色的,或者说Pipe name没有建立出来,将不能进行内核调试。这个步骤我搞了n久找到了解决方案。如果你有这样的问题,你可以这么做:

  • 进入目录"%USERPROFILE%\AppData\Roaming\VirtualKD"

  • 将里面的*.vmpatch文件删除

  • 重试上面的步骤
  1. VS中选择菜单调试-Driver Launch Settings…

  • 首次调试,会提示你配置Visual DDK(这个操作你也可以通过菜单工具-VisualDDK Settings…进行)

    选择好你的调试工具的目录(如上,需要32位的调试工具)和符号目录(调试符号,到时候会自动下载到该目录)

  • 设置好VisualDDK后,应该会弹出调试设置对话框

    选择Virtual Machine的调试方式,此时,应该可以选择已经加载管道的虚拟机了。其他使用默认配置(如果你手动指定了虚拟机的IP,最好再这里填写),配置好之后,点Launch。

  1. 点击Launch之后,你应该可以看到一个连接对话框,这个时候点Detail可以看到以下信息。它在等待虚拟机启动。

  2. 这个时候启动虚拟机(选择VirtualKD调试),启动的时候会为你加载符号。首次加载符号会从符号服务器下载,请耐心等候。

    如果有不能加载的符号,VisualDDK会弹出提醒(服务器上没有),问你下次是否跳过这些符号,点OK就行了。

  3. 如果虚拟机版本是Vista以上,会跳出一个对话框,问你是否要打印调试信息,选是。

  4. 然后,VS此时会进入一个中断。点击调试-继续让内核和驱动继续加载

  5. 启动的过程可能相当缓慢,而且VisualDDK的控制台会输出一些错误信息,这是正常的,请耐心等候

  6. 如果你的虚拟机成功启动,恭喜你,你基本已经成功了!成功启动后,启动虚拟机上的DDKLaunchMonitor(默认在C盘根目录)。启动后,可以看到虚拟机的IP是192.168.3.105

  7. 现在点击VisualDDK控制台上的加载驱动的命令(如果控制台不见了,可以选择菜单调试-窗口-VisualDDK Console调出来)

    点击之后,可以看到以下对话框。因为刚才填写调试配置的时候没有填写IP,现在需要重新填写才能跟虚拟机通信。

    点击菜单调试-停止调试,重新选择菜单调试-Driver Launch Settings… ,将虚拟机的IP填上。

    这次再点击Launch,你能成功连接了。

  8. 现在弹出了一个驱动安装的配置向导,使用默认设置,然后点击"Install"

  9. 此时看虚拟机,会弹出让你安装驱动程序的对话框,选择"始终安装此驱动程序"

  10. 当驱动安装成功,你可以看到,输出的调试信息"Hello from PnpDriver",输出的语句你可以在你的源代码的DriverEntry函数中找到。

  11. 要结束调试,记住点击"调试"-"结束调试"。
  12. 下次继续调试,不用重启虚拟机,可以直接使用建立好的管道。下面敲个断点试试。

  13. 调试情况:

问题收集

  1. 调试菜单下没有VisualDDK的相关菜单项。

    此时你可以试试打开我的文档,把Visual Studio 2010目录底下的Addins文件夹删掉再重装VisualDDK。如果还不行,你可以试试把整个Visual Studio 2010目录删掉(注意备份你以前的工程)

  2. 没法连接到我的VMWare虚拟机

    正确的步骤是,在VMWare启动时,将界面停留在os 选择这里,然后点击Driver Launch Settings,设置好,然后点击Launch,然后在VMWare里进入系统。经过这样的步骤后,虚拟机系统里的驱动,才可以被正常的调试。

    如果你在VMMon看到的"指示图标"不是绿色的,你需要删除%USERPROFILE%\AppData\Roaming\VirtualKD下的*.vmpatch文件

  3. 其他问题,加我QQ:techird@qq.com
  4. 本文参考地址: