原文发表于百度空间,2009-01-09
==========================================================================

今天又想起来VirtualKD这个东西,试用了一下,真是爽坏了,可能我火星了~~

很久以前就知道小喂有个VmKd工具,使用Vmware的后门指令直接拷贝数据来代替模拟串口,能大大提高调试时的数据传输速度。不过那个对VMware版本的依赖性太强,我的Vmware就没法用,所以很不爽得又放下了,很长一段时间也没关注过。最近翻资料时又找到index09同学的一篇文章,介绍了比Vmkd更好用的VirtualKD,于是马上下回来试用了一下,安装简单多了,使用方便,终于体会到了什么叫做速度,调试时那个嗖嗖的啊,比老爷车一样的串口爽太多了,相信某些同学已经用了很久了。各位如果不嫌我火星的话,我就来详细介绍一下,好东西分享给大家:)

使用场景:如果你正在使用Windbg+Vmware或Windbg+VirtualBox进行内核调试,并且觉得虚拟串口方式过于缓慢,那么这个就是你最需要的东西了!它可以大幅提升调试时数据传输的速度,实在是居家旅行、杀人灭口,必备良药~~(后悔用得太晚了)
这是一个开源项目,工程在sourceforge上:
http://sourceforge.net/projects/virtualkd/

官方网站:http://virtualkd.sysprogs.org/
原理和Vmkd差不多,但是使用范围更广,安装更简单了。我简单讲一讲在Vmware上如何使用。

一、准备工作

从上面的网址下载VirtualKD-2.2.zip(当前版本为2.2),并解压出来。应该会有以下文件:

PS:搬运这篇文章时,VirtualKD已经更新到了3.0版本,支持Win10系统,下载地址http://virtualkd.sysprogs.org/download/

二、Guest OS中相应部分的安装
启动虚拟机中的GuestOS,然后把上面的target文件夹的内容全部拷贝到GuestOS中。
运行vminstall.exe,会出现以下界面:

这里相关的东西除了拷贝文件外添加服务外,其实就是新添加一个DEBUG模式的启动菜单,就是更改boot.ini(如图中红框部分所示),但是这一切由vminstall.exe来完成。

不过我发现vminstall.exe好像有个小Bug,新添加的启动入口并没有名称显示,你可以打开boot.ini自己加上。如果是Vista或Win7的话,使用如下命令:
bcdedit /set dbgtransport kdvm.dll
这个装好后,GuestOS中的部分就完成了。

三、HOST OS中相应部分的安装
实际上VirtualKD完全绿色,不需要安装,只要找个合适的地方放好,然后运行vmmon.exe就可以了~~
vmmon.exe会自动找到vmware-vmx.exe并显示在上面,并显示它的一些详细信息。

然后在界面下方的位置你会看到一些设置选项:
Start debugger automatically:GuestOS启动时自动启动调试器
Stop debugger automatically:退出时自动关闭调试器(经测试好像不好使)
DbgBreakPoint() on start:系统启动时的第一时间就中断下来
TraceAssist params:该功能是把虚拟机GuestOS的DbgPrint输出记录到文件,而不是发送到调试器,这样可以在输出特别频繁时提高性能
Debugger path:调试器路径,这里选择你的Windbg就可以了
Unpath process/Repath process:动态地对vmware_vmx.exe进行Patch或恢复(这也是VirtualKD功能的核心)
Run debugger:启动设置好的调试器
Close:退出vmmon.exe

在HOST端我们要做的工作将会非常简单,只需要在Vmware中启动虚拟机的同时启动vmmon.exe就可以了。剩下的vmmon.exe都会替我们做好(动态查找vmware-vmx.exe并进行Patch).
如果你选上了Start debugger automatically那么虚拟机中GuestOS启动的同时vmmon会自动帮你打开调试器,非常方便。
如果你仍然想像以前那样自已通过加参数的方式启动windbg进行双机调试,那么它的参数可以这么写:
"C:\Program Files\Debugging Tools for Windows\windbg.exe" -k com:port=\\.\pipe\kd_WinXP,pipe
关键就是这个管道的名称,也就是kd_<你的GuestOS的安装目录>.比如我的XP虚拟机安装目录在E:\Vmware\WinXP,那么管道名称就是kd_WinXP.
实际上也就是虚拟机系统的*.vmx文件所在的文件夹的名字。
更方便一点,直接看vmmon里显示的管道名称就可以了。

如果你使用的是这种内存动态Patch方式的话,因为总是要运行vmmon.exe,建议还是选上自动启动调试器,会方便一点。或者可以按照readme.txt中的相关介绍直接进行永久性文件Patch,这样就不需要运行vmmon.exe了,详情可参考readme.txt。
另外,VirualKD还解决了一个BUG,就是GuestOS中断在调试器时会大量占用CPU的问题,这个也很爽了。搞完这些之后,调试时数据传输的速度将会大幅提升,你就可以体验极速的感觉了~~~

