本文主要是介绍linux dev_dbg输出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
这几天在搞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);
应该是调试信息打印,目测无误。
开始想办法:
网上找到一些教程
大致有两类
dynamic debug
http://blog.csdn.net/fnjnash/article/details/17115035直接打印
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之后,就无法正常输出了。
也算是总结。希望有所帮助。
这篇关于linux dev_dbg输出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!