亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 953 | 回復(fù): 0
打印 上一主題 下一主題

Linux 內(nèi)核調(diào)試器內(nèi)幕 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2007-07-20 05:39 |只看該作者 |倒序?yàn)g覽

               
Hariprasad Nellitheertha
(
[email=nharipra@in.ibm.com?subject=Linux%20%E5%86%85%E6%A0%B8%E8%B0%83%E8%AF%95%E5%99%A8%E5%86%85%E5%B9%95]nharipra@in.ibm.com[/email]
), 軟件工程師, IBM
2003 年  9 月  01 日
調(diào)
試內(nèi)核問題時(shí),能夠跟蹤內(nèi)核執(zhí)行情況并查看其內(nèi)存和數(shù)據(jù)結(jié)構(gòu)是非常有用的。Linux 中的內(nèi)置內(nèi)核調(diào)試器 KDB
提供了這種功能。在本文中您將了解如何使用 KDB 所提供的功能,以及如何在 Linux 機(jī)器上安裝和設(shè)置 KDB。您還將熟悉 KDB
中可以使用的命令以及設(shè)置和顯示選項(xiàng)。
      
Linux 內(nèi)核調(diào)試器(KDB)允許您調(diào)試 Linux 內(nèi)核。這個(gè)恰如其名的工具實(shí)質(zhì)上是內(nèi)核代碼的補(bǔ)丁,它允許高手訪問內(nèi)核內(nèi)存和數(shù)據(jù)結(jié)構(gòu)。KDB 的主要優(yōu)點(diǎn)之一就是它不需要用另一臺(tái)機(jī)器進(jìn)行調(diào)試:您可以調(diào)試正在運(yùn)行的內(nèi)核。
      
設(shè)置一臺(tái)用于 KDB 的機(jī)器需要花費(fèi)一些工作,因?yàn)樾枰o內(nèi)核打補(bǔ)丁并進(jìn)行重新編譯。KDB 的用戶應(yīng)當(dāng)熟悉 Linux 內(nèi)核的編譯(在一定程度上還要熟悉內(nèi)核內(nèi)部機(jī)理),但是如果您需要編譯內(nèi)核方面的幫助,請(qǐng)參閱本文結(jié)尾處的
        
參考資料
一節(jié)。
      
      
在本文中,我們將從有關(guān)下載 KDB 補(bǔ)丁、打補(bǔ)丁、(重新)編譯內(nèi)核以及啟動(dòng) KDB 方面的信息著手。然后我們將了解 KDB 命令并研究一些較常用的命令。最后,我們將研究一下有關(guān)設(shè)置和顯示選項(xiàng)方面的一些詳細(xì)信息。
      
入門
      
KDB 項(xiàng)目是由 Silicon Graphics 維護(hù)的(請(qǐng)參閱
        
參考資料
以獲取鏈接),您需要從它的
        
FTP 站點(diǎn)

載與內(nèi)核版本有關(guān)的補(bǔ)丁。(在編寫本文時(shí))可用的最新 KDB 版本是
4.2。您將需要下載并應(yīng)用兩個(gè)補(bǔ)丁。一個(gè)是“公共的”補(bǔ)丁,包含了對(duì)通用內(nèi)核代碼的更改,另一個(gè)是特定于體系結(jié)構(gòu)的補(bǔ)丁。補(bǔ)丁可作為 bz2
文件獲取。例如,在運(yùn)行 2.4.20 內(nèi)核的 x86 機(jī)器上,您會(huì)需要 kdb-v4.2-2.4.20-common-1.bz2 和
kdb-v4.2-2.4.20-i386-1.bz2。
      
這里所提供的所有示例都是針對(duì) i386 體系結(jié)構(gòu)和 2.4.20 內(nèi)核的。您將需要根據(jù)您的機(jī)器和內(nèi)核版本進(jìn)行適當(dāng)?shù)母。您還需要擁有 root 許可權(quán)以執(zhí)行這些操作。
      
將文件復(fù)制到 /usr/src/linux 目錄中并從用 bzip2 壓縮的文件解壓縮補(bǔ)丁文件:

      #bzip2 -d kdb-v4.2-2.4.20-common-1.bz2
        
        
#bzip2 -d kdb-v4.2-2.4.20-i386-1.bz2
      

      
您將獲得 kdb-v4.2-2.4.20-common-1 和 kdb-v4.2-2.4-i386-1 文件。
      
