青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

elva

[Pthread] Linux程序調(diào)試的基石(二)--Inside GDB

3. GDB的實(shí)現(xiàn)
GDB是GNU發(fā)布的一個強(qiáng)大的程序調(diào)試工具,用以調(diào)試C/C++程序。可以使程序員在程序運(yùn)行的時候觀察程序在內(nèi)存/寄存器中的使用情況。它的實(shí)現(xiàn)也是基于ptrace系統(tǒng)調(diào)用來完成的。
其 原理是利用ptrace系統(tǒng)調(diào)用,在被調(diào)試程序和gdb之間建立跟蹤關(guān)系。然后所有發(fā)送給被調(diào)試程序的信號(除SIGKILL)都會被gdb截獲,gdb 根據(jù)截獲的信號,查看被調(diào)試程序相應(yīng)的內(nèi)存地址,并控制被調(diào)試的程序繼續(xù)運(yùn)行。GDB常用的使用方法有斷點(diǎn)設(shè)置和單步跟蹤,接下來我們來分析一下他們是如 何實(shí)現(xiàn)的。

3.1 建立調(diào)試關(guān)系
用gdb調(diào)試程序,可以直接gdb ./test,也可以gdb <pid>(test的進(jìn)程號)。這對應(yīng)著使用ptrace建立跟蹤關(guān)系的兩種方式:
1)fork: 利用fork+execve執(zhí)行被測試的程序,子進(jìn)程在執(zhí)行execve之前調(diào)用ptrace(PTRACE_TRACEME),建立了與父進(jìn)程(debugger)的跟蹤關(guān)系。如我們在分析strace時所示意的程序。
2)attach: debugger可以調(diào)用ptrace(PTRACE_ATTACH,pid,...),建立自己與進(jìn)程號為pid的進(jìn)程間的跟蹤關(guān)系。即利用 PTRACE_ATTACH,使自己變成被調(diào)試程序的父進(jìn)程(用ps可以看到)。用attach建立起來的跟蹤關(guān)系,可以調(diào)用ptrace (PTRACE_DETACH,pid,...)來解除。注意attach進(jìn)程時的權(quán)限問題,如一個非root權(quán)限的進(jìn)程是不能attach到一個 root進(jìn)程上的。

3.2 斷點(diǎn)原理
斷點(diǎn)是大家在調(diào)試程序時常用的一個功能,如break linenumber,當(dāng)執(zhí)行到linenumber那一行的時候被調(diào)試程序會停止,等待debugger的進(jìn)一步操作。
斷點(diǎn)的實(shí)現(xiàn)原理,就是在指定的位置插入斷點(diǎn)指令,當(dāng)被調(diào)試的程序運(yùn)行到斷點(diǎn)的時候,產(chǎn)生SIGTRAP信號。該信號被gdb捕獲并進(jìn)行斷點(diǎn)命中判定,當(dāng)gdb判斷出這次SIGTRAP是斷點(diǎn)命中之后就會轉(zhuǎn)入等待用戶輸入進(jìn)行下一步處理,否則繼續(xù)。
斷點(diǎn)的設(shè)置原理: 在程序中設(shè)置斷點(diǎn),就是先將該位置的原來的指令保存,然后向該位置寫入int 3。當(dāng)執(zhí)行到int 3的時候,發(fā)生軟中斷,內(nèi)核會給子進(jìn)程發(fā)出SIGTRAP信號,當(dāng)然這個信號會被轉(zhuǎn)發(fā)給父進(jìn)程。然后用保存的指令替換int3,等待恢復(fù)運(yùn)行。
斷點(diǎn)命中判定:gdb把所有的斷點(diǎn)位置都存放在一個鏈表中,命中判定即把被調(diào)試程序當(dāng)前停止的位置和鏈表中的斷點(diǎn)位置進(jìn)行比較,看是斷點(diǎn)產(chǎn)生的信號,還是無關(guān)信號。

3.3 單步跟蹤原理
單步跟蹤就是指在調(diào)試程序的時候,讓程序運(yùn)行一條指令/語句后就停下。GDB中常用的命令有next, step, nexti, stepi。單步跟蹤又常分為語句單步(next, step)和指令單步(如nexti, stepi)。

