printklinux
① printf和printk的區別
printk與printf的一個區別printk是「行驅動」的,也就是說只有收到一個換行符數據才會真正輸出到終端,否則就不會有任何信息輸出。另一個值得注意的問題是我們在調試嵌入式設備的時候,經常是從串口獲得顯示信息,如果我們使用printk過於頻繁的話,串口的傳輸速度就會成為瓶頸,這樣會造成系統的性能下降甚至停止反應。
printf功 能:產生格式化輸出的函數
用 法:int printf(const char *format,[argument]);format 參數輸出的格式,定義格式為:%[flags][width][.perc][F|N|h|l]type
printk:
printk相當於printf的孿生姐妹,她們一個運行在用戶態,另一個則在內核態被人們所熟知。
補充:printf()函數是格式化輸出函數,一般用於向標准輸出設備按規定格式輸出信息。printf()函數的調用格式為:printf("<格式化字元串>",<參量表>)。格式輸出,它是c語言中產生格式化輸出的函數(在stdio.h中定義)。用於向終端(顯示器、控制台等)輸出字元。格式控制由要輸出的文字和數據格式說明組成。要輸出的的文字除了可以使用字母、數字、空格和一些數字元號以外,還可以使用一些轉義字元表示特殊的含義。
② 如何修改arm linux中Printk的等級
1、查看當前控制台的列印級別
cat /proc/sys/kernel/printk
4 4 1 7
其中第一個「4」表示內核列印函數printk的列印級別,只有級別比他高的信息才能在控制台上列印出來,既 0-3級別的信息
2、修改列印
echo "新的列印級別 4 1 7" >/proc/sys/kernel/printk
3、不夠列印級別的信息會被寫到日誌中可通過dmesg 命令來查看
4、printk的列印級別
#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 condition */
#define KERN_INFO "<6>" /* informational */
#define KERN_DEBUG "<7>" /* debug-level messages */
5、printk函數的使用
printk(列印級別 「要列印的信息」)
列印級別 既上面定義的幾個宏
③ 怎麼屏蔽Linux 內核中的printk 列印信息
echo 0 > /proc/sys/kernel/printk
將列印輸出的優先順序提高到最高
④ 急急急!!這個最簡單的linux內核的printk列印不出信息是怎麼回事
printk並不默認列印到終端,你載入進內核後,使用指令dmesg試試
⑤ 怎樣屏蔽linux內核printk( ) 列印信息
你好,可以採用以下的宏來集體打開或者關閉printk:
/*
* Macros to help debugging
*/
#undef PDEBUG /* 假設之前就有定義,先取消,初始化 */
#ifdef SCULL_DEBUG
#ifdef __KERNEL__
/* This one if debugging is on, and kernel space */
#define PDEBUG(fmt, args...) printk( KERN_DEBUG "scull: " fmt, ## args)
#else
/* This one for user space */
#define PDEBUG(fmt, args...) fprintf(stderr, fmt, ## args)
#endif
#else
# define PDEBUG(fmt, args...) /* not debugging: nothing */
#endif
#undef PDEBUGG
#define PDEBUGG(fmt, args...) /* nothing: it's a placeholder */
在編譯的時候,Makefile如下:
gcc -O -g -DSCULL_DEBUG -C $(KERNELDIR) M=$(shell pwd) moles
⑥ 為什麼內核printk列印不出來,printk在<linux/kernel.h>有這個函數,為什麼載入不到
首先,你編譯的東西是一個Linux內核模塊嗎?
printk函數通常只只在Linux內核或內核模塊中可用。
如果不是用在Linux內核中,你應該將printk替換成printf。
⑦ 嵌入式中printk的功能是什麼
對於做嵌入式或者熟悉linux內核的人來說,對printk這個函數一定不會感到陌生。printk相當於printf的孿生姐妹,她們一個運行在用戶態,另一個則在內核態被人們所熟知。
printk是在內核中運行的向控制台輸出顯示的函數,Linux內核首先在內核空間分配一個靜態緩沖區,作為顯示用的空間,然後調用sprintf,格式化顯示字元串,最後調用tty_write向終端進行信息的顯示
⑧ 如何查看linux printk
用dmesg -c命令查看列印信息。 ctrl+alt+F1 切換到純終端,可以在終端直接看到列印信息