linux设备调试信息输出
来源:互联网 发布:域名冲突 编辑:程序博客网 时间:2024/05/01 06:56
http://blogold.chinaunix.net/u1/38038/showart_1359825.html
1、打开调试开关:你调试的文件中必然包含了<linux/device.h>,或者《linux/paltforam_device.h》,后者包含了前者,在包含此头文件之前,使用#define DEBUG 1 来打开调试开关:例如
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/clk.h>
#include <linux/module.h>
#define DEBUG 1
#include <linux/platform_device.h>
在linux/device.h文件中:
#define dev_printk(level, dev, format, arg...) /
printk(level "%s %s: " format , dev_driver_string(dev) , (dev)->bus_id , ## arg)
#ifdef DEBUG
#define dev_dbg(dev, format, arg...) /
dev_printk(KERN_DEBUG , dev , format , ## arg)
#else
static inline int __attribute__ ((format (printf, 2, 3)))
dev_dbg(struct device * dev, const char * fmt, ...)
{
return 0;
}
#endif
但是这个打开了之后,也不能顺利的输出信息,原因是printk有默认的信息级别。
linux/kernel文件中
#define KERN_EMERG "<0>" /* system is unusable */
#define KERN_ALERT "<1>" /* action must be taken immediately */
#define KERN_CRIT "<2>" /* critical conditions */
#define KERN_ERR "<3>" /* error conditions */
#define KERN_WARNING "<4>" /* warning conditions */
#define KERN_NOTICE "<5>" /* normal but significant condition */
#define KERN_INFO "<6>" /* informational */
#define KERN_DEBUG "<7>" /* debug-level messages */
可以看到KERN_DEBUG是级别最低的。
2、修改文件kernel/printk文件
/* printk's without a loglevel use this.. */
#define DEFAULT_MESSAGE_LOGLEVEL 4 /* KERN_WARNING */
/* We show everything that is MORE important than this.. */
#define MINIMUM_CONSOLE_LOGLEVEL 1 /* Minimum loglevel we let people use */
#define DEFAULT_CONSOLE_LOGLEVEL 8 /* anything MORE serious than KERN_DEBUG */
其中DEFAULT_CONSOLE_LOGLEVEL为终端console输出的最低级别,比这严重的都将输出。原来该值为7,则调试信息无法输出,修改为8则全部有输出。
- linux设备调试信息输出
- linux设备调试信息输出
- linux设备调试信息输出
- Linux调试信息输出串口设备号的设置
- linux中输出调试信息
- linux输出信息调试信息重定向
- 调试信息输出
- vc 调试信息输出
- OutputDebugString输出调试信息
- VC 调试 信息输出
- 开启调试信息输出
- 格式化输出调试信息
- 黑莓调试信息输出
- 调试输出信息OutPutDebugString
- 调试输出信息OutPutDebugString
- makefile输出调试信息
- 输出调试信息
- 输出调试信息宏
- c5700连接电脑做modem上网 3G上网 无线上网设置
- 关于中文文件名字转码
- 次小生成树
- 标准差
- jni实现过程
- linux设备调试信息输出
- 坑爹的dsfksvcs.sys
- myeclipse和sql sever2000的连接
- thinkphp的常用页面跳转语句的用法
- TCP连接的状态转换图深度剖析
- 单独一个列表框的应用
- 简单设置提高VS2010的运行速度
- 一个TCPClient和TCPListener的例子 dotNet
- three20 缓存 TTURLRequestCachePolicy 缓冲 方案 详解