dump_stack 分析使用

dump_stack是用来回溯内核运行的信息的,打印内核信息堆栈段;

dump_stack原型:

void dump_stack(void);

1、使用这个功能时需要将内核配置勾选上;

make menuconfig -> kernel hacking--> kernel debug

2、在函数中使用:

 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);

3、需要加入的头文件:

1 #include <linux/kprobes.h>
2 #include <asm/traps.h>

4、得到hello.ko之后,insmod hello.ko,打印信息如下:

 1 [ 3719.352022] usb 1-8: new high speed USB device number 11 using ehci_hcd
 2 [ 4266.252826] usb 1-8: USB disconnect, device number 11
 3 [ 5246.942980] dump_stack start
 4 [ 5246.942985] Pid: 3438, comm: insmod Not tainted 3.0.0-21-generic #35-Ubuntu
 5 [ 5246.942987] Call Trace:
 6 [ 5246.942993]  [] hello_init+0x17/0x1000 [hello]
 7 [ 5246.942999]  [] do_one_initcall+0x42/0x180
 8 [ 5246.943003]  [] sys_init_module+0xbe/0x230
 9 [ 5246.943006]  [] system_call_fastpath+0x16/0x1b
10 [ 5246.943008] dump_stack over

在不同环境下,Call Trace也可能被称为Back Trace;

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏杨建荣的学习笔记

通过shell分析表依赖的层级关系(r3笔记第97天)

在平时的工作环境中,总会有一些表会存在依赖关系,比如我们有三张表customer,用户表subscriber,账户表account 其中客户可以有多个用户或者账...

29610
来自专栏Jerry的SAP技术分享

SAP Cloud for Customer使用移动设备访问系统的硬件要求

Processor: 2 x quad-core CPU -- 1.9 and 1.3 gigahertz (GHz)○

942
来自专栏北京马哥教育

LVM创建实例及相关注释

LVM创建 pv—>vg—->lv—->快照 创建前准备了四块1g硬盘分别为:sdb sdc sdd sde,并分别给四块盘划分了1G的空间,并指定了分区系统类...

26512
来自专栏逍遥剑客的游戏开发

哇哈哈, 终于天上掉箱子了

934
来自专栏Linux驱动

31.Linux-wm9876声卡驱动(移植+测试)

本节学习目的 1)分析Linux中的OSS声卡系统 2)移植wm9876声卡 3)使用madplay应用程序播放mp3 1.声音三要素 采样频率 音频采样率是指...

2646
来自专栏数据库新发现

Oracle诊断案例-Spfile案例一则

情况说明: 系统:SUN Solaris8 数据库版本:9203 问题描述:工程人员报告,数据库在重新启动时无法正常启动.检查发现UNDO表空间丢失. 问题诊断...

673
来自专栏FreeBuf

Windows DNS API RCE漏洞分析及PoC构造

根据 Microsoft 2017 年 10 月安全通告,多个版本 Windows 中的 dnsapi.dll 在处理 DNS response 时可导致 SY...

29510
来自专栏沃趣科技

ASM 翻译系列第十二弹:ASM Internal amdu - ASM Metadata Dump Utility

原作者:Bane Radulovic 译者: 庄培培 审核: 魏兴华 DBGeeK社群联合出品 amdu - ASM Metadata Dump U...

3525
来自专栏Kubernetes

Kubernetes Deployment滚动更新场景分析

基于Kubernetes v1.7.4 关于Kubernetes Deployment滚动更新 Kubernetes官网文档说明:https://kube...

3548
来自专栏Python小屋

Python监视进程创建情况和系统服务状态

(1)监视Windows系统中进程创建情况 import wmi c = wmi.WMI() process_watcher = c.Win32_Proce...

2696

扫码关注云+社区