几种统计内核启动耗时的方法

启动耗时统计printk time打开kernel配置:
kernel hacking --- >[*] show timing information on printks打开后,每个printk的前面都会显示时间戳
主要用来测量内核启动过程各个阶段的耗时
initcall_debug众所周知,kernel启动时会执行不同等级的initcall,而每个initcall的耗时也是可以统计的。
在kernel的cmdline中加入参数initcall_debug=1:
initcall_debug=1setargs_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电平。
通过示波器抓取波形可以得到各阶段耗时。
通常该方法被用来 测量整个启动的耗时,或者各阶段的耗时 ,该方法也是用的比较多的。

厨电MES工厂如何打造数据采集物联网
TPCAST在研究无线虚拟现实系统商业版,将由德国Schenker技术公司发行
漏电继电器的接线方法
恒讯科技解读:TikTok常用的登陆节点软件V2ray配置教程
2012年全球半导体行业销售收入达2916亿美元
几种统计内核启动耗时的方法
四大技术领域齐头并进,Aruba重点发力中小企业数字化转型市场
磷酸铁锂正极材料8月报
激光电视市场竞争异常激烈,各大企业该如何应对?
海目星激光与国内动力电池企业达成深度合作
微软引入了名为Flashlight的全新功能可通过VR头显观察现实世界
可行的平台ASIC解决方案用于实现芯片上的定制系统
七夕合适送女生的礼物,合适女生的蓝牙耳机!赶紧收藏!
对“区块链”传销应该怎样对待
电子负载的工作模式
安防行业应着眼于未来面临的机会与风险 推动产业的发展
如何利用AI科技来预防失明
4298元起,搭载超感光微云台vivo X50 Pro今日开售
机器人加速企业复工 工作效率是工人的三倍
经纬恒润再次荣获多个奖项