現(xiàn)在,應(yīng)用這些補(bǔ)。

      #patch -p1

      
這些補(bǔ)丁應(yīng)該干凈利落地加以應(yīng)用。查找任何以 .rej 結(jié)尾的文件。這個(gè)擴(kuò)展名表明這些是失敗的補(bǔ)丁。如果內(nèi)核樹沒問題,那么補(bǔ)丁的應(yīng)用就不會(huì)有任何問題。
      
接下來,需要構(gòu)建內(nèi)核以支持 KDB。第一步是設(shè)置
        CONFIG_KDB 選項(xiàng)。使用您喜歡的配置機(jī)制(xconfig 和 menuconfig 等)來完成這一步。轉(zhuǎn)到結(jié)尾處的“Kernel hacking”部分并選擇“Built-in Kernel Debugger support”選項(xiàng)。
      
      
您還可以根據(jù)自己的偏好選擇其它兩個(gè)選項(xiàng)。選擇“Compile the kernel with frame pointers”選項(xiàng)(如果有的話)則設(shè)置
        CONFIG_FRAME_POINTER 標(biāo)志。這將產(chǎn)生更好的堆;厮荩?yàn)閹羔樇拇嫫鞅挥米鲙羔樁皇峭ㄓ眉拇嫫。您還可以選擇“KDB off by default”選項(xiàng)。這將設(shè)置
        CONFIG_KDB_OFF 標(biāo)志,并且在缺省情況下將關(guān)閉 KDB。我們將在后面一節(jié)中對(duì)此進(jìn)行詳細(xì)介紹。
      
      
保存配置,然后退出。重新編譯內(nèi)核。建議在構(gòu)建內(nèi)核之前執(zhí)行“make clean”。用常用方式安裝內(nèi)核并引導(dǎo)它。
      




回頁首
初始化并設(shè)置環(huán)境變量
      
您可以定義將在 KDB 初始化期間執(zhí)行的 KDB 命令。需要在純文本文件 kdb_cmds 中定義這些命令,該文件位于 Linux
源代碼樹(當(dāng)然是在打了補(bǔ)丁之后)的 KDB
目錄中。該文件還可以用來定義設(shè)置顯示和打印選項(xiàng)的環(huán)境變量。文件開頭的注釋提供了編輯文件方面的幫助。使用這個(gè)文件的缺點(diǎn)是,在您更改了文件之后需要重
新構(gòu)建并重新安裝內(nèi)核。
      




回頁首
激活 KDB
      
如果編譯期間沒有選中
        CONFIG_KDB_OFF ,那么在缺省情況下 KDB 是活動(dòng)的。否則,您需要顯式地激活它 - 通過在引導(dǎo)期間將
        kdb=on 標(biāo)志傳遞給內(nèi)核或者通過在掛裝了 /proc 之后執(zhí)行該工作:
      

      #echo "1" >/proc/sys/kernel/kdb

      
倒過來執(zhí)行上述步驟則會(huì)取消激活 KDB。也就是說,如果缺省情況下 KDB 是打開的,那么將
        kdb=off 標(biāo)志傳遞給內(nèi)核或者執(zhí)行下面這個(gè)操作將會(huì)取消激活 KDB:
      

      #echo "0" >/proc/sys/kernel/kdb

      
在引導(dǎo)期間還可以將另一個(gè)標(biāo)志傳遞給內(nèi)核。
        kdb=early 標(biāo)志將導(dǎo)致在引導(dǎo)過程的初始階段就把控制權(quán)傳遞給 KDB。如果您需要在引導(dǎo)過程初始階段進(jìn)行調(diào)試,那么這將有所幫助。
      
      
調(diào)用 KDB 的方式有很多。如果 KDB 處于打開狀態(tài),那么只要內(nèi)核中有緊急情況就自動(dòng)調(diào)用它。按下鍵盤上的 PAUSE 鍵將手工調(diào)用 KDB。調(diào)用 KDB 的另一種方式是通過串行控制臺(tái)。當(dāng)然,要做到這一點(diǎn),需要設(shè)置串行控制臺(tái)(請(qǐng)參閱
        
參考資料
以獲取這方面的幫助)并且需要一個(gè)從串行控制臺(tái)進(jìn)行讀取的程序。按鍵序列 Ctrl-A 將從串行控制臺(tái)調(diào)用 KDB。
      
      




