设为首页 收藏本站
查看: 720|回复: 0

[经验分享] WinDBG+VMware=调试内核

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-1-5 08:43:00 | 显示全部楼层 |阅读模式
  声明,本文转载自http://blog.csdn.net/floweronwarmbed/archive/2008/11/01/3201307.aspx,不过最初原创者无法知道,改日知道补上。
  呵呵,搞点突兀的标题而已。其实说的还是如何使用WinDBG和VMware来搭建调试内核的环境而已,这些网上已经有数不清的教程了,不过我喜欢自己亲手写一下。第一,把这个过程写一遍能加深印象,就算以后忘记了也可以有笔记查找,快速想起来。第二、网上的教程很多都是互相抄来抄去,连错误也抄过去了。很典型一个错误就是Baud Rate,前面还写115200,后面就写成了11520了,狂汗!
  按照我这篇笔记写的步骤去做,绝对能够成功,并且还能大略地了解到为什么要这样做的原因。第1部分是步骤,如果不想看原因的,直接按部照搬就可以成功。如果还想深入点了解为什么要做这些步骤,这些步骤的含义是什么?那就请继续看第二部分。
  第一部分(步骤):
  先统一名称,真实的操作系统叫HostOS,在VMware里虚拟的操作系统叫GuestOS。
  1.在VMware里安装好GuestOS;下载WinDBG并安装好。
  2.添加一个串口
  在关闭GuestOS的情况下才能添加硬件。添加串口的过程如下:
  

  
  选择“串行端口”,
  

 选择“输出命名管道”
  

 其他如下设置:
  

  3.在GuestOS的boot.ini文件里填入如下内容:
  multi(0)disk(0)rdisk(0)partition(1)\WINDOWS="Microsoft Windows XP Professional Debug" /fastdetect /debugport=com1 /baudrate=115200
  如图:
  

  4.创建一个WinDBG的快捷方式,在“目标”一栏后面加上:
  -b -k com:pipe,port=\\.\pipe\com_1,resets=0
  如图:

 5.重启GuestOS,选择Debug模式。

 6.双击第4步创建的那个快捷方式启动WinDBG,它会自动去连接调试GuestOS。
  

  可以看到,已经成功了,现在可以尽情地调试内核了。
  第二部分(解说):
  原理就是VMware在GuestOS虚拟一个COM口,并在HostOS创建了一个管道,这个管道的一端连接GuestOS的COM口,另一端则是WinDBG,所以HostOS(WinDBG)和GuestOS的所有数据交换都是通过这个管道来流通转发的。
  1.我的电脑没有COM口,所以不能搭建调试环境?
  不是的,你的电脑有没有COM口与这个调试环境没有任何关系,整个过程根本没有使用到你电脑的物理COM口。VMware只是在GuestOS虚拟了一个COM口而已。
  2.在创建串口(COM口属于串口的一种)的过程中,看到指定的管道为“\\.\pipe\com_1”,我可以指定为其他吗?
  可以的。这只是指定一个管道名字而已,VMware用这个名字来创建一个命名管道。我完全可以改成“\\.\pipe\liangyu”、“\\.\pipe\aaa”等等,但记得要把WinDBG的快捷方式处的管道名字更改为一样。
  3.我可以在GuestOS的boot.ini文件更改那个COM口吗?比如把COM1改为COM2?
  不可以的,VMware会把虚拟出的这个COM口总是定义为com1。GuestOS的其他COM口都得让位。
  4.看到很多教程都说到要勾选“I/O模式”,如图:
  

  一定要勾选吗?
  这个勾选不勾选都可以,我没发现有什么大的区别。
  5.在更改GuestOS的boot.ini文件的时候,增加有“/debugport=com1 /baudrate=115200”这些内容,含义是?
  使用的调试端口是com1,波特率是115200。这是在告诉GuestOS现在要调试内核(操作系统),把调试信息往COM1口输出,使用的波特率是115200。
我在试验的时候发现,这个波特率其实也不一定要设为115200,完全可以修改为112233、445566等等其他数据。可能是因为WinDBG自动调节波特率来适配管道或COM口,所以波特率在这里没有实际意义。
  6.WinDBG的快捷方式那里添加了“-b -k com:pipe,port=\\.\pipe\com_1,resets=0”这些内容,含义是?
  大概意思就是使用管道“\\.\pipe\com_1”来进行内核调试。各个参数的说明在WinDBG的参考文档里面有,这里粘贴一下:
-b(Kernel mode only)This option has two effects:  1. The debugger will break into the target computer immediately upon connection.
  2. After a reboot, the debugger will break into the target computer once the kernel is initialized. See Crashing and Rebooting the Target Computerfor details and for other methods of changing this status.


-k[ConnectType] (Kernel mode only)Starts a kernel debugging session. For details, see Choosing Kernel Debugging Settings. If -kis used without any ConnectTypeoptions following it, it must be the final entry on the command line. resets=0Specifies that an unlimited number of reset packets can be sent to the target when the host and target are synchronizing. Use the resets=0parameter for Microsoft Virtual PC and other virtual machines whose pipes drop excess bytes. Do not use this parameter for VMware or other virtual machines whose pipes do not drop all excess bytes.  7.一定要这样创建一个WinDBG的快捷方式才能进行调试吗?
  不是的,我们完全可以先正常运行WinDBG,然后选择菜单“File”--->“Kernel Debug...”,然后会弹出以下对话框:
  

  然后设置如上,点确定。这样也是可以进行调试的。
  8.上面第5、第6步有先后顺序吗?看到很多资料都很强调这个先后顺序。
  这个是没有先后顺序的。你可以先执行第5,再到第6步,或者先执行第6,再到第5步都是没有关系的。
  选择Debug模式后,即使进入系统操作了很久,运行了很多东西,但只要你运行WinDBG,照样能够连上去调试。所以说这里是没有先后顺序的。
  
  虚拟机部分配置,英文请参考:http://silverstr.ufies.org/lotr0/windbg-vmware.html
  Vista部分参考: http://www.pediy.com/bbshtml/bbs8/pediy8-484.htm(本人未测试)

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-160409-1-1.html 上篇帖子: 扩大VMware的硬盘SCSI大小方法 下篇帖子: Windows iPhone VMware [转]
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表