動態輸出可以動態選擇打開某個內核子系統的輸出,可以有選擇性地打開某些模塊的輸出。
配置內核編譯選項要使用動態輸出,必須在配置內核時打開CONFIG_DYNAMIC_DEBUG宏。內核代碼里使用大量pr_debug()/dev_dbg()函數來輸出信息,這些就使用了動態輸出。
需要打開的內核配置選項:
CONFIG_DEBUG_FS=yCONFIG_DYNAMIC_DEBUG=y
CONFIG_DYNAMIC_DEBUG是配置動態輸出,它依賴于CONFIG_DEBUG_FS,而CONFIG_DEBUG_FS是debugfs文件系統。
打開內核配置后,我們還需要掛載debugfs文件系統。
debugfs文件系統掛載動態輸出在debugfs文件系統中有一個control文件節點,這個文件節點記錄了系統中所有使用動態輸出技術的文件名路徑、輸出所在的行號、模塊名字和要輸出的語句。
debugfs默認會掛載到/sys/kernel/debug,如果沒有掛載,可以執行以下命令掛載:
mount -t debugfs none /sys/kernel/debug/
掛載debugfs文件系統后,可以查看control節點內容:
cat /sys/kernel/debug/dynamic_debug/control
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
相關推薦
很多內核開發者喜歡的調試工具是printk,在Linux內核中,使用printk()函數來打印信息,它與C庫的printf()函數類似。
發表于 06-01 15:14
?1168次閱讀
上篇說到printk調試,但printk是全局的,只能設置輸出等級。而動態輸出可以動態選擇打開某個內核
發表于 06-01 15:16
?549次閱讀
問個問題,怎么調試linux內核,百度了一下,結果還是不會使用gdb調試內核。希望大蝦幫忙指點一下。
發表于 02-25 07:32
現有的嵌入式LINUX系統開發過程中,所有的工程師都疲憊于使用兩種不同的調試模式分別調試系統的內核和應用程序。首先通過一個JTAG調試工具來
發表于 11-06 11:00
?0次下載
了解如何配置和使用Linux內核printk功能,包括其動態調試功能。
這樣可以選擇性地打印調試消息,而無需重新編譯
發表于 11-27 06:40
?3104次閱讀
內核開發比用戶空間開發更難的一個因素就是內核調試艱難。內核錯誤往往會導致系統宕機,很難保留出錯時的現場。調試
發表于 05-07 11:01
?2345次閱讀
Linux:QEMU調試內核的步驟
發表于 06-23 09:03
?3161次閱讀
在Linux下的開發中,printf打印調試信息默認輸出到標準輸出 stdout (即屏幕/終端)中。我們也可以使用輸出重定向技術
發表于 11-04 16:40
?7448次閱讀
本文檔的主要內容詳細介紹的是嵌入式LINUX系統內核和內核模塊調試教程。
發表于 11-06 17:32
?21次下載
嵌入式LINUX系統內核和內核模塊調試(嵌入式開發和硬件開發)-嵌入式LINUX系統內核和
發表于 07-30 13:55
?10次下載
printk()是很多嵌入式開發者喜歡用的調試手段之一,但是,使用printk()每次都要重新編譯內核,很不方便。使用動態輸出在不需要重新編譯內核
發表于 01-06 10:46
?902次閱讀
內核總是那么捉摸不透, 內核也會犯錯, 但是調試卻不能像用戶空間程序那樣, 為此內核開發者為我們提供了一系列的工具和系統來支持內核的
發表于 02-20 17:56
?873次閱讀
內核總是那么捉摸不透, 內核也會犯錯, 但是調試卻不能像用戶空間程序那樣, 為此內核開發者為我們提供了一系列的工具和系統來支持內核的
發表于 05-22 14:37
?1478次閱讀
動態輸出使用 打開svcsock.c文件中所有的動態輸出語句 # echo 'file svcsock.c +p' > /sys/ kernel /debug/ dynamic_deb
發表于 09-27 15:51
?499次閱讀
很多內核開發者喜歡的調試工具是printk,在Linux內核中,使用printk()函數來打印信息,它與C庫的printf()函數類似。 printk()與printf()的一個重要
發表于 09-27 16:09
?1065次閱讀
評論