回頁首
KDB 命令
      
KDB 是一個(gè)功能非常強(qiáng)大的工具,它允許進(jìn)行幾個(gè)操作,比如內(nèi)存和寄存器修改、應(yīng)用斷點(diǎn)和堆棧跟蹤。根據(jù)這些,可以將 KDB 命令分成幾個(gè)類別。下面是有關(guān)每一類中最常用命令的詳細(xì)信息。
      
內(nèi)存顯示和修改
      
這一類別中最常用的命令是
        md 、
        mdr 、
        mm 和
        mmW 。
      
      

        md 命令以一個(gè)地址/符號(hào)和行計(jì)數(shù)為參數(shù),顯示從該地址開始的
        line-count 行的內(nèi)存。如果沒有指定
        line-count ,那么就使用環(huán)境變量所指定的缺省值。如果沒有指定地址,那么
        md 就從上一次打印的地址繼續(xù)。地址打印在開頭,字符轉(zhuǎn)換打印在結(jié)尾。
      
      

        mdr 命令帶有地址/符號(hào)以及字節(jié)計(jì)數(shù),顯示從指定的地址開始的
        byte-count 字節(jié)數(shù)的初始內(nèi)存內(nèi)容。它本質(zhì)上和
        md 一樣,但是它不顯示起始地址并且不在結(jié)尾顯示字符轉(zhuǎn)換。
        mdr 命令較少使用。
      
      

        mm 命令修改內(nèi)存內(nèi)容。它以地址/符號(hào)和新內(nèi)容作為參數(shù),用
        new-contents 替換地址處的內(nèi)容。
      
      

        mmW 命令更改從地址開始的
        W 個(gè)字節(jié)。請(qǐng)注意,
        mm 更改一個(gè)機(jī)器字。
      
      
        示例
      
      
顯示從 0xc000000 開始的 15 行內(nèi)存:

      [0]kdb> md 0xc000000 15

      
將內(nèi)存位置為 0xc000000 上的內(nèi)容更改為 0x10:

      [0]kdb> mm 0xc000000 0x10

      
寄存器顯示和修改
      
這一類別中的命令有
        rd 、
        rm 和
        ef 。
      
      

        rd 命令(不帶任何參數(shù))顯示處理器寄存器的內(nèi)容。它可以有選擇地帶三個(gè)參數(shù)。如果傳遞了
        c 參數(shù),則
        rd 顯示處理器的控制寄存器;如果帶有
        d 參數(shù),那么它就顯示調(diào)試寄存器;如果帶有
        u 參數(shù),則顯示上一次進(jìn)入內(nèi)核的當(dāng)前任務(wù)的寄存器組。
      
      

        rm 命令修改寄存器的內(nèi)容。它以寄存器名稱和
        new-contents 作為參數(shù),用
        new-contents 修改寄存器。寄存器名稱與特定的體系結(jié)構(gòu)有關(guān)。目前,不能修改控制寄存器。
      
      

        ef 命令以一個(gè)地址作為參數(shù),它顯示指定地址處的異常幀。
      
      
        示例
      
      
顯示通用寄存器組:

      [0]kdb> rd

      



      [0]kdb> rm %ebx 0x25

      
斷點(diǎn)
      
常用的斷點(diǎn)命令有
        bp 、
        bc 、
        bd 、
        be 和
        bl 。
      
      

        bp 命令以一個(gè)地址/符號(hào)作為參數(shù),它在地址處應(yīng)用斷點(diǎn)。當(dāng)遇到該斷點(diǎn)時(shí)則停止執(zhí)行并將控制權(quán)交予 KDB。該命令有幾個(gè)有用的變體。
        bpa 命令對(duì) SMP 系統(tǒng)中的所有處理器應(yīng)用斷點(diǎn)。
        bph 命令強(qiáng)制在支持硬件寄存器的系統(tǒng)上使用它。
        bpha 命令類似于
        bpa 命令,差別在于它強(qiáng)制使用硬件寄存器。
      
      

        bd 命令禁用特殊斷點(diǎn)。它接收斷點(diǎn)號(hào)作為參數(shù)。該命令不是從斷點(diǎn)表中除去斷點(diǎn),而只是禁用它。斷點(diǎn)號(hào)從 0 開始,根據(jù)可用性順序分配給斷點(diǎn)。
      
      

        be 命令啟用斷點(diǎn)。該命令的參數(shù)也是斷點(diǎn)號(hào)。
      
      

        bl 命令列出當(dāng)前的斷點(diǎn)集。它包含了啟用的和禁用的斷點(diǎn)。
      
      

        bc 命令從斷點(diǎn)表中除去斷點(diǎn)。它以具體的斷點(diǎn)號(hào)或
        * 作為參數(shù),在后一種情況下它將除去所有斷點(diǎn)。
      
      
