首页 > 其他分享 >使用dynamic debug帮助调试

使用dynamic debug帮助调试

时间:2024-08-08 16:50:42浏览次数:17  
标签:kernel dynamic module dyndbg debug smpboot 调试

你一定在kernel source code中看过很多pr_debug()/dev_dbg()/print_hex_dump_debug()吧,这些debug语句提供更多的信息帮助我们了解内核运行流程或是定位问题,可以在运行时按per-callsite单独开启/关闭。那我们来看一下它是如何实现和使用的吧。

一、kernel configuration

在编译时,需要设置

CONFIG_DYNAMIC_DEBUG=y

CONFIG_DEBUG_FS=y

打开这个配置之后,kernel会提供一个debugfs control file:/sys/kernel/debug/dynamic_debug/control

通过这个文件,可以在运行时打开/关闭dynamic debugging statement。

通过这个文件,可以在运行时打开/关闭dynamic debugging statement。

debugging statement可以通过filename/module/function/line number来匹配。

往dynamic_debug debugfs中写入的内容主要是operations+flags;

其中operation有以下三种:

+:add the given flags;

-: remove the given flags;

=:set the dyndbg flags to the given flags;

其中flags包括:

p:enable the pr_debug() callsite;

f/l/m/t:include the function name、line number、module name、threadID in the printed message;

比如,想要打开svcsock.c文件中,line 1603中的pr_debug,可以设置

echo "file svcsock.c line 1603 +p" > /sys/kernel/debug/dynamic_debug/control;

二、开启dynamic debug的四种方式

2.1 在内核编译时

修改你关心模块目录下的Makefile文件,对指定文件/模块打开dynamic debug

ccflags-y += -DDEBUG

比如我们想要打开arch/x86/kernel/smpboot.c中的pr_debug

vim arch/x86/kernel/Makefile

在 obj-$(CONFIG_SMP) += smpboot.o

后面,添加

CFLAGS_smpboot.o += -DDEBUG 或 ccflags-$(CONFIG_SMP) += -DDEBUG

之后,重新编译kernel,即可开启smpboot.c文件中的dynamic debug。

2.2 boot time 系统启动时开启

对于core code和built-in modules中的debug message,可以在系统启动时开启,在启动参数中设置

“module.dyndbg="QUERY"”,

其中module就是lsmod命令显示的结果(去除路径信息,把'-'改成'_')

这些dyndbg参数会在ddebug tables处理之后来处理,是archi_initcall的一部分

比如,在x86系统中,开启ec.c中的dynamic debug,可以在commandline中设置 dyndbg="file ec.c +p"

如果module foo不是built-in的,foo.dyndbg依然会在boot time时处理,在module foo加载时再次处理。

2.3 加载module时设置dyndbg