在linux上,指令單步可以通過ptrace來實(shí)現(xiàn)。調(diào)用ptrace(PTRACE_SINGLESTEP,pid,...)可以使被調(diào)試的進(jìn)程在每執(zhí)行完一條指令后就觸發(fā)一個SIGTRAP信號,讓GDB運(yùn)行。下面來看一個例子:
    child = fork();
    if(child == 0) {
         execl("./HelloWorld", "HelloWorld", NULL);
    }
    else {
        ptrace(PTRACE_ATTACH,child,NULL,NULL);
        while(1){
        wait(&val);
        if(WIFEXITED(val))
            break;
        count++;
        ptrace(PTRACE_SINGLESTEP,child,NULL,NULL);
        }
    printf("Total Instruction number= %d\n",count);
    }
這 段程序比較簡單,子進(jìn)程調(diào)用execve執(zhí)行HelloWorld,而父進(jìn)程則先調(diào)用ptrace(PTRACE_ATTACH,pid,...)建立與 子進(jìn)程的跟蹤關(guān)系。然后調(diào)用ptrace(PTRACE_SINGLESTEP, pid, ...)讓子進(jìn)程一步一停,以統(tǒng)計(jì)子進(jìn)程一共執(zhí)行了多少條指令(你會發(fā)現(xiàn)一個簡單的HelloWorld實(shí)際上也執(zhí)行了好幾萬條指令才完成)。當(dāng)然你也完 全可以在這個時候查看EIP寄存器中存放的指令,或者某個變量的值,當(dāng)然前提是你得知道這個變量在子進(jìn)程內(nèi)存鏡像中的位置。
指令單步可以依靠硬件 完成,如x86架構(gòu)處理器支持單步模式(通過設(shè)置EFLAGS寄存器的TF標(biāo)志實(shí)現(xiàn)),每執(zhí)行一條指令,就會產(chǎn)生一次異常(在Intel 80386以上的處理器上還提供了DRx調(diào)試寄存器以用于軟件調(diào)試)。也可以通過軟件完成,即在每條指令后面都插入一條斷點(diǎn)指令,這樣每執(zhí)行一條指令都會 產(chǎn)生一次軟中斷。
語句單步基于指令單步實(shí)現(xiàn),即GDB算好每條語句所對應(yīng)的指令,從什么地方開始到什么地方結(jié)束。然后在結(jié)束的地方插入斷點(diǎn),或者指令單步一步一步的走到結(jié)束點(diǎn),再進(jìn)行處理。

當(dāng) 然gdb的實(shí)現(xiàn)遠(yuǎn)比今天我們所說的內(nèi)容要復(fù)雜,它能讓我們很容易的監(jiān)測,修改被調(diào)試的進(jìn)程,比如通過行號,函數(shù)名,變量名。而要真正實(shí)現(xiàn)這些,一是需要在 編譯的時候提供足夠的信息,如在gcc時加入-g選項(xiàng),這樣gcc會把一些程序信息放到生成的ELF文件中,包括函數(shù)符號表,行號,變量信息,宏定義等, 以便日后gdb調(diào)試,當(dāng)然生成的文件也會大一些。二是需要我們對ELF文件格式,進(jìn)程的內(nèi)存鏡像(布局)以及程序的指令碼十分熟悉。這樣才能保證在正確的 時機(jī)(斷點(diǎn)發(fā)生?單步?)找到正確的內(nèi)存地址(代碼?數(shù)據(jù)?)并鏈接回正確的程序代碼(這是哪個變量?程序第幾行?)。感興趣的同學(xué)可以找到相應(yīng)的代碼仔 細(xì)分析一下。

小結(jié):
ptrace可以實(shí)時監(jiān)測和修改另一個進(jìn)程的運(yùn)行,它是如此的強(qiáng)大以至于曾經(jīng)因?yàn)樗趗nix-like平臺 (如Linux, *BSD)上產(chǎn)生了各種漏洞。但換言之,只要我們能掌握它的使用,就能開發(fā)出很多以前在用戶態(tài)下不可能實(shí)現(xiàn)的應(yīng)用。當(dāng)然這可能需要我們掌握編譯,文件格 式,程序內(nèi)存布局等相當(dāng)多的底層知識。

