文章目录

  • printk
  • 动态输出
  • BUG()和BUG_ON()
  • dump_stack()
  • devmem

printk

printk共有8个等级,从0-7,等级依次降低。

打印等级可以通过修改/proc/sys/kernel/printk来改变。

查看printk等级:

cat /proc/sys/kernel/printk
7 4 1 7

打开内核所有打印:

echo 8 > /proc/sys/kernel/printk

具体内容:
Linux内核基础篇——printk


动态输出

printk打印是全局的,使用动态输出则可以有选择地输出某个模块或某个子系统的打印,pr_debug()就是使用了动态输出。

打开svcsock.c文件中所有的动态输出语句

echo 'file svcsock.c +p' > /sys/kernel/debug/dynamic_debug/control

打开usbcore模块中所有的动态输出语句

echo 'module usbcore +p' > /sys/kernel/debug/dynamic_debug/control

打开svc_process()函数中所有的动态输出语句

 echo 'func svc_process() +p' > /sys/kernel/debug/dynamic_debug/control

打开文件路径包含usb的文件里所有的动态输出语句

 echo -n '*usb* +p' > /sys/kernel/debug/dynamic_debug/control

打开系统所有的动态输出语句

 echo -n '+p' > /sys/kernel/debug/dynamic_debug/control

具体内容:
Linux内核基础篇——动态输出调试


BUG()和BUG_ON()

在内核中经常看到BUG()和BUG_ON()宏,这也是内核调试常用的技巧之一。

#<include/asm-generic/bug.h>#define BUG_ON(condition) do { if (unlikely(condition)) BUG();} while(0)#define BUG() do { \printk("BUG:failure at %s:%d/%s()!\n",__FILE__, __LINE__, __func__); \panic("BUG!"); \
}while(0)

对于BUG_ON()宏来说,满足条件(condition)就会触发BUG()宏,它会使用panic()函数来主动让系统宕机。通常只有一些内核的bug才会触发BUG_ON()宏,在实际产品中使用该宏需要小心谨慎。

WARN_ON()宏相对会好一些,不会触发panic()函数,使系统主动宕机,但会输出函数调用栈信息,提示开发者可能发生了一些不好的事情。


dump_stack()

dump_stack()用于打印函数的调用关系,例如,在驱动的入口处添加一句dump_stack():

static int __init hello_init(void)
{......dump_stack();
......return 0;
}

dump_stack()打印的信息:

dump_stack()打印的函数调用关系,需要从下往上看:

ret_fast_syscall->sys_finit_module->load_module->do_init_module->do_one_initcall->hello_init

通过调用关系看出,驱动入口函数hello_init,是由do_init_module调用do_one_initcall,然后再调用到了hello_init。


devmem

通常在Linux驱动中操作寄存器,需要先通过ioremap映射寄存器基地址,转为虚拟地址后才可进行访问。

而devmem可以直接对寄存器进行读写操作,而不需要专门写一个驱动这么麻烦,这在调试的时候很有用。

devmem命令格式:

Usage: devmem ADDRESS [WIDTH [VALUE]]Read/write from physical addressADDRESS Address to act uponWIDTH Width (8/16/...)VALUE Data to be written

ADDRESS:物理地址

WIDTH:位宽,32位、64位等等

VALUE:要写入的值

例如,读取32位寄存器0x40200000的值:

devmem 0x40200000 32

向32位寄存器0x40200000写入0x12345678

devmem 0x40200000 32 0x12345678

具体内容:
内核调试之devmem直接读写寄存器

