• <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>
            posts - 297,  comments - 15,  trackbacks - 0

            GDB多線程調試的基本命令。

            info threads
            顯示當前可調試的所有線程,每個線程會有一個GDB為其分配的ID,后面操作線程的時候會用到這個ID。
            前面有*的是當前調試的線程。

            thread ID
            切換當前調試的線程為指定ID的線程。

            break thread_test.c:123 thread all
            在所有線程中相應的行上設置斷點

            thread apply ID1 ID2 command
            讓一個或者多個線程執行GDB命令command。

            thread apply all command
            讓所有被調試線程執行GDB命令command。

            set scheduler-locking off|on|step
            估計是實際使用過多線程調試的人都可以發現,在使用step或者continue命令調試當前被調試線程的時候,其他線程也是同時執行的,怎么只讓被調試程序執行呢?通過這個命令就可以實現這個需求。
            off 不鎖定任何線程,也就是所有線程都執行,這是默認值。
            on 只有當前被調試程序會執行。
            step 在單步的時候,除了next過一個函數的情況(熟悉情況的人可能知道,這其實是一個設置斷點然后continue的行為)以外,只有當前線程會執行。

            在介紹完基本的多線程調試命令后,大概介紹一下GDB多線程調試的實現思路。

            比較主要的代碼是thread.c,前面介紹的幾個命令等都是在其中實現。
            thread_list這個表存儲了當前可調試的所有線程的信息。
            函數add_thread_silent或者add_thread(不同版本GDB不同)用來向thread_list列表增加一個線程的信息。
            函數delete_thread用來向thread_list列表刪除一個線程的信息。
            上面提到的這2個函數會被有線程支持的target調用,用來增加和刪除線程,不同的OS對線程的實現差異很大,這么實現比較好的保證了GDB多線程調試支持的擴展性。
            函數info_threads_command是被命令info threads調用的,就是顯示thread_list列表的信息。
            函數thread_command是被命令thread調用,切換當前線程最終調用的函數是switch_to_thread,這個函數會先將當前調試線程變量inferior_ptid,然后對寄存器和frame緩沖進行刷新。
            函數thread_apply_command被命令thread apply調用,這個函數的實際實現其實很簡單,就是先切換當前線為指定線程,然后調用函數execute_command調用指定函數。

            比較特別的是set scheduler-locking沒有實現在thread.c中,而是實現在控制被調試程序執行的文件infrun.c中。
            對 其的設置會保存到變量scheduler_mode中,而實際使用這個變量的函數只有用來令被調試程序執行的函數resume。在默認情況下, 傳遞給target_resume的變量是resume_ptid,默認情況下其的值為RESUME_ALL,也就是告訴target程序執行的時候所有 被調試線程都要被執行。而當scheduler_mode設置為只讓當前線程執行的時候,resume_ptid將被設置為inferior_ptid, 這就告訴target只有inferior_ptid的線程會被執行。

            最后特別介紹一下Linux下多線程的支持,基本的調試功能在linux-nat.c中,這里有對Linux輕量級別進程本地調試的支持。但是其 在調試多線程程序的時候,還需要對pthread調試的支持,這個功能實現在linux-thread-db.c中。對pthread的調試要通過調用 libthread_db庫來支持。
            這里有一個單獨的target"multi-thread",這個target有2點很特別:
            第 一,一般target的裝載是在調用相關to_open函數的時候調用push_target進行裝載。而這個target則不同,在其初始化 的時候,就注冊了函數thread_db_new_objfile到庫文件attach事件中。這樣當GDB為調試程序的動態加載庫時候attach庫文 件的時候,就會調用這個函數thread_db_new_objfile。這樣當GDB裝載libpthread庫的時候,最終會裝載 target"multi-thread"。
            第二,這個target并沒有像大部分target那樣自己實現了全部調試功能,其配合linux-nat.c的代碼的功能,這里有一個target多層結構的設計,要介紹的比較多,就不詳細介紹了。


            最后介紹一下我最近遇見的一個多線程調試和解決。

            基本問題是在一個Linux環境中,調試多線程程序不正常,info threads看不到多線程的信息。
            我先用命令 maintenance print target-stack看了一下target的裝載情況,發現target"multi-thread"沒有被裝載,用GDB對GDB進行調試,發現在 函數check_for_thread_db在調用libthread_db中的函數td_ta_new的時候,返回了TD_NOLIBTHREAD,所 以沒有裝載target"multi-thread"。
            在時候我就懷疑是不是libpthread有問題,于是檢查了一下發現了問題,這個環 境中的libpthread是被strip過的,我想可能 就是以為這個影響了td_ta_new對libpthread符號信息的獲取。當我換了一個沒有strip過的libpthread的時候,問題果然解決 了。
            最終我的解決辦法是拷貝了一個.debug版本的libpthread到lib目錄中,問題解決了。  多線程如果dump,多為段錯誤,一般都涉及內存非法讀寫??梢赃@樣處理,使用下面的命令打開系統開關,讓其可以在死掉的時候生成core文件。  
            ulimit -c unlimited
            這樣的話死掉的時候就可以在當前目錄看到core.pid(pid為進程號)的文件。接著使用gdb:
            gdb ./bin ./core.pid
            進去后,使用bt查看死掉時棧的情況,在使用frame命令。

            還有就是里面某個線程停住,也沒死,這種情況一般就是死鎖或者涉及消息接受的超時問題(聽人說的,沒有遇到過)。遇到這種情況,可以使用:
            gcore pid (調試進程的pid號)
            手動生成core文件,在使用pstack(linux下好像不好使)查看堆棧的情況。如果都看不出來,就仔細查看代碼,看看是不是在if,return,break,continue這種語句操作是忘記解鎖,還有嵌套鎖的問題,都需要分析清楚了。


            from:

            http://blog.chinaunix.net/u3/91335/showart.php?id=2249238

            posted on 2010-08-20 17:16 chatler 閱讀(580) 評論(0)  編輯 收藏 引用 所屬分類: Linux_Coding
            <2010年8月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(10)

            隨筆分類(307)

            隨筆檔案(297)

            algorithm

            Books_Free_Online

            C++

            database

            Linux

            Linux shell

            linux socket

            misce

            • cloudward
            • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

            network

            OSS

            • Google Android
            • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
            • os161 file list

            overall

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            中文字幕久久欲求不满| 久久久精品2019免费观看| 国产精品成人99久久久久 | 久久精品国产亚洲AV不卡| 精品久久久久久国产免费了| 久久久久久噜噜精品免费直播| 人人妻久久人人澡人人爽人人精品| 亚洲色欲久久久综合网| 久久成人国产精品一区二区| 亚洲精品高清一二区久久| 97久久精品人妻人人搡人人玩| 日韩电影久久久被窝网| 东京热TOKYO综合久久精品| 久久久久九国产精品| 精品国产一区二区三区久久久狼| 国内精品久久久久久久coent| 午夜精品久久久久久99热| 精品国产一区二区三区久久蜜臀| 久久久久久人妻无码| 中文字幕无码av激情不卡久久 | 美女写真久久影院| 狠狠色婷婷久久综合频道日韩| 91久久香蕉国产熟女线看| 韩国免费A级毛片久久| 伊人久久大香线蕉av不变影院| 久久久无码精品午夜| 久久久久中文字幕| 久久精品国产亚洲AV嫖农村妇女 | 久久久网中文字幕| 久久免费视频一区| 久久精品无码免费不卡| 精品久久人人爽天天玩人人妻| 国产一级持黄大片99久久| 久久亚洲AV成人出白浆无码国产| 国产69精品久久久久久人妻精品| 2021国产精品久久精品| 久久人妻AV中文字幕| 色欲av伊人久久大香线蕉影院| 777午夜精品久久av蜜臀| 欧美大香线蕉线伊人久久| 久久久老熟女一区二区三区|