• 慢慢学Linux驱动开发,第三篇,关于printk的输出总结


    参考一下这个: http://blogold.chinaunix.net/u3/111072/showart_2298170.html

     

    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() 将信息输出到 控制台而不是只是添加到日志文件中。 当你编写真正的实用的模块时,你应该针对可能遇到的情况使用合 适的优先级。

     

  • 相关阅读:
    <转>浅谈DNS体系结构:DNS系列之一
    SOA和NS区别
    《浅析各类DDoS攻击放大技术》
    《转》DNS放大攻击
    Linux创建公钥
    MATLAB 中有哪些命令,让人相见恨晚
    SQL中的declare用法
    SQl server 附加数据库失败如何解决
    VS中代码对齐等快捷键
    C#窗口控件Dock的位置顺序调整方法
  • 原文地址:https://www.cnblogs.com/pang123hui/p/2309908.html
Copyright © 2020-2023  润新知