Linux内核基础篇——常用调试技巧汇总相关推荐

  1. [转]Linux内核基础与常用命令总结

    ##这部分内容主要是基于一些关于Linux系统的内核基础和基本命令的学习总结,内容不全面,只讲述了其中的一小部分,后续会再补充,如有错误,还请见谅. Linux操作系统 Linux操作系统博大精深,其 ...

  2. LINUX学习基础篇(三十五)日志管理

    LINUX学习基础篇(三十五)日志管理 日志管理 系统中常见的日志文件 日志文件格式 rsyslogd服务的配置文件 日志轮替 logrotate配置文件 配置文件夹 /etc/logrotate.d ...

  3. Linux 快速基础篇__Linux操作系统

    Linux 快速基础篇__Linux操作系统 Linux操作系统 文章目录 Linux 快速基础篇__Linux操作系统 Linux操作系统 学习目标 一.操作系统概述 1.计算机分类 2.计算机组成 ...

  4. LINUX学习基础篇(十七)用户与用户组

    LINUX学习基础篇(十七)用户与用户组 用户相关文件 /etc/passwd 用户信息文件 /etc/shadow 影子文件 /etc/group 组信息文件 其他用户有关文件 用户管理命令 use ...

  5. iOS开发之Xcode常用调试技巧总结

    转载自:iOS开发之Xcode常用调试技巧总结 最近在面试,面试过程中问到了一些Xcode常用的调试技巧问题.平常开发过程中用的还挺顺手的,但你要突然让我说,确实一脸懵逼.Debug的技巧很多,比如最 ...

  6. Linux 内核的测试和调试(1)

    Linux 内核的测试和调试(1) Linux 内核测试哲学 不管是开源还是闭源,所有软件的开发流程中,测试是一个重要的.不可或缺的环节,Linux 内核也不例外.开发人员自测.系统测试.回归测试.压 ...

  7. RISC-V IDE MRS使用笔记(七) :常用开发技巧汇总

    RISC-V IDE MRS使用笔记(七) :常用开发技巧汇总 Q1: MRS调试时如何查看外设寄存器内容? A1: 在调试配置界面添加相应的.svd文件. Q2: MRS如何调用数学库? A2: # ...

  8. LINUX学习基础篇(三十三)系统资源

    LINUX学习基础篇(三十三)系统资源 系统资源查看 vmstat命令监控系统资源 dmesg显示开机时内核检测信息 free命令查看内存使用状态 查看CPU信息 查看内存信息 查看当前登录的用户 u ...

  9. linux内核基础和配置编译原理

    2020-8-8 星期六 北京 闷热天 总结linux内核基础和配置编译原理,分两部分总结.仅作为技术积累,方便日后查阅.参考了网上的一些笔记. 第一部分:内核基础 2.14.1.内核和发行版的区别 ...

最新文章

  1. tensorflow 2
  2. java集合框架综述
  3. LinkedHashMap源码剖析
  4. 使用字符代替圆角尖角研究(转)
  5. python抖音github_GitHub - eternal-flame-AD/Douyin-Bot: Python 抖音机器人,论如何在抖音上找到漂亮小姐姐?...
  6. Linux软件包组的选择
  7. pyqt5 点击开始执行_《快速掌握PyQt5》第一章 PyQt5的起点
  8. 谷歌发布AdaNet,快速灵活的AutoML工具,帮助开发者构筑强大集成学习模型
  9. NSTimer--转
  10. mysql返回前2行_取得前一次MySQL操作所影响的记录行数
  11. Spring MVC 入门指南(二):@RequestMapping用法详解
  12. Android:安卓线性布局(属性)
  13. TypeScript:Web开发
  14. 解决Intellij中的一些bug
  15. 集体智慧编程学习笔记(2.1)提供推荐
  16. 用小乌龟git解决冲突之后,再提交,出现自己没用动过的文件
  17. 使用IBM SPSS Statistics常用图表附例演示讲解
  18. 神经网络可以解决的问题,神经网络修复老照片
  19. 如何用公式编辑器编辑直角三角形符号
  20. seo技巧,seo技巧搜行者SEO

热门文章

  1. js如何实现随机数切换
  2. oa办公系统源码OA企业人事管理系统源码php协同自动化办公签到
  3. vuex 源码分析_vue源码解析之vuex原理
  4. 游戏中常见的漏洞和预防措施
  5. Linux下smba服务端的搭建和客户端的使用
  6. 电路分析基础笔记(一)基础知识
  7. 一个电压跟随器的小故事
  8. 14.利用虚函数实现多态性来求正方体、球体和圆柱体的表面积和体积。
  9. 阿里正式启动2021届春季校招!字节跳动Android面试凉凉经,实战解析
  10. 网页设计与制作的学习(一)