示例
      
        對(duì)函數(shù)
          sys_write() 設(shè)置斷點(diǎn):
        

      

      [0]kdb> bp sys_write

      
列出斷點(diǎn)表中的所有斷點(diǎn):

      [0]kdb> bl

      
清除斷點(diǎn)號(hào) 1:

      [0]kdb> bc 1

      
>堆棧跟蹤
      
主要的堆棧跟蹤命令有
        bt 、
        btp 、
        btc 和
        bta 。
      
      

        bt 命令設(shè)法提供有關(guān)當(dāng)前線程的堆棧的信息。它可以有選擇地將堆棧幀地址作為參數(shù)。如果沒有提供地址,那么它采用當(dāng)前寄存器來回溯堆棧。否則,它假定所提供的地址是有效的堆棧幀起始地址并設(shè)法進(jìn)行回溯。如果內(nèi)核編譯期間設(shè)置了
        CONFIG_FRAME_POINTER 選項(xiàng),那么就用幀指針寄存器來維護(hù)堆棧,從而就可以正確地執(zhí)行堆棧回溯。如果沒有設(shè)置
        CONFIG_FRAME_POINTER ,那么
        bt 命令可能會(huì)產(chǎn)生錯(cuò)誤的結(jié)果。
      
      

        btp 命令將進(jìn)程標(biāo)識(shí)作為參數(shù),并對(duì)這個(gè)特定進(jìn)程進(jìn)行堆;厮荨
      
      

        btc 命令對(duì)每個(gè)活動(dòng) CPU 上正在運(yùn)行的進(jìn)程執(zhí)行堆;厮。它從第一個(gè)活動(dòng) CPU 開始執(zhí)行
        bt ,然后切換到下一個(gè)活動(dòng) CPU,以此類推。
      
      

        bta 命令對(duì)處于某種特定狀態(tài)的所有進(jìn)程執(zhí)行回溯。若不帶任何參數(shù),它就對(duì)所有進(jìn)程執(zhí)行回溯?梢杂羞x擇地將各種參數(shù)傳遞給該命令。將根據(jù)參數(shù)處理處于特定狀態(tài)的進(jìn)程。選項(xiàng)以及相應(yīng)的狀態(tài)如下:
      
      
  • D:不可中斷狀態(tài)
  • R:正運(yùn)行
  • S:可中斷休眠
  • T:已跟蹤或已停止
  • Z:僵死
  • U:不可運(yùn)行

      
這類命令中的每一個(gè)都會(huì)打印出一大堆信息。請(qǐng)查閱下面的
        
參考資料
以獲取這些字段的詳細(xì)文檔。
      
      
        示例
      
      
跟蹤當(dāng)前活動(dòng)線程的堆棧:

      [0]kdb> bt

      
跟蹤標(biāo)識(shí)為 575 的進(jìn)程的堆棧:

      [0]kdb> btp 575

      
其它命令
      
下面是在內(nèi)核調(diào)試過程中非常有用的其它幾個(gè) KDB 命令。
      

        id 命令以一個(gè)地址/符號(hào)作為參數(shù),它對(duì)從該地址開始的指令進(jìn)行反匯編。環(huán)境變量
        IDCOUNT 確定要顯示多少行輸出。
      
      

        ss 命令單步執(zhí)行指令然后將控制返回給 KDB。該指令的一個(gè)變體是
        ssb ,它執(zhí)行從當(dāng)前指令指針地址開始的指令(在屏幕上打印指令),直到它遇到將引起分支轉(zhuǎn)移的指令為止。分支轉(zhuǎn)移指令的典型示例有
        call 、
        return 和
        jump 。
      
      

        go 命令讓系統(tǒng)繼續(xù)正常執(zhí)行。一直執(zhí)行到遇到斷點(diǎn)為止(如果已應(yīng)用了一個(gè)斷點(diǎn)的話)。
      
      

        reboot 命令立刻重新引導(dǎo)系統(tǒng)。它并沒有徹底關(guān)閉系統(tǒng),因此結(jié)果是不可預(yù)測的。
      
      

        ll 命令以地址、偏移量和另一個(gè) KDB 命令作為參數(shù)。它對(duì)鏈表中的每個(gè)元素反復(fù)執(zhí)行作為參數(shù)的這個(gè)命令。所執(zhí)行的命令以列表中當(dāng)前元素的地址作為參數(shù)。
      
      
        示例
      
      
