• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            WinDBG+VMware=調試內核 [轉載]

            Posted on 2010-01-06 11:33 S.l.e!ep.¢% 閱讀(505) 評論(0)  編輯 收藏 引用 所屬分類: WinDbg
            http://hi.baidu.com/1ian9yu/blog/item/bbaf1301240d7ad3267fb524.html

            按照我這篇筆記寫的步驟去做,絕對能夠成功,并且還能大略地了解到為什么要這樣做的原因。第1部分是步驟,如果不想看原因的,直接按部照搬就可以成功。如果還想深入點了解為什么要做這些步驟,這些步驟的含義是什么?那就請繼續看第二部分。

            第一部分(步驟):

            先統一名稱,真實的操作系統叫HostOS,在VMware里虛擬的操作系統叫GuestOS。

            1.在VMware里安裝好GuestOS;下載WinDBG并安裝好。

            2.添加一個串口

            在關閉GuestOS的情況下才能添加硬件。添加串口的過程如下:
            添加硬件向導 -> 添加 -> 選擇“串行端口” -> 選擇“輸出命名管道”
            命名管道: \\.\pipe\com_1
            終端是服務器.
            其它終端是一個應用程序

            設備狀態
            * 打開電源時連接

            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 Computer for 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 -k is used without any ConnectType options following it, it must be the final entry on the command line.

            resets=0
            Specifies that an unlimited number of reset packets can be sent to the target when the host and target are synchronizing. Use the resets=0 parameter 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...”,然后會彈出對話框

            Baud Rate : 115200
            Port: \\.\pipe\com_1
            *Pipe
            *Reconnect
            Resets:0

            然后設置如上,點確定。這樣也是可以進行調試的。

            8.上面第5、第6步有先后順序嗎?看到很多資料都很強調這個先后順序。

            這個是沒有先后順序的。你可以先執行第5,再到第6步,或者先執行第6,再到第5步都是沒有關系的。

            選擇Debug模式后,即使進入系統操作了很久,運行了很多東西,但只要你運行WinDBG,照樣能夠連上去調試。所以說這里是沒有先后順序的。

            久久精品人人槡人妻人人玩AV| 99久久精品国产一区二区| 51久久夜色精品国产| 久久综合给合久久狠狠狠97色69| 思思久久好好热精品国产| 久久久久国产亚洲AV麻豆| 国内精品久久久久影院免费| 久久久久久午夜成人影院 | 狠狠色丁香婷综合久久| 综合久久给合久久狠狠狠97色| 久久综合成人网| 中文字幕精品久久久久人妻| 欧美激情精品久久久久久久| 综合久久一区二区三区| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 性欧美丰满熟妇XXXX性久久久 | 久久亚洲欧洲国产综合| 午夜精品久久久久久| 久久毛片一区二区| 久久久久亚洲AV无码专区体验| 国产精品国色综合久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久久久亚洲精品无码网址| 香蕉99久久国产综合精品宅男自 | 久久人人爽爽爽人久久久| 久久精品草草草| 思思久久99热免费精品6| 久久综合亚洲鲁鲁五月天| 看久久久久久a级毛片| 亚洲狠狠综合久久| 久久精品国产男包| 久久97精品久久久久久久不卡| 久久久精品波多野结衣| 久久精品免费一区二区| 欧美亚洲另类久久综合| 伊人久久五月天| 韩国无遮挡三级久久| 欧美久久一级内射wwwwww.| 久久久久AV综合网成人| 伊人色综合久久天天网| 久久精品国产一区|