• dump_stack的简单使用


    转载:http://blog.csdn.net/sanchuyayun/article/details/39183941

     

    刚刚接触内核,在调试过程中用printk打印信息当然是直接有效的办法,但当我们不知到一个函数或者一个模块到底在哪里出了问题时我们可以利用dump_stack有效的找到问题的根源,下面只是简单的给出了使用方法。
      我在自己的主机上试了一下dump_stack()

    Makefile文件

        obj-m := hello.o
        KERNELBUILD :=/lib/modules/$(shell uname -r)/build
        default:
                make -C $(KERNELBUILD) M=$(shell pwd) modules
        clean:
                rm -rf *.o *.ko *.mod.c .*.cmd *.markers *.order *.symvers .tmp_versions

     
    hello.c文件

        #include <linux/module.h>
        #include <linux/init.h>
        #include <linux/kprobes.h>
        #include <asm/traps.h>
         
        MODULE_LICENSE("Dual BSD/GPL");
          
        static int __init hello_init(void)
        {
             printk(KERN_ALERT "dump_stack start
    ");
             dump_stack();
             printk(KERN_ALERT "dump_stack over
    ");
             return 0;
         }
         static void __exit hello_exit(void)
         {
              printk(KERN_ALERT "test module
    ");
         }
         
        module_init(hello_init);
        module_exit(hello_exit);

    注意使用dump_stack()要加上这两个头文件

    #include <linux/kprobes.h>
    #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]  [<ffffffffa0072017>] hello_init+0x17/0x1000 [hello]
    [ 5246.942999]  [<ffffffff81002042>] do_one_initcall+0x42/0x180
    [ 5246.943003]  [<ffffffff810a011e>] sys_init_module+0xbe/0x230
    [ 5246.943006]  [<ffffffff815fd202>] system_call_fastpath+0x16/0x1b
    [ 5246.943008] dump_stack over

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

    补充:

    Android.mk文件

        obj-m := hello.o
        #hello-objs := hello-world.o
    
        KVERSION := $(ANDROID_PRODUCT_OUT)/obj/KERNEL_OBJ
    
        all:
            make ARCH=arm CROSS_COMPILE=arm-eabi- -C $(KVERSION) M=$(PWD) modules
        clean:
            make -C $(KVERSION) M=$(PWD) clean
    在android编译环境下编译,编译出来的.ko文件可以在手机中insmod。
     
  • 相关阅读:
    hdu 2842 Chinese Rings
    Codeforces Round #118 (Div. 1) A 矩阵快速幂
    hdu2604 Queuing
    支付宝 生活号 获取 userId 和 生活号支付
    maven 项目使用本地jar
    nexus 私有 maven 仓库的搭建
    linux jdk 安装
    gitlab 可以上传代码,但是 不能 上传 tag 问题
    maven 内置变量
    mysql 不允许分组的问题 this is incompatible with sql_mode=only_full_group_by
  • 原文地址:https://www.cnblogs.com/pengdonglin137/p/4095805.html
Copyright © 2020-2023  润新知