#Windbg虚拟机双机内核调试
做内核调试时,我们经常使用到windbg的虚拟机双机调试,所以这里记录一下配置双机调试的过程,方便查询。另外,微软提供了一个windbgpreview
工具,算是windbg的升级版本,ui更好看了,并且把x86和 x64合在了一起,还不需要管理员权限运行。比较方便。
首先选择连接方式,用虚拟机只有一种串口方式,通过虚拟机模拟的串口输出到主机上的命名管道,然后 WinDbg(preview)
连接这个命名管道,从而实现主机和虚拟机的连接
1. 第一步就是给虚拟机创建虚拟串口。
关掉虚拟机,进入该虚拟机的设置页面。首先我们要删除打印机这个硬件设备,因为打印机的硬件设备占了一个串口,导致我们后面添加的串口只能是串口2.当然,你也可以不删,只是后面设置的时候要改一些参数。
然后点击左下角的“添加”。
选着串行端口,下一步。
选择输出到命名管道,下一步。
命名管道名称为WinDbg(Preview) 连接时需要用到的
管道名,\.\pipe\前缀不可少,后面接一个容易理解的名称即可。选择另一端是应用程序,即windbg Preview。完成。
2. 添加调试启动项
设置好硬件连接方式后(这里是虚拟硬件),启动虚拟机中的系统,添加调试启动项。因为虚拟机只是虚拟了串口 , 所以设置系统启动项时只能使用串口方式。Vista
之前的系统通过修改 boot.ini 文件实现,如下表。红色项表示新添 加的启动项,/debug 表示打开内核调试引擎,/debugport=com1
表示采用串口 1 通信,/baudrate=115200 设 置串口1 的波特率为 115200。
[boot loader] timeout=30 default=multi(0)disk(0)rdisk(0)partition(1)\WINDOWS
[operating systems]multi(0)disk(0)rdisk(0)partition(1)\WINDOWS="Microsoft
Windows XP Professional" /noexecute=optin /fastdetect multi(0)disk(0)rdisk(0
)partition(1)\WINDOWS="debug entry" /noexecute=optin /debug /debugport=com1
/baudrate=115200
最后一行的启动项配置就是我们呢要添加的。
添加完后重启, 在进入启动项的选择界面后,上下选择一下,使其停留在这个界面。然后打开windbg Preview 的内核调试界面,