反匯編從例程 schedule 開始的指令。所顯示的行數(shù)取決于環(huán)境變量
        IDCOUNT :
      


      [0]kdb> id schedule

      
執(zhí)行指令直到它遇到分支轉(zhuǎn)移條件(在本例中為指令
        jne )為止:
      


      
[0]kdb> ssb
        
        
0xc0105355  default_idle+0x25:  cli
        
0xc0105356  default_idle+0x26:  mov  0x14(%edx),%eax
        
0xc0105359  default_idle+0x29:  test %eax, %eax
        
0xc010535b  default_idle+0x2b:  jne  0xc0105361 default_idle+0x31
      

      




回頁首
技巧和訣竅
      
調(diào)試一個(gè)問題涉及到:使用調(diào)試器(或任何其它工具)找到問題的根源以及使用源代碼來跟蹤導(dǎo)致問題的根源。單單使用源代碼來確定問題是極其困難的,只有老練
的內(nèi)核黑客才有可能做得到。相反,大多數(shù)的新手往往要過多地依靠調(diào)試器來修正錯(cuò)誤。這種方法可能會(huì)產(chǎn)生不正確的問題解決方案。我們擔(dān)心的是這種方法只會(huì)修
正表面癥狀而不能解決真正的問題。此類錯(cuò)誤的典型示例是添加錯(cuò)誤處理代碼以處理 NULL 指針或錯(cuò)誤的引用,卻沒有查出無效引用的真正原因。
      
結(jié)合研究代碼和使用調(diào)試工具這兩種方法是識(shí)別和修正問題的最佳方案。
      
調(diào)試器的主要用途是找到錯(cuò)誤的位置、確認(rèn)癥狀(在某些情況下還有起因)、確定變量的值,以及確定程序是如何出現(xiàn)這種情況的(即,建立調(diào)用堆棧)。有經(jīng)驗(yàn)的黑客會(huì)知道對(duì)于某種特定的問題應(yīng)使用哪一個(gè)調(diào)試器,并且能迅速地根據(jù)調(diào)試獲取必要的信息,然后繼續(xù)分析代碼以識(shí)別起因。
      
因此,這里為您介紹了一些技巧,以便您能使用 KDB 快速地取得上述結(jié)果。當(dāng)然,要記住,調(diào)試的速度和精確度來自經(jīng)驗(yàn)、實(shí)踐和良好的系統(tǒng)知識(shí)(硬件和內(nèi)核內(nèi)部機(jī)理等)。
      
技巧 #1
      
在 KDB 中,在提示處輸入地址將返回與之最為匹配的符號(hào)。這在堆棧分析以及確定全局?jǐn)?shù)據(jù)的地址/值和函數(shù)地址方面極其有用。同樣,輸入符號(hào)名則返回其虛擬地址。
      
        示例
      
      
表明函數(shù)
        sys_read 從地址 0xc013db4c 開始:
      


      [0]kdb> 0xc013db4c
        
        
0xc013db4c = 0xc013db4c (sys_read)
      

      
同樣,
      
同樣,表明
        sys_write 位于地址 0xc013dcc8:
      


      [0]kdb> sys_write
        
        
sys_write = 0xc013dcc8 (sys_write)
      

      
這些有助于在分析堆棧時(shí)找到全局?jǐn)?shù)據(jù)和函數(shù)地址。
      
技巧 #2
      
在編譯帶 KDB 的內(nèi)核時(shí),只要
        CONFIG_FRAME_POINTER
