Chinaunix首页 | 论坛 | 博客
  • 博客访问: 862509
  • 博文数量: 581
  • 博客积分: 7803
  • 博客等级: 少将
  • 技术积分: 3653
  • 用 户 组: 普通用户
  • 注册时间: 2007-04-27 08:21
文章分类

全部博文(581)

文章存档

2013年(7)

2012年(414)

2011年(159)

2009年(1)

分类:

2012-03-06 10:00:16

原文地址:使用printk调试kernel 作者:g050649

printk(KERN_ERR "\n\nfile: %s \t line = %d\t function: %s\n", __FILE__, __LINE__, __func__);
printk("KERNEL:File: %s\t line = %d\t function: %s\n", __FILE__, __LINE__, __func__);

调试kernel增加一些打印信息,可能通过这个信息从而看到函数被哪些函数调用了.

unsigned int * s_bp;

__asm__("movl %%ebp,%0":"=g"(s_bp));

printk( "\nKERNEL-DEBUG: file : [%s] \nFunction:[%s] \nLine = [%d] \nIs called Add = [%x]\n", __FILE__, __func__, __LINE__,* (unsigned int *) (s_bp+1));

查函数表:

$ cat /proc/kallsyms


C语言编译器的预定义符号:
__LINE__           当前(源代码文件)行号 [整数]
__FILE__           当前正在编译的文件的文件名   [字符串]
__DATE__           当前日期,以“月月 日日 年年年年”的形式给出 [字符串]
__TIME__           当前时间,以“HH:mm:ss”的格式给出   [字符串]
__STDC__           如果编译器符合ANSI C标准,该宏为1,否则为0
__STDC_HOSTED__    如果实现了所有C标准库,该宏为1,否则为0
__STDC_VERSION__   被定义为199901L(不同编译器可能不一样,比如我用的gcc里就没有这个预定义符号)

注:这些预定义符号的首尾为两个下划线,如果是两个 单词,中间以一个下划线连接。
如果在源代码中使用了这些符号,它们会在预处理时被转换(使用gcc编译器的 -E 选项可以看到替换后的值)

C 标准里还在每个函数内预定义了一个标志符: __func__
它被定义为 static const char __func__[]="function-name";
即不能在程序内对__func__赋值,也不能改变它所指向的字符串(函数名),否则报 编译错误

注:__func__是个标志符,它在预处理阶段不被替换,所以使用gcc -E 是看不到任何效果的。
例:test.c
int main(){
printf("%s %s\n",__FILE__,__func__);
return 0;
}

输 出: test.c main


在头文件中共定义了八个可用的记录级;我们下面按其严重性倒序列出:

KERN_EMERG

Used for emergency messages, usually those that precede a crash.

用于突发性事件的消息,通常在系统崩溃之前报告此类消息。

KERN_ALERT

A situation requiring immediate action.

在需要立即操作的情况下使用此消息。

KERN_CRIT

Critical conditions, often related to serious hardware or software failures.

用于临界条件下,通常遇到严重的硬软件错误时使用此消息。

KERN_ERR

Used to report error conditions; device drivers often use KERN_ERR to report hardware difficulties.

用于报告错误条件;设备驱动经常使用KERN_ERR报告硬件难题。

KERN_WARNING

Warnings about problematic situations that do not, in themselves, create serious problems with the system.

是关于问题状况的警告,一般这些状况不会引起系统的严重问题。

KERN_NOTICE

Situations that are normal, but still worthy of note. A number of security-related conditions are reported at this level.

该级别较为普通,但仍然值得注意。许多与安全性相关的情况会在这个级别被报告。

KERN_INFO

Informational messages. Many drivers print information about the hardware they find at startup time at this level.

信息消息。许多驱动程序在启动时刻用它来输出获得的硬件信息。

KERN_DEBUG

Used for debugging messages.

用于输出调试信息

printk(KERN_ERR, "file: %s \t line = %d\t function: %s\n", __FILE__, __LINE__, __func__);
阅读(508) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~