高效分析Linux内核源码
最近在调试nvme的驱动 , 顺便分享一下分析内核代码的方法 , 我自己感觉异常高效 , 整体逻辑分分钟可以掌握的明明白白 。
对于给定的一个函数 , 例如nvme_probe()函数 , 如果想分析系统怎样调到这个函数,也就是想知道函数之前的调用栈 , 可以在函数中添加WARN_ON(1)打印堆栈 , 但是这样要重新编译源码 , 内核提供了ftrace 技术 , 可以使用ftrace function + 和enable func_stace_trace达到同样的效果 。
cd/sys/kernel/debug/tracing/echo nvme_probe > set_ftrace_filterecho 1 > ./options/func_stack_trace
如果nvme_probe()函数中包含trace_event的内嵌函数 , 那就更加方便了 , 可以使用:
cd/sys/kernel/debug/tracing/echo 1 > ./events/nvme/nvme_probe/enableecho 1 > ./options/stacktrace 或者 echo 'stacktrace' > ./events/nvme/nvme_probe/trigger
也可以设置内核启动参数:
trace_options=func_stack_trace,userstacktrace,sym-addr ftrace=function ftrace_filter="nvme_probe"
效果图:
文章插图
如果想知道nvme_probe()函数之后的调用逻辑 , 可以使用ftrace + func_graph的方式
debugfs=/sys/kernel/debugecho nop > $debugfs/tracing/current_tracerecho 0 > $debugfs/tracing/tracing_onecho 10 > $debugfs/tracing/max_graph_depth#echo $$ > $debugfs/tracing/set_ftrace_pidecho function_graph > $debugfs/tracing/current_tracerecho nvme_probe > $debugfs/tracing/set_graph_functionecho 1 > $debugfs/tracing/tracing_onexec "$@"
【高效分析Linux内核源码】同样也可以设置内核启动参数:
ftrace=function_graph ftrace_graph_filter="nvme_probe"
效果图:
文章插图
(图中白色背景的函数还可以再展开详细查看)
呈现上图的效果可以借助折叠脚本:function-graph-fold.vim
脚本来源:
使用方法:
vim ./ftrace-nvme/func-graph-nvme-probe.log -S ./function-graph-fold.vim
更详细的说明可以参考我的github:
推荐阅读
- 分析师:iPhone 12任一机型头三月销量都将超越Galaxy S21产品线
- 分析师预测苹果新服务可能包括播客+股票+和 邮件+
- 发布|分析师:苹果将于2021年发布AirTags物品追踪器 新款Mac也有望面世
- Google AI建立了一个能够分析烘焙食谱的机器学习模型
- Linux Kernel 5.10.5发布:禁用FBCON加速滚动特性
- 锂电池霸主地位岌岌可危!新型高效超级电容器性能相当 寿命还更长
- Linux 5.11开始围绕PCI Express 6.0进行早期准备
- Fedora正在寻求协助 希望加快Linux 5.10 LTS内核测试进度
- Linux Mint 20.1 Ulyssa稳定版已确定延期至2021年初发布
- 英特尔Xe GPU在Linux 5.11上的性能表现不错