選項(xiàng)出現(xiàn)就使用該選項(xiàng)。為此,需要在配置內(nèi)核時(shí)選擇“Kernel hacking”部分下面的“Compile the kernel with
frame
pointers”選項(xiàng)。這確保了幀指針寄存器將被用作幀指針,從而產(chǎn)生正確的回溯。實(shí)際上,您可以手工轉(zhuǎn)儲(chǔ)幀指針寄存器的內(nèi)容并跟蹤整個(gè)堆棧。例如,在
i386 機(jī)器上,%ebp 寄存器可以用來回溯整個(gè)堆棧。
      
例如,在函數(shù)
        rmqueue() 上執(zhí)行第一個(gè)指令后,堆?瓷先ヮ愃朴谙旅孢@樣:
      

      [0]kdb> md %ebp
        
        
0xc74c9f38 c74c9f60  c0136c40 000001f0 00000000
        
0xc74c9f48 08053328 c0425238 c04253a8 00000000
        
0xc74c9f58 000001f0  00000246 c74c9f6c c0136a25
        
0xc74c9f68 c74c8000  c74c9f74  c0136d6d c74c9fbc
        
0xc74c9f78 c014fe45  c74c8000  00000000 08053328
        
        
[0]kdb> 0xc0136c40
        
        
0xc0136c40 = 0xc0136c40 (__alloc_pages +0x44)
        
        
[0]kdb> 0xc0136a25
        
        
0xc0136a25 = 0xc0136a25 (_alloc_pages +0x19)
        
        
[0]kdb> 0xc0136d6d
        
        
0xc0136d6d = 0xc0136d6d (__get_free_pages +0xd)
      

      
我們可以看到
        rmqueue() 被
        __alloc_pages 調(diào)用,后者接下來又被
        _alloc_pages 調(diào)用,以此類推。
      
      
每一幀的第一個(gè)雙字(double word)指向下一幀,這后面緊跟著調(diào)用函數(shù)的地址。因此,跟蹤堆棧就變成一件輕松的工作了。
      
技巧 #3
      

        go 命令可以有選擇地以一個(gè)地址作為參數(shù)。如果您想在某個(gè)特定地址處繼續(xù)執(zhí)行,則可以提供該地址作為參數(shù)。另一個(gè)辦法是使用
        rm 命令修改指令指針寄存器,然后只要輸入
        go 。如果您想跳過似乎會(huì)引起問題的某個(gè)特定指令或一組指令,這就會(huì)很有用。但是,請(qǐng)注意,該指令使用不慎會(huì)造成嚴(yán)重的問題,系統(tǒng)可能會(huì)嚴(yán)重崩潰。
      
      
技巧 #4
      
您可以利用一個(gè)名為
        defcmd 的有用命令來定義自己的命令集。例如,每當(dāng)遇到斷點(diǎn)時(shí),您可能希望能同時(shí)檢查某個(gè)特殊變量、檢查某些寄存器的內(nèi)容并轉(zhuǎn)儲(chǔ)堆棧。通常,您必須要輸入一系列命令,以便能同時(shí)執(zhí)行所有這些工作。
        defcmd 允許您定義自己的命令,該命令可以包含一個(gè)或多個(gè)預(yù)定義的 KDB 命令。然后只需要用一個(gè)命令就可以完成所有這三項(xiàng)工作。其語法如下:
      

      
[0]kdb> defcmd name "usage" "help"
        
        
[0]kdb> [defcmd] type the commands here
        
        
[0]kdb> [defcmd] endefcmd
      

      
例如,可以定義一個(gè)(簡單的)新命令
        hari ,它顯示從地址 0xc000000 開始的一行內(nèi)存、顯示寄存器的內(nèi)容并轉(zhuǎn)儲(chǔ)堆棧:
      

      [0]kdb> defcmd hari "" "no arguments needed"
        
        
[0]kdb> [defcmd] md 0xc000000 1
        
        
[0]kdb> [defcmd] rd
        
        
[0]kdb> [defcmd] md %ebp 1
        
        
[0]kdb> [defcmd] endefcmd
      

      
該命令的輸出會(huì)是:

      [0]kdb> hari
        
        
[hari]kdb> md 0xc000000 1
        
        
0xc000000 00000001 f000e816 f000e2c3 f000e816
        
        
[hari]kdb> rd
        
        
eax = 0x00000000 ebx = 0xc0105330 ecx = 0xc0466000 edx = 0xc0466000
        
....
        
