校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核的調(diào)試技術(shù)筆記整理

Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核的調(diào)試技術(shù)筆記整理

熱門標(biāo)簽:外呼系統(tǒng)不彈窗 申請(qǐng)400電話價(jià)格多少 安陽(yáng)ai電銷機(jī)器人軟件 廈門營(yíng)銷外呼系統(tǒng)平臺(tái) 涪陵商都400電話開(kāi)通辦理 外呼系統(tǒng)的經(jīng)營(yíng)范圍 智能電話機(jī)器人坐席 柳州市機(jī)器人外呼系統(tǒng)報(bào)價(jià) 云會(huì)外呼系統(tǒng)
/******************
 * 內(nèi)核的調(diào)試技術(shù)
 ******************/

(1)內(nèi)核源代碼中的一些與調(diào)試相關(guān)的配置選項(xiàng)

內(nèi)核的配置選項(xiàng)中包含了一些與內(nèi)核調(diào)試相關(guān)的選項(xiàng),都集中在"kernel hacking"菜單中。包括:

CONFIG_DEBUG_KERNEL

使其他的調(diào)試選項(xiàng)可用,應(yīng)該選中,其本身不會(huì)打開(kāi)所有的調(diào)試功能。

具體的調(diào)試選項(xiàng)說(shuō)明可參見(jiàn)驅(qū)動(dòng)一書,或通過(guò)menuconfig的help說(shuō)明查看。

(2)如何通過(guò)宏對(duì)printk調(diào)試語(yǔ)句進(jìn)行全局控制

通過(guò)和Makefile配合,可以在c文件中定義屬于我們自己的調(diào)試語(yǔ)句。

(3)strace的使用

strace可以跟蹤由用戶空間程序所發(fā)出的所有系統(tǒng)調(diào)用。有用的參數(shù)有:

  • -t  顯示調(diào)用發(fā)生的時(shí)間
  • -T  顯式調(diào)用所花費(fèi)的時(shí)間
  • -e  限定被跟蹤的系統(tǒng)調(diào)用類型,如"-e execve"
  • -f  跟蹤所有子進(jìn)程
  • -p  跟蹤特定進(jìn)程。如"-p 8856"
  • -o  將輸出的信息導(dǎo)入特定的文件

strace對(duì)于發(fā)現(xiàn)系統(tǒng)調(diào)用時(shí)的細(xì)微錯(cuò)誤非常有用,尤其是針對(duì)多進(jìn)程的程序,可以通過(guò)strace輸出的返回值和進(jìn)程pid獲得大量有用信息。如:

$>strace -o zht.txt -f ./process_create

(4)ltrace的使用

ltrace可以跟蹤由用戶空間程序所發(fā)出的所有動(dòng)態(tài)庫(kù)函數(shù)調(diào)用。有用的參數(shù)有:

  • -t  顯示調(diào)用發(fā)生的時(shí)間
  • -T  顯式調(diào)用所花費(fèi)的時(shí)間
  • -f  跟蹤所有子進(jìn)程
  • -p  跟蹤特定進(jìn)程
  • -o  將輸出的信息導(dǎo)入特定的文件

(5)查看oops消息

oops是內(nèi)核告知用戶有不幸發(fā)生的最常用方式。通常,發(fā)送完oops后,內(nèi)核會(huì)處于一種不穩(wěn)定狀態(tài)。

在某些情況下,oops會(huì)導(dǎo)致內(nèi)核混亂,而混亂的結(jié)果就是死機(jī),這些情況可能包括:

  • *oops發(fā)生在持有鎖的代碼中
  • *oops發(fā)生在和硬件設(shè)備通訊的過(guò)程中
  • *oops在中斷上下文中發(fā)生
  • *oops發(fā)生在idle進(jìn)程(0)或init進(jìn)程(1),因?yàn)閮?nèi)核沒(méi)有這兩個(gè)進(jìn)程沒(méi)法工作

如果oops在其他進(jìn)程運(yùn)行時(shí)發(fā)生,內(nèi)核會(huì)殺死該進(jìn)程并嘗試著繼續(xù)運(yùn)行。oops的產(chǎn)生有很多原因,包括內(nèi)存訪問(wèn)越界或非法指令等。

oops包含的最重要訊息是寄存器上下文和回溯線索(call trace)可以人為引起oops,如:

if(bad_thing)
 BUG();
//或 BUG_ON(bad_thing);

可以用panic()引發(fā)更嚴(yán)重的錯(cuò)誤,調(diào)用panic()不但會(huì)打印錯(cuò)誤信息,還會(huì)掛起整個(gè)系統(tǒng)。只有在極端惡劣的情況下才會(huì)使用:

if(terrible_thing)
 panic("foo is %ld!\n", foo);

有些時(shí)候,只要打印一下棧信息就可以幫助測(cè)試,如dump_stack():

 if(!debug_check){
  printk(KERNEL_DEBUG "provide some info\n");
  dump_stack();
 }

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

標(biāo)簽:巴中 晉城 蕪湖 南充 福州 孝感 綏化 撫順

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核的調(diào)試技術(shù)筆記整理》,本文關(guān)鍵詞  Linux,內(nèi)核,設(shè)備驅(qū)動(dòng),之,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核的調(diào)試技術(shù)筆記整理》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核的調(diào)試技術(shù)筆記整理的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 定日县| 达尔| 新河县| 郴州市| 宜城市| 应用必备| 兴安县| 吉木乃县| 沙河市| 长沙县| 丰都县| 肇庆市| 大田县| 三江| 峨边| 信宜市| 钟山县| 乌拉特后旗| 禹城市| 青岛市| 陆良县| 台州市| 台南县| 汉阴县| 北辰区| 昌邑市| 同江市| 鄂托克旗| 陵水| 济源市| 武山县| 沭阳县| 柘荣县| 公安县| 久治县| 涞源县| 驻马店市| 双流县| 班玛县| 乌兰浩特市| 芦山县|