【旧文章搬运】Windbg+Vmware驱动调试入门(四)---VirtualKD内核调试加速工具的更多相关文章

  1. 【旧文章搬运】PE感染逆向之修复(Serverx.exe专杀工具出炉手记)

    原文发表于百度空间,2008-10-4看雪论坛发表地址:https://bbs.pediy.com/thread-73948.htm================================== ...

  2. 【旧文章搬运】Windbg+Vmware驱动调试入门(一)---Windbg的设置

    原文发表于百度空间,2009-01-08========================================================================== Windb ...

  3. 【旧文章搬运】Windbg+Vmware驱动调试入门(二)---Vmware及GuestOS的设置

    原文发表于百度空间,2009-01-08========================================================================== 这一篇是主 ...

  4. 【旧文章搬运】Windbg+Vmware驱动调试入门(三)---Windbg基本调试入门

    原文发表于百度空间,2009-01-09========================================================================== 这一节的内 ...

  5. 《天书夜读:从汇编语言到windows内核编程》四 windows内核调试环境搭建

    1) 基础篇是讲理论的,先跳过去,看不到代码运行的效果要去记代码是一个痛苦的事情.这里先跳入探索篇.其实今天的确也很痛苦,这作者对驱动开发的编译与调试环境介绍得太模糊了,我是各种尝试,对这个环境的搭建 ...

  6. 【旧文章搬运】关于windbg搜索符号文件的一点说明

    原文发表于百度空间,2010-09-07========================================================================== 本来只是打 ...

  7. 【旧文章搬运】无Device的驱动如何通信

    原文发表于百度空间,2009-07-14========================================================================== 标准的驱动 ...

  8. 【旧文章搬运】Windows内核常见数据结构(驱动相关)

    原文发表于百度空间,2008-7-24========================================================================== 这些是驱动中 ...

  9. 【旧文章搬运】KeUserModeCallback用法详解

    原文发表于百度空间及看雪论坛,2010-01-10 看雪论坛地址:https://bbs.pediy.com/thread-104918.htm  代码及附件可到这里下载=============== ...

随机推荐

  1. 用canvas实现一个colorpicker

    http://www.cnblogs.com/ufex/p/6382982.html 每个浏览器都有自己的特点,比如今天要做的colorpicker就是,一千个浏览器,一千个哈姆雷特,一千个color ...

  2. Oracle释放高水位线

    /*****************************************************************原因:由于原导出数据库没有整理表空间其中主要包括两方面,一是用户产生 ...

  3. python的分布式队列神器 Celery

    pip search kafka可以搜索到很多kafka的python插件,选择一个大家用的比较多的 celery结合kafka使用 使用kafka扩展python logging集中式日志收集 re ...

  4. c++中vector向量几种情况的总结(向量指针,指针的向量)

    1.标准库vector类型 vector 是同一种类型的对象的集合.每一个对象都有一个相应的整数索引值.标准库将负责管理与存储元素相关的内存.我们把 vector 称为容器,是由于它能够包括其它对象. ...

  5. 哈理工2015 暑假训练赛 zoj 2976 Light Bulbs

    MS    Memory Limit:65536KB    64bit IO Format:%lld & %llu SubmitStatusid=14946">Practice ...

  6. lua 异常 错误处理 pcall

    lua 错误处理 匿名函数 if pcall(function () local s=object.data[1]['type'] end) then return object.data[1]['t ...

  7. 与linux相处的日子里

    在前几天装了一下linux操作系统,并安装了几个经常使用的工具.如今就谈谈我的感受吧! 对一个连linux几个字母都不会拼写的人来说.让我參与这个工作可谓是:"太残忍啦!"当然这在 ...

  8. 深入JVM系列(二)之GC机制、收集器与GC调优(转)

    一.回顾JVM内存分配   需要了解更多内存模式与内存分配的,请看 深入JVM系列(一)之内存模型与内存分配 1.1.内存分配: 1.对象优先在EDEN分配2.大对象直接进入老年代 3.长期存活的对象 ...

  9. C++学习总结3

    链接上一篇日志,C++学习总结2,下面介绍下C++里面的其他内容 虚函数:一个接口,多种方法. 多态:编译时的多态与运行时的多态. 编译时的多态表现为运算符的重载与函数的重载. 运行时的多态表现为使用 ...

  10. UI_Target/action 设计模式

    RootView.m 中 UIButton *button = [UIButton buttonWithType:UIButtonTypeSystem]; button.frame = CGRectM ...