...
        
        
[hari]kdb> md %ebp 1
        
        
0xc0467fbc c0467fd0 c01053d2 00000002 000a0200
        
        
[0]kdb>
      

      
技巧 #5
      
可以使用
        bph 和
        bpha 命令(假如體系結(jié)構(gòu)支持使用硬件寄存器)來應(yīng)用讀寫斷點(diǎn)。這意味著每當(dāng)從某個(gè)特定地址讀取數(shù)據(jù)或?qū)?shù)據(jù)寫入該地址時(shí),我們都可以對(duì)此進(jìn)行控制。當(dāng)調(diào)試數(shù)據(jù)/內(nèi)存毀壞問題時(shí)這可能會(huì)極其方便,在這種情況中您可以用它來識(shí)別毀壞的代碼/進(jìn)程。
      
      
        示例
      
      
每當(dāng)將四個(gè)字節(jié)寫入地址 0xc0204060 時(shí)就進(jìn)入內(nèi)核調(diào)試器:

      [0]kdb> bph 0xc0204060 dataw 4

      
在讀取從 0xc000000 開始的至少兩個(gè)字節(jié)的數(shù)據(jù)時(shí)進(jìn)入內(nèi)核調(diào)試器:

      [0]kdb> bph 0xc000000 datar 2

      




回頁首
結(jié)束語
      
對(duì)于執(zhí)行內(nèi)核調(diào)試,KDB 是一個(gè)方便的且功能強(qiáng)大的工具。它提供了各種選項(xiàng),并且使我們能夠分析內(nèi)存內(nèi)容和數(shù)據(jù)結(jié)構(gòu)。最妙的是,它不需要用另一臺(tái)機(jī)器來執(zhí)行調(diào)試。
   
參考資料
      
  • 您可以參閱本文在 developerWorks 全球站點(diǎn)上的
             
    英文原文
    .
            
  • 請(qǐng)?jiān)?Documentation/kdb 目錄中查找 KDB 手冊(cè)頁。
             
             
            
  • 有關(guān)設(shè)置串行控制臺(tái)的信息,請(qǐng)查找 Documentation 目錄中的 serial-console.txt。
             
             
            
  • 請(qǐng)?jiān)?SGI 的內(nèi)核調(diào)試器項(xiàng)目網(wǎng)站上
             
    下載 KDB
    。
             
             
            
  • 有關(guān)幾個(gè)基于方案的 Linux 調(diào)試技術(shù)的概述,請(qǐng)閱讀“
             
    掌握 Linux 調(diào)試技術(shù)
    ”(
              developerWorks,2002 年 8 月)。
             
             
            
  • 教程“
             
    編譯 Linux 內(nèi)核
    ”(
              developerWorks,2000 年 8 月)讓您完整地了解配置、編譯和安裝內(nèi)核的過程。
             
             
            
  • IBM AIX 用戶可以在
             
    KDB Kernel Debugger and Command
    頁面上獲取有關(guān)用于 AIX 的 KDB 的使用幫助。
             
             
            
  • 那些尋求有關(guān)調(diào)試 OS/2 信息的讀者應(yīng)該閱讀 IBM 紅皮書
              The OS/2 Debugging Handbook(共四卷)的
             
    第 II 卷

             
             
            

  •           developerWorksLinux 專區(qū)中查找更多
             
    針對(duì) Linux 開發(fā)人員的參考資料
    。
             
             
            

   
關(guān)于作者


Hariprasad
Nellitheertha 在印度班加羅爾(Bangalore)的 IBM Linux 技術(shù)中心工作。他目前正在 Linux Change
Team 從事修正內(nèi)核和其它 Linux 錯(cuò)誤的工作。Hari 研究過 OS/2 內(nèi)核和文件系統(tǒng)。他的興趣包括 Linux
內(nèi)核內(nèi)部機(jī)理、文件系統(tǒng)和自主計(jì)算?梢酝ㄟ^
[email=nharipra@in.ibm.com?cc=dwlinux@us.ibm.com&Subject=Inside%20the%20Linux%20kernel%20debugger]nharipra@in.ibm.com[/email]
與 Hari 聯(lián)系。
原文地址:http://www.ibm.com/developerworks/cn/linux/l-kdbug/index.html
               
               
               
               
               

本文來自ChinaUnix博客,如果查看原文請(qǐng)點(diǎn):http://blog.chinaunix.net/u/31996/showart_343216.html
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP