慢慢学Linux驱动开发,第三篇,关于printk的输出总结
2011-04-01 08:45
363 查看
参考一下这个: http://blogold.chinaunix.net/u3/111072/showart_2298170.html
printk是内核态信息打印函数,功能和比准C库的printf类似。
printk还有信息打印级别。
函数原型:
需要的头文件:
消息打印级别:
fmt----消息级别:
不同级别使用不同字符串表示,数字越小,级别越高。
printk输出跟输出的日志级别有关系,当输出日志级别比控制台的级别高时,就会显示在控制台上,当比控制台低时,则会记录在/var/log
/message中.但是当系统同时运行了klogd和syslogd时,都追加到/var/log/message.在/proc/sys
/kernel/printk文件中,前两个整数为当前的日志级别和默认的日志级别(默认的日志级别即为printk的输出级别)。
注意:
/proc/sys/kernel/printk
该文件有四个数字值,它们根据日志记录消息的重要性,定义将其发送到何处。关于不同日志级别的更多信息,请阅读 syslog(2) 联机帮助页。该文件的四个值为:
控制台日志级别:优先级高于该值的消息将被打印至控制台
缺省的消息日志级别:将用该优先级来打印没有优先级的消息
最低的控制台日志级别:控制台日志级别可被设置的最小值(最高优先级)
缺省的控制台日志级别:控制台日志级别的缺省值
/proc/sys/kernel/printk
The four values in this file are console_loglevel, default_mes-
sage_loglevel, minimum_console_level and default_con-
sole_loglevel. These values influence printk() behavior when
printing or logging error messages. See syslog(2) for more info
on the different loglevels. Messages with a higher priority
than console_loglevel will be printed to the console. Messages
without an explicit priority will be printed with priority
default_message_level. minimum_console_loglevel is the minimum
(highest) value to which console_loglevel can be set.
default_console_loglevel is the default value for con-
sole_loglevel.
缺省设置:6 4 1 7
注意:
需要开启klogd和syslogd服务才能正常输出。通过klogd可以改变系统消息输出级别。
linux0.11为什么在内核态使用printk()函数,而在用户态使用printf()函数?
答:printk()函数是直接使用了向终端写函数tty_write()。而printf()函数是调用write()系统调用函数向标准输出设备写。
所以在用户态(如进程0)不能够直接使用printk()函数,而在内核态由于他已是特权级,所以无需系统调用来改变特权级,因而能够直接使用
printk()函数。
printk是内核输出,在终端是看不见的。
你可以看一下系统日志。/var/log/message
或者使用dmesg命令看一下。
使用Ctrl + Alt + T打开的终端是无法显示的,必须用Ctrl + Alt + F2—F6打开的终端才可以显示。
并不是设计用来同用户交互的,虽然我们在
hello-1
就是出于这样的目的使用它!它实际上是为内核提供日志功能,
记录内核信息或用来给出警告。因此,每个
声明都会带一个优先级,就像你看到的
<1>
和
KERN_ALERT
那样。内核总共定义了八个优先级的宏,
所以你不必使用晦涩的数字代码,并且你可以从文件
linux/kernel.h
查看这些宏和它们的意义。如果你
不指明优先级,默认的优先级
DEFAULT_MESSAGE_LOGLEVEL
将被采用。
阅读一下这些优先级的宏。头文件同时也描述了每个优先级的意义。在实际中,
使用宏而不要使用数字,就像
<4>
。总是使用宏,就像
KERN_WARNING
。
当优先级低于
int
console_loglevel
,信息将直接打印在你的终端上。如果同时
syslogd
和
klogd
都在运行,信息也同时添加在文件
/var/log/messages
,而不管是否显示在控制台上与否。我们使用像
KERN_ALERT
这样的高优先级,来确保
将信息输出到
控制台而不是只是添加到日志文件中。
当你编写真正的实用的模块时,你应该针对可能遇到的情况使用合
适的优先级。
printk是内核态信息打印函数,功能和比准C库的printf类似。
printk还有信息打印级别。
函数原型:
int printk(const char *fmt, ... |
#include <linux/kernel.h |
fmt----消息级别:
#define KERN_EMERG "<0>" #define KERN_ALERT "<1>" #define KERN_CRIT "<2>" #define KERN_ERR "<3>" #define KERN_WARNING "<4>" #define KERN_NOTICE "<5>" #define KERN_INFO "<6>" #define KERN_DEBUG "<7>" |
printk输出跟输出的日志级别有关系,当输出日志级别比控制台的级别高时,就会显示在控制台上,当比控制台低时,则会记录在/var/log
/message中.但是当系统同时运行了klogd和syslogd时,都追加到/var/log/message.在/proc/sys
/kernel/printk文件中,前两个整数为当前的日志级别和默认的日志级别(默认的日志级别即为printk的输出级别)。
注意:
/proc/sys/kernel/printk
该文件有四个数字值,它们根据日志记录消息的重要性,定义将其发送到何处。关于不同日志级别的更多信息,请阅读 syslog(2) 联机帮助页。该文件的四个值为:
控制台日志级别:优先级高于该值的消息将被打印至控制台
缺省的消息日志级别:将用该优先级来打印没有优先级的消息
最低的控制台日志级别:控制台日志级别可被设置的最小值(最高优先级)
缺省的控制台日志级别:控制台日志级别的缺省值
/proc/sys/kernel/printk
The four values in this file are console_loglevel, default_mes-
sage_loglevel, minimum_console_level and default_con-
sole_loglevel. These values influence printk() behavior when
printing or logging error messages. See syslog(2) for more info
on the different loglevels. Messages with a higher priority
than console_loglevel will be printed to the console. Messages
without an explicit priority will be printed with priority
default_message_level. minimum_console_loglevel is the minimum
(highest) value to which console_loglevel can be set.
default_console_loglevel is the default value for con-
sole_loglevel.
缺省设置:6 4 1 7
注意:
需要开启klogd和syslogd服务才能正常输出。通过klogd可以改变系统消息输出级别。
linux0.11为什么在内核态使用printk()函数,而在用户态使用printf()函数?
答:printk()函数是直接使用了向终端写函数tty_write()。而printf()函数是调用write()系统调用函数向标准输出设备写。
所以在用户态(如进程0)不能够直接使用printk()函数,而在内核态由于他已是特权级,所以无需系统调用来改变特权级,因而能够直接使用
printk()函数。
printk是内核输出,在终端是看不见的。
你可以看一下系统日志。/var/log/message
或者使用dmesg命令看一下。
使用Ctrl + Alt + T打开的终端是无法显示的,必须用Ctrl + Alt + F2—F6打开的终端才可以显示。
printk()
并不是设计用来同用户交互的,虽然我们在
hello-1
就是出于这样的目的使用它!它实际上是为内核提供日志功能,
记录内核信息或用来给出警告。因此,每个
printk()
声明都会带一个优先级,就像你看到的
<1>
和
KERN_ALERT
那样。内核总共定义了八个优先级的宏,
所以你不必使用晦涩的数字代码,并且你可以从文件
linux/kernel.h
查看这些宏和它们的意义。如果你
不指明优先级,默认的优先级
DEFAULT_MESSAGE_LOGLEVEL
将被采用。
阅读一下这些优先级的宏。头文件同时也描述了每个优先级的意义。在实际中,
使用宏而不要使用数字,就像
<4>
。总是使用宏,就像
KERN_WARNING
。
当优先级低于
int
console_loglevel
,信息将直接打印在你的终端上。如果同时
syslogd
和
klogd
都在运行,信息也同时添加在文件
/var/log/messages
,而不管是否显示在控制台上与否。我们使用像
KERN_ALERT
这样的高优先级,来确保
printk()
将信息输出到
控制台而不是只是添加到日志文件中。
当你编写真正的实用的模块时,你应该针对可能遇到的情况使用合
适的优先级。
相关文章推荐
- 慢慢学Linux驱动开发,第三篇,关于printk的输出总结
- 关于arm-linux驱动开发设计推荐博文
- linux驱动开发总结(一)
- 【Linux开发】linux设备驱动归纳总结(三):6.poll和sellct
- Linux USB 驱动开发(五)—— USB驱动程序开发过程简单总结
- linux驱动开发之多路复用poll+按键点灯+中断+标准输入输出
- 【原创】关于wince os开发面试的总结系列之驱动
- 【Linux开发】linux设备驱动归纳总结(七):2.内核定时器
- Linux USB 驱动开发(五)—— USB驱动程序开发过程简单总结
- Linux驱动开发中s3c2410关于gpio的内核导出函数的解读
- 【Linux开发】linux设备驱动归纳总结(八):1.总线、设备和驱动
- Linux内核与驱动开发学习总结:内核初始化宏__init(十二)
- 慢慢学Linux驱动开发,第八篇,LDD3中第三章scull注释详解
- 【Linux开发】linux设备驱动归纳总结(三):1.字符型设备之设备申请
- 【Linux开发】linux设备驱动归纳总结(三):7.异步通知fasync
- 【Linux开发】linux设备驱动归纳总结(八):2.总线、设备和驱动的关系
- 嵌入式linux驱动开发流程总结
- 慢慢学Linux驱动开发,第八篇,LDD3中第三章scull注释详解
- 【Linux开发】linux设备驱动归纳总结(三):2.字符型设备的操作open、close、read、write
- 【Linux开发】linux设备驱动归纳总结(八):3.设备管理的分层与面向对象思想