將驅動中的printk資訊列印出來

2021-06-17 23:53:28 字數 2097 閱讀 8101

要將linux核心的帶級別控制的printk內容列印出來,在命令列 輸入 dmesg -n 8 就將所有級別的資訊都列印出來

linux命令:dmesg  功能說明:顯示開機資訊。

語 法:dmesg [-cn][-s 《緩衝區大小》]

補充說明:kernel會將開機資訊儲存在ring buffer中。您若是開機時來不及檢視資訊,可利用dmesg來檢視。開機資訊亦儲存在/var/log目錄中,名稱為dmesg的檔案裡。

參 數:

-c 顯示資訊後,清除ring buffer中的內容。

-s《緩衝區大小》 預設定為8196,剛好等於ring buffer的大小。

-n 設定記錄資訊的層級。

printk() 使用說明

核心通過 printk() 輸出的資訊具有日誌級別,日誌級別是通過在 printk() 輸出的字串前加乙個帶尖括號的整數來控制的,如 printk("<6>hello, world!/n");。核心中共提供了八種不同的日誌級別,在 linux/kernel.h 中有相應的巨集對應。

#define kern_emerg      "<0>"    /* system is unusable */   

#define kern_alert      "<1>"    /* action must be taken immediately */   

#define kern_crit       "<2>"    /* critical conditions */   

#define kern_err        "<3>"    /* error conditions */   

#define kern_warning    "<4>"    /* warning conditions */   

#define kern_notice     "<5>"    /* normal but significant */   

#define kern_info       "<6>"    /* informational */   

#define kern_debug      "<7>"    /* debug-level messages */ 

所以 printk() 可以這樣用:printk(kern_info "hello, world!/n");。

未指定日誌級別的 printk() 採用的預設級別是 default_message_loglevel,這個巨集在 kernel/printk.c 中被定義為整數 4,即對應kern_warning。

在 /proc/sys/kernel/printk 會顯示4個數值(可由 echo 修改),分別表示當前控制台日誌級別、未明確指定日誌級別的預設訊息日誌級別、最小(最高)允許設定的控制台日誌級別、引導時預設的日誌級別。當 printk() 中的訊息日誌級別小於當前控制台日誌級別時,printk 的資訊(要有/n符)就會在控制台上顯示。但無論當前控制台日誌級別是何值,通過/proc/kmsg (或使用dmesg)總能檢視。另外如果配置好並執行了 syslogd 或 klogd,沒有在控制台上顯示的 printk 的資訊也會追加到/var/log/messages.log 中。

通過讀寫/proc/sys/kernel/printk檔案可讀取和修改控制台的日誌級別。檢視這個檔案的方法如下:

#cat /proc/sys/kernel/printk

6 4 1 7

上面顯示的4個資料分別對應控制台日誌級別、預設的訊息日誌級別、最低的控制台日誌級別和預設的控制台日誌級別。

可用下面的命令設定當前日誌級別:

# echo 8 > /proc/sys/kernel/printk

另外為了防止 printk() 瞬時被呼叫次數過多,可以通過 printk_ratelimit() 來控制速度。printk_ratelimit() 通過跟蹤傳送到控制台的訊息數量工作,當輸出速度超過乙個臨界值,就返回零。可通過修改 /proc/sys/kernel/ 來調節 printk_ratelimit() 的計算。

printk_ratelimit() 的典型用法如下:

if (printk_ratelimit())

printk(kern_info "hello, world!/n");

printk資訊列印到指定檔案 終端 網路

有的時候除錯核心程式,經常要將資訊列印到其他地方如指定檔案或終端還有網路,網路的話dreanice版主寫過個netconsole我這裡就不說了.列印到檔案 include include include include include include include include include ...

將執行資訊列印日誌到檔案中

開發程式經常要從控制台當中獲取程式執行的情況,最近在開發在伺服器端,導師要求要記錄好執行資訊,包括異常資訊,客戶連線情況等資訊,但控制台 有種種限制,如視窗過小閱讀不方便,或者在伺服器上通過命令列執行jar包時的行數限制等等。於是就想到將執行資訊列印日誌到檔案中。接下來就分享一下這幾天研究出來的幾種...

調整核心printk的列印級別

有時除錯核心模組,列印資訊太多了,可以通過修改 proc sys kernel printk檔案內容來控制。預設設定是6 4 1 7 cat proc sys kernel printk 7 4 1 7 該檔案有四個數字值,它們根據日誌記錄訊息的重要性,定義將其傳送到何處。關於不同日誌級別的更多資訊...