这几天在搞smbus(大致上算是阉割版的i2c吧),在调试的时候碰到了一个问题:
直接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
but
我觉得第一种比较麻烦,因为调试的时候主要调试的还是那么几个文件,所以我觉得采用第二种。直接修改文件得方法。
在device.h前加入debug宏,修改输出等级。他的攻略中间有一部分是修改了linux/device.h,但是我修改之后就开始报错,重定义之类的,编译了之后发现没有什么用处,我自己这边是没用了就。搞不清,后来又在网上找了很多办法,有的说只需要定义debug就可以打印。
到最后解决办法:在你需要输出的文件内添加debug宏(在device.h前面),修改输出等级kernel/printk/printk.c。重新编译。生效。
貌似两种方法不能一起用,我开了dynamic debug之后,就无法正常输出了。
也算是总结。希望有所帮助。