dump_stack的简单使用

来源:互联网 发布:淘宝兼职招聘 编辑:程序博客网 时间:2024/06/02 02:41
   刚刚接触内核,在调试过程中用printk打印信息当然是直接有效的办法,但当我们不知到一个函数或者一个模块到底在哪里出了问题时我们可以利用dump_stack有效的找到问题的根源,下面只是简单的给出了使用方法。

  我在自己的主机上试了一下dump_stack()


hello.c文件

点击(此处)折叠或打开

  1. #include <linux/module.h>
  2. #include <linux/init.h>
  3. #include <linux/kprobes.h>
  4. #include <asm/traps.h>
  5.  
  6. MODULE_LICENSE("Dual BSD/GPL");
  7.   
  8. static int __init hello_init(void)
  9. {
  10.      printk(KERN_ALERT"dump_stack start\n");
  11.      dump_stack();
  12.      printk(KERN_ALERT"dump_stack over\n");
  13.      return 0;
  14.  }
  15.  static void __exit hello_exit(void)
  16.  {
  17.       printk(KERN_ALERT"test module\n");
  18.  }
  19.  
  20. module_init(hello_init);
  21. module_exit(hello_exit);
注意使用dump_stack()要加上这两个头文件
  1. #include <linux/kprobes.h>
  2. #include <asm/traps.h>
然后make得到hello.ko
在运行insmod hello.ko把模块插入内核
运行dmesg
[ 3719.352022] usb 1-8: new high speed USB device number 11 using ehci_hcd
[ 4266.252826] usb 1-8: USB disconnect, device number 11
[ 5246.942980] dump_stack start
[ 5246.942985] Pid: 3438, comm: insmod Not tainted 3.0.0-21-generic #35-Ubuntu
[ 5246.942987] Call Trace:
[ 5246.942993]  [] hello_init+0x17/0x1000 [hello]
[ 5246.942999]  [] do_one_initcall+0x42/0x180
[ 5246.943003]  [] sys_init_module+0xbe/0x230
[ 5246.943006]  [] system_call_fastpath+0x16/0x1b
[ 5246.943008] dump_stack over


打出运行这个模块时调用的函数
删除模rmmod hello


insmod 模块 之后,system_call_fastpath --> sys_init_module  -->do_one_initcall ->hello_init->dump_stack
其中hello_init 就是你写的模块初始化函数

0 0