modprobe foo执行时,会扫描/proc/cmdline中的foo.params,并跟其他在modprobe时指定的module params、/etc/modprob.d/*.conf中的参数一起传递给kernel来处理;所有的参数按照以下顺序来处理

a) /etc/modprobe.d/*.conf中的module params

options foo dyndbg=+pt

options foo dyndbg //default,使用+p

b) boot commandline中设置的params

foo.dyndbg = "func bar +p; func buz +mp"c) 在modprobe加载时指定的参数

modprobe foo dyndbg==pmf      //这会override之前的配置

2.4 在系统运行时,通过debugfs修改

在编译或系统启动时,开启的dynamic_debug选项都可以通过/sys/kernel/debug/dynaminc_debug/control来查询并修改

cat /sys/kernel/debug/dynaminc_debug/control

查询所有开启了dynamic debug选项的文件;

开启某个文件中的pr_debug或dev_dbg

echo 'file $file_name +p' > /sys/kernel/debug/dynaminc_debug/control

比如开启smpboot.c中的pr_debug信息

echo 'file smpboot.c  +p' > /sys/kernel/debug/dynaminc_debug/control

之后,查看相关的dynamic debug是否开启

cat /sys/kernel/debug/dynaminc_debug/control | grep smpboot
arch/x86/kernel/smpboot.c:1356 [smpboot]native_smp_cpus_done =p "Boot done\012"
arch/x86/kernel/smpboot.c:1095 [smpboot]native_cpu_up =p "do_boot_cpu %d Already started\012"
arch/x86/kernel/smpboot.c:1082 [smpboot]native_cpu_up =p "++++++++++++++++++++=_---CPU UP  %u\012"
arch/x86/kernel/smpboot.c:993 [smpboot]do_boot_cpu =p "Setting warm reset code and vector.\012"

停止某个文件中的dynamic debug打印

echo 'file $file_name -p' > /sys/kernel/debug/dynaminc_debug/control

打印某个module中的信息

​​​​​​​echo 'module $mod_name +p' > /sys/kernel/debug/dynaminc_debug/control

标签:kernel,dynamic,module,dyndbg,debug,smpboot,调试
From: https://www.cnblogs.com/linhaostudy/p/18349272

相关文章

  • JSP公共卫生综合管控平台md94w(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统功能:用户,服务站,管控申请,管控记录,申请处理开题报告内容一、项目背景与意义在全球化背景下,公共卫生事件频发,对人民群众的生命安全和身体健康构成严重威......
  • JSP个人健康数据管理系统j3z2r程序+源码+数据库+调试部署+开发环境
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统功能:信息,医生,用户,坐诊信息,图书分类,图书信息,咨询信息,预约就诊,取消预约,循环预约,健康数据开题报告内容一、研究背景与意义随着健康意识的提升与信......
  • Debug:调用MIG IP核
    MIGIP核功能:        MIGIP核主要用于帮助设计人员轻松地建立各种类型的存储器接口,包括DDR(DoubleDataRate)SDRAM(同步动态随机存取存储器)、DDR2、DDR3、DDR4等。问题描述        当我们遇到了如图所示的TheConfigurationPinPUDC_Bisusedforallthe......
  • SAM2:环境安装&代码调试
    引子时隔大半年,SAM2代终于来了,之前写过一篇《SegmentAnything(SAM)环境安装&代码调试》,感兴趣童鞋请移步https://blog.csdn.net/zzq1989_/article/details/135479818?spm=1001.2014.3001.5501,OK,让我们开始吧。一、模型介绍Meta公司去年发布了SAM1基础模型,已经可以在图像上......
  • 基于SpringBoot教学管理系统的设计与实现(源码+LW+调试文档+讲解等)
     博主介绍:  ......
  • 基于SpringBoot大学生家教管理系统的设计与实现(源码+LW+调试文档+讲解等)
    博主介绍:  ......
  • Springboot计算机毕业设计大学生请假系统(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表学生,教师,学院,专业,班级,请假信息,请假条,销假信息,公告信息,出勤率开题报告内容一、选题背景与意义随着高等教育的普及和学生数量的不断增加,传统的学生请假......
  • JSP个人博客管理系统4n8ge(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统功能:用户,日志信息,个人相册,标签分类,登录签到,积分充值技术要求:    开发语言:JSP前端使用:HTML5,CSS,JSP动态网页技术后端使用SpringBoot,Spring技......
  • 《重生到现代之从零开始的C语言生活》—— 调试
    前言:调试是几乎每一个计算机行业的人员必备的技能,那么让我们来学习一下吧bugbug这个词好像出现在生活的很多地方,一般指在电脑系统中或程序中,隐藏着一些未被发现的缺陷和问题,简称程序漏洞调试(debug)我们发现bug后,下一步就是找到问题并修复问题,找问题的过程就是调试调试一......
  • VS调试技巧
    目录1.什么是debug2.Debug和Release3.VS调试快捷键4.监视和内存观察4.1监视4.2内存5.编译常见错误归类5.1编译型错误5.2链接型错误5.3运⾏时错误1.什么是debug当我们发现程序中存在的问题的时候,那下⼀步就是找到问题,并修复问题。这个找问题的过程叫称为调试,英......