最后讓我們來回顧一下ptrace的使用:
1)用PTRACE_ATTACH或者PTRACE_TRACEME 建立進(jìn)程間的跟蹤關(guān)系。
2)PTRACE_PEEKTEXT, PTRACE_PEEKDATA, PTRACE_PEEKUSR等讀取子進(jìn)程內(nèi)存/寄存器中保留的值。
3)PTRACE_POKETEXT, PTRACE_POKEDATA, PTRACE_POKEUSR等把值寫入到被跟蹤進(jìn)程的內(nèi)存/寄存器中。
4)用PTRACE_CONT,PTRACE_SYSCALL, PTRACE_SINGLESTEP控制被跟蹤進(jìn)程以何種方式繼續(xù)運(yùn)行。
5)PTRACE_DETACH, PTRACE_KILL 脫離進(jìn)程間的跟蹤關(guān)系。

TIPS:
    1. 進(jìn)程狀態(tài)TASK_TRACED用以表示當(dāng)前進(jìn)程因?yàn)楸桓高M(jìn)程跟蹤而被系統(tǒng)停止。
    2. 如在子進(jìn)程結(jié)束前,父進(jìn)程結(jié)束,則trace關(guān)系解除。
    3. 利用attach建立起來的跟蹤關(guān)系,雖然ps看到雙方為父子關(guān)系,但在"子進(jìn)程"中調(diào)用getppid()仍會返回原來的父進(jìn)程id。
    4. 不能attach到自己不能跟蹤的進(jìn)程,如non-root進(jìn)程跟蹤root進(jìn)程。
    5. 已經(jīng)被trace的進(jìn)程,不能再次被attach。
    6. 即使是用PTRACE_TRACEME建立起來的跟蹤關(guān)系,也可以用DETACH的方式予以解除。
    7. 因?yàn)檫M(jìn)入/退出系統(tǒng)調(diào)用都會觸發(fā)一次SIGTRAP,所以通常的做法是在第一次(進(jìn)入)的時候讀取系統(tǒng)調(diào)用的參數(shù),在第二次(退出)的時候讀取系統(tǒng)調(diào)用的返回值。但注意execve是個例外。
    8. 程序調(diào)試時的斷點(diǎn)由int 3設(shè)置完成,而單步跟蹤則可由ptrace(PTRACE_SINGLESTEP)實(shí)現(xiàn)。
   
Pthread 08/01/14

原文地址:http://blog.csdn.net/Javadino/archive/2008/09/06/2891434.aspx

