linux dev_dbg输出

本文介绍了在使用SMBus进行调试时遇到的问题及解决方法。针对内核3.12.10中出现的Invalid argument错误,通过分析调试信息打印语句,最终采取直接修改文件的方式解决了调试过程中定位具体错误位置的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这几天在搞smbus(大致上算是阉割版的i2c吧),在调试的时候碰到了一个问题:

内核3.12.10

直接perror出来的调试错误信息,只会给你一个Invalid argument,但是在内核同一个函数中有好多地方都返回了EINVAL,根本不知道是错在哪儿


找方法解决:
发现返回之前会有一句

        dev_dbg(&client->adapter->dev,
            "size out of range (%x) in ioctl I2C_SMBUS.\n",
            data_arg.size);

应该是调试信息打印,目测无误。
开始想办法:
网上找到一些教程
大致有两类

  1. dynamic debug
    http://blog.youkuaiyun.com/fnjnash/article/details/17115035

  2. 直接打印
    http://blog.sina.com.cn/s/blog_a53598e601015tsy.html

but
我觉得第一种比较麻烦,因为调试的时候主要调试的还是那么几个文件,所以我觉得采用第二种。直接修改文件得方法。

在device.h前加入debug宏,修改输出等级。他的攻略中间有一部分是修改了linux/device.h,但是我修改之后就开始报错,重定义之类的,编译了之后发现没有什么用处,我自己这边是没用了就。搞不清,后来又在网上找了很多办法,有的说只需要定义debug就可以打印。

到最后解决办法:在你需要输出的文件内添加debug宏(在device.h前面),修改输出等级kernel/printk/printk.c。重新编译。生效。

貌似两种方法不能一起用,我开了dynamic debug之后,就无法正常输出了。

也算是总结。希望有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值