• Linux驱动调试之printk的使用


    目录

    1 printk使用方法1----宏定义控制是否打印

    2 printk使用方法2----在用户空间修改内核打印级别console_loglevel

    3 printk使用方法3----在启动参数中设置loglevel从而修改内核打印级别console_loglevel

    4 printk使用方法4----在启动参数中设置debug或quiet从而修改内核打印级别console_loglevel


    1 printk使用方法1----宏定义控制是否打印

    我们以第一个驱动程序,点灯的驱动为例看一下printk的使用,我们把之前的程序改成错误的(驱动程序里面要使用ioremap,如果不ioremap,直接使用物理地址会报错),

     把驱动程序和测试程序重新编译一下,然后把ko文件和测试程序拷贝到网络文件系统那里去。

    cp *.ko firstdrvtest /sork/nfs_root/first_fs

    然后insmod我们的驱动程序之后,运行测试程序,直接崩溃了,然后开始增加打印调试

    然后把驱动程序重新编译,然后想把之前的驱动卸载掉,发现卸载不了了。

     这是因为之前的驱动程序崩溃了,崩溃之后就一直占用驱动,这时候reboot重启开发板,然后再insmod,

     然后测试

     26行打印出来了,28行没有打印出来,那说明27行访问的地址不对,访问了非法地址,这是因为我们前面改错的地方,gpfcon的地址没有做ioremap。

    另外,当我们调试完之后,想把这些打印去掉,那么我们可以把宏定义改为空

    1. //#define DBG_PRINTK printk
    2. #define DBG_PRINTK(x...) //...表示可变参数

    2 printk使用方法2----在用户空间修改内核打印级别console_loglevel

    上面的方法,当我们调试完之后,如果想去掉打印,需要修改代码并且重新编译程序,如果想不编译程序,那我们也可以使用打印级别来控制是否打印。

    我们代码中使用printk的时候,加上打印级别

     然后我们前面分析过,printk只有当打印级别够了的时候才会打印

     然后我们重新编译发现没有打印,是因为KERN_DEBUG的级别是7,它没有小于console_loglevel. 这个level我们可以修改

     我们改一下打印机别,然后再次尝试,发现可以打印出来

    3 printk使用方法3----在启动参数中设置loglevel从而修改内核打印级别console_loglevel

    一上电的时候,我们内核打印了很多启动信息,而这些信息都是用串口打印的,而串口又比较慢,这样会导致开机时间慢,那么我们怎么把打印信息全都去掉,我们前面说的设置打印等级是等系统启动之后用某个命令来修改她的打印级别,能不能一开始就来修改它呢。

    我们在内核的Documentation中找到kernel-parameters.txt文档,然后可以去内核中搜索loglevel=

     然后这个值就赋给了console_loglevel,这个变量就是打印函数里面的那个

     试验一下,

     发现所有的启动打印信息都没有了。

    当然这时候用dmesg还是可以看到的,因为这些打印信息兵分两路,一路放在log_buf里面,一路是打印出来了。

    4 printk使用方法4----在启动参数中设置debug或quiet从而修改内核打印级别console_loglevel

     还可以设置debug或者quiet,其中debug参数是设置console_loglevel为10,quiet参数是设置console_loglevel为4.

  • 相关阅读:
    Revel敏捷后台开发框架
    LabVIEW开发低成本静脉监测和控制输液系统
    SpringBoot 整合 ActiveMQ、RabbitMQ(direct、topic模式)、RocketMQ详解代码示例
    spring基本使用
    C语言入门
    Vue中的过滤器 Filters
    21天算法打卡系列(6)——冒泡排序和快速排序
    leetcode-两数之和
    【C++】设计模式简介
    lintcode 1646 · 合法组合【字符串DFS, vip 中等 好题】
  • 原文地址:https://blog.csdn.net/u013171226/article/details/126009946