启动耗时统计
printk time
打开kernel配置:
kernel hacking --- >
[*] Show timing information on printks
打开后,每个printk的前面都会显示时间戳
主要用来测量内核启动过程各个阶段的耗时
initcall_debug
众所周知,kernel
启动时会执行不同等级的initcall
,而每个initcall
的耗时也是可以统计的。
在kernel
的cmdline
中加入参数initcall_debug=1
:
initcall_debug=1
setargs_nand=setenv bootargs console=${console} earlyprintk=${earlyprintk} root=${nand_root} initcall_debug=${initcall_debug} init=${init}
开启后,就能打印每个initcall
函数调用及耗时。
bootgraph
内核自带了一个工具用于统计启动时间:scripts/bootgraph.pl
使用该工具需要打开内核配置CONFIG_PRINTK_TIME=y
,并且在cmdline
中加上"initcall_debug=1
"
系统启动之后,执行命令:
dmesg|perl $(kernel_dir)/script/bootgraph.pl > out.svg
用浏览器查看out.svg
文件,可以看到内核启动过程中各个阶段的耗时。
这个工具有点类似于perf
的火焰图,可以统计启动各阶段的耗时。
bootchart
除了内核自带的工具,也有开源的工具可用:bootchart
。
bootchart是一个用于linux启动过程性能分析的开源软件工具,在系统启动过程自动收集CPU占用率、进程等信息,并以图形方式显示分析结果,可用作指导优化系统启动过程。
- 修改
kernel cmdline
。将其中的init
修改为“init=/sbin/bootchartd
”。 - 收集信息。
bootchartd
会从/proc/stat
,/proc/diskstat
,/proc/[pid]/stat
中采集信息,经过处理后保存为bootchart.tgz
文件 - 转换图片。在
pc
上通过pybootchartgui.py
工具将bootchart.tgz
转换为bootchart.png
,方便分析
最后也会成图片供做分析,例如:
bootchar
主要用来测量挂载文件系统到主应用程序启动过程中的耗时
gpio+示波器
可以找一个在系统启动过程中空闲的GPIO
,在适当位置设置GPIO
电平。
通过示波器抓取波形可以得到各阶段耗时。
通常该方法被用来 测量整个启动的耗时,或者各阶段的耗时 ,该方法也是用的比较多的。
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
-
示波器
+关注
关注
107文章
4888浏览量
179966 -
内核
+关注
关注
3文章
1188浏览量
39612 -
Linux
+关注
关注
85文章
10263浏览量
205828
发布评论请先 登录
相关推荐
介绍几种常见的ARM内核
内核 介绍几种常见的ARM内核1.Cortex-M3 2.Cortex-A7 3.Cortex-A53 4.Cortex-A72 ——什么是SoC芯片1. STM32F103ZET6 2. i.MX 6ULL 3. A133(全志) 4. RK3399总结文章参考
发表于 12-07 06:36
分辨矩阵法耗时推算
耗时推算:针对粗集理论的分辨矩阵方法求解知识约简过程中时空性能上存在的问题,提出分辨矩阵法耗时推算的原理和算法,包括2 个耗时段的推算及推算结果的可靠
发表于 10-17 23:06
•17次下载
内核级HOOK的几种实现方法与应用说明
内核级HOOK 对于拦截、分析、跟踪系统内核起着致关重要的作用。实现的方法不同意味着应用侧重点的不同。如想要拦截NATIVE API 那么可能常用的就是HOOKSERVICE TABLE 的
发表于 11-10 17:35
•5次下载
电机软启动有几种方式_电机软启动最简单的方法
启动是一种通过逐渐升高电机电压和电流,减小电机启动时的电流冲击,保护电机和电网,提高电机的使用寿命和运行效率的控制方式。常见的电机软启动方式包括以下几种:
电压降低
发表于 03-09 09:35
•4383次阅读
Linux内核常用的几种镜像文件
几种常用的内核镜像文件:vmlinux、Image、zImage、bzImage、uImage、bootpImage、XIPImage等等。
发表于 06-23 11:49
•3162次阅读
评论