posted on 2009-07-25 17:56 葉子 閱讀(1476) 評論(0)  編輯 收藏 引用 所屬分類: Unix

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品私人影院| 免费成人高清视频| 精品动漫一区| 国产一区二区福利| 国产一级久久| 精品电影一区| 亚洲人成小说网站色在线| 亚洲欧洲精品一区| 99视频有精品| 亚洲免费视频网站| 久久久国产精品一区二区三区| 久久久久久久999精品视频| 老鸭窝91久久精品色噜噜导演| 蜜臀久久久99精品久久久久久 | 久久久久久亚洲综合影院红桃| 久久精品日韩| 亚洲成色精品| 亚洲精品一区二区在线| 国产精品99久久久久久人| 欧美在线精品免播放器视频| 欧美xx视频| 国产亚洲精品久久久久久| 亚洲人成网站色ww在线| 午夜天堂精品久久久久| 欧美激情乱人伦| 亚洲欧美日韩中文视频| 免费视频一区二区三区在线观看| 国产精品久久久久av| 亚洲国产日韩欧美在线图片| 亚洲欧美日本视频在线观看| 欧美国产高潮xxxx1819| 亚洲自拍偷拍一区| 欧美成人国产| 永久久久久久| 久久精品亚洲乱码伦伦中文| 亚洲精品影视| 老牛国产精品一区的观看方式| 国产精品久久久久久久久久久久| 亚洲国产欧美国产综合一区| 久久成人精品无人区| 艳女tv在线观看国产一区| 女生裸体视频一区二区三区| 欧美性大战久久久久久久蜜臀| 国产亚洲成精品久久| 一区二区三区日韩精品| 欧美成人免费全部| 久久成人国产精品| 国产精品欧美久久| 在线综合亚洲| 亚洲免费电影在线| 欧美成人黄色小视频| 红桃视频欧美| 免费看av成人| 久久久综合香蕉尹人综合网| 国内在线观看一区二区三区| 久久av一区| 欧美制服丝袜| 黑人巨大精品欧美一区二区| 久久av资源网站| 亚洲欧美综合国产精品一区| 国产精品私人影院| 久久狠狠一本精品综合网| 亚洲女人天堂成人av在线| 国产精品国产自产拍高清av| 亚洲欧美精品suv| 亚洲男人的天堂在线| 国产精品日韩欧美一区二区三区 | 久久精品国产亚洲aⅴ| 亚洲一区综合| 国产午夜一区二区三区| 久久久激情视频| 久久躁日日躁aaaaxxxx| 亚洲精品免费一区二区三区| 亚洲麻豆国产自偷在线| 欧美日韩日本国产亚洲在线 | 亚洲一区国产| 午夜精品成人在线| 红桃视频欧美| 亚洲人成人77777线观看| 欧美色图麻豆| 久久久激情视频| 欧美大胆成人| 亚洲欧美成人网| 久久久www| 一二三四社区欧美黄| 亚洲桃花岛网站| 伊人成人开心激情综合网| 亚洲国产一区二区在线| 国产精品美女www爽爽爽| 久久久一本精品99久久精品66| 蜜桃久久精品乱码一区二区| 日韩一区二区精品葵司在线| 亚洲一二区在线| 亚洲电影在线观看| 亚洲色无码播放| 狠狠色综合日日| 99视频精品免费观看| 国内一区二区三区| 99国内精品| 久久久噜噜噜久久| 国产亚洲精品aa午夜观看| 欧美一区二区成人| 久久婷婷麻豆| 日韩一级精品| 欧美在线播放视频| 洋洋av久久久久久久一区| 亚洲欧美激情四射在线日 | 亚洲成人在线网| 一区二区三区视频观看| 精品动漫3d一区二区三区免费| 亚洲人成小说网站色在线| 国产亚洲视频在线| 宅男噜噜噜66一区二区| 亚洲激情社区| 久久久久久日产精品| 新狼窝色av性久久久久久| 欧美黄网免费在线观看| 美女脱光内衣内裤视频久久网站| 国产精品久久久久一区二区三区| 91久久在线播放| 亚洲欧洲三级电影| 久久久久久高潮国产精品视| 亚洲欧美激情视频| 欧美日韩情趣电影| 亚洲第一精品夜夜躁人人躁| 韩国一区电影| 久久精品亚洲国产奇米99| 久久国产精品网站| 国产精品女同互慰在线看| 一区二区三区欧美视频| 一区二区三区不卡视频在线观看 | 午夜视频在线观看一区二区三区| 日韩系列在线| 免费亚洲电影在线观看| 米奇777在线欧美播放| 国产综合久久| 久久精品最新地址| 久久深夜福利| 激情亚洲成人| 久久综合久久综合九色| 欧美顶级少妇做爰| 亚洲裸体俱乐部裸体舞表演av| 美女精品在线| 亚洲人精品午夜在线观看| 一区二区三区四区五区视频| 欧美日韩在线观看一区二区| 日韩视频永久免费| 亚洲欧美日韩网| 国产午夜精品久久久久久免费视| 亚洲欧美日韩国产另类专区| 久久久综合免费视频| 国产亚洲精品综合一区91| 亚洲精品国产精品国自产观看浪潮 | 亚洲国产一区二区视频| 免费成人激情视频| 欧美第一黄色网| 亚洲精品免费观看| 欧美性猛交xxxx乱大交退制版| 亚洲视频1区| 久久久精品国产免费观看同学| 国内成人精品一区| 男女精品视频| 夜夜嗨av一区二区三区中文字幕 | 欧美91福利在线观看| 日韩亚洲欧美精品| 欧美在线日韩在线| 亚洲国产福利在线| 欧美日产国产成人免费图片| 亚洲免费在线播放| 欧美高清视频一区二区三区在线观看| 亚洲精品日产精品乱码不卡| 国产精品va在线| 久久人人九九| 亚洲一区二三| 亚洲高清不卡av| 香蕉久久夜色精品| 亚洲人www| 国产日韩欧美另类| 欧美精品久久久久a| 性色av香蕉一区二区| 亚洲黄网站黄| 久久久久综合网| 亚洲欧美国产va在线影院| 亚洲第一黄网| 国产亚洲成av人片在线观看桃 | 亚洲激情在线观看视频免费| 国产精品免费观看在线| 欧美成人a视频| 久久精品中文字幕一区| 中文一区二区| 亚洲国产精品久久久| 久久久久久亚洲精品中文字幕| 亚洲图片在区色| 亚洲另类在线一区| 激情久久久久久久久久久久久久久久| 欧美性天天影院| 欧美日韩一区二区三区免费看| 欧美91大片| 蜜臀av性久久久久蜜臀aⅴ四虎| 午夜精品婷婷|