-------------------------------------------------------------------------
这篇文章的小目标:了解抓取开机过程systrace的步骤
-------------------------------------------------------------------------
手机开机的过程,涉及的代码很多,如果能用systrace来分析,事半功倍。
首先分解开机各阶段的耗时,方便后续对照。
只需要在events log过滤boot_progress关键字,就可以得出开机各阶段的耗时。
device:/ $ logcat -b events | grep boot_progress
07-17 08:33:00.241 400 400 I boot_progress_start: 4826
11-29 09:53:34.968 400 400 I boot_progress_preload_start: 7577
11-29 09:53:36.154 400 400 I boot_progress_preload_end: 8763
11-29 09:53:36.519 2072 2072 I boot_progress_system_run: 9127
11-29 09:53:37.088 2072 2072 I boot_progress_pms_start: 9697
11-29 09:53:37.238 2072 2072 I boot_progress_pms_system_scan_start: 9847
11-29 09:53:37.402 2072 2072 I boot_progress_pms_data_scan_start: 10011
11-29 09:53:37.430 2072 2072 I boot_progress_pms_scan_end: 10039
11-29 09:53:37.925 2072 2072 I boot_progress_pms_ready: 10533
11-29 09:53:39.394 2072 2072 I boot_progress_ams_ready: 12003
11-29 09:53:41.324 2072 2637 I boot_progress_enable_screen: 13933
在操作抓取systrace之前,不妨先参考 [Android systrace系列] systrace的信息从哪里来,来熟悉systrace log类别的掩码,和ftrace事件的路径。
下面来说明抓取开机systrace的步骤,这里需要编译手机的userdebug版本
1. 全局搜所有rc文件,将所有关闭trace的命令注释,例如这一句 #write /sys/kernel/debug/tracing/instances/wifi/tracing_on 0
修改完rc文件后,编译手机ROM。
技巧:可以编完一次手机ROM之后,只在out文件夹搜rc文件,缩小搜索范围,然后修改重编。
2. 修改build.prop,并push到手机
2.1 首先提取手机上的build.prop
adb pull /system/build.prop
2.2 添加属性debug.atrace.tags.enableflags,数值为掩码,使能需要的systrace category。
掩码可参考源码//android/system/core/libcutils/include/cutils/trace.h中,ATRACE_TAG开头的宏定义。
debug.atrace.tags.enableflags可以是0x开头的十六进制,也可以用0开头的8进制,或者非0卡开头的十进制。
debug.atrace.tags.enableflags=0xC402A
2.3 将buid.prop重新push到手机
adb rootadb remountadb push build.prop /system/
提示:也可以在device.mk添加属性debug.atrace.tags.enableflags,然后编译手机ROM
3. 修改atrace.rc,并push到手机
3.1 首先提取手机上的atrace.rc
adb pull /system/etc/init/atrace.rc
在更改buffer权限的下一行,扩大buffer大小 ,以便容纳足够长时间的log
chmod 0666 /sys/kernel/debug/tracing/buffer_size_kbwrite /sys/kernel/debug/tracing/buffer_size_kb 51200
3.2 选择需要抓取的kernel ftrace event。
可以先关闭所有开关,就是手机目录 /sys/kernel/debug/tracing/events/ 下所有的trace,下面只列举四行作为例子
write /sys/kernel/debug/tracing/events/power/enable 0write /sys/kernel/debug/tracing/events/sched/enable 0write /sys/kernel/debug/tracing/events/vmscan/enable 0write /sys/kernel/debug/tracing/events/block/enable 0
再打开需要的开关,可以参考atrace.cpp的数组 k_categories
write /sys/kernel/debug/tracing/events/power/cpu_frequency/enable 1write /sys/kernel/debug/tracing/events/power/idle/enable 1write /sys/kernel/debug/tracing/events/sched/sched_switch/enable 1write /sys/kernel/debug/tracing/events/sched/sched_wakeup/enable 1write /sys/kernel/debug/tracing/events/block/block_rq_issue/enable 1write /sys/kernel/debug/tracing/events/block/block_rq_complete/enable 1
3.3 正如第1点所说,atrace.rc中,要注释关闭 trace 的命令,因为开机过程的trace是默认关闭的。
#write /sys/kernel/debug/tracing/tracing_on 0#write /sys/kernel/tracing/tracing_on 0
3.4 为了避免开机完成后继续输出 trace 冲掉开机 log,开机完成后停止trace,在atrace.rc的最后面加入下面两行:
这里注意不要在3.3所说的两行上面加,因为on property会被认为是另一个 action 块的开头
on property:sys.boot_completed=1 write /sys/kernel/debug/tracing/tracing_on 0
3.5 将 atrace.rc push 到 /system/etc/init/atrace.rc
adb rootadb remountadb push atrace.rc /system/etc/init/atrace.rc
4. 重启开机,执行adb shell "cat /sys/kernel/debug/tracing/trace" > trace.out
这时可以尝试在 chrome://tracing 点击Load加载 trace.out。
提示:文件太大,或者个别log的不完整,会导致加载失败。
如果加载出错,请继续下面的步骤。
5. (可选步骤)太大的 trace.out 文件,可以以纯文本方式,切割出需要分析的启动阶段,单独保存成part.out,再尝试加载。
6. 因不完整 log 而加载失败的 trace 文件(无论切割过或未切割),可以用 trace2html.py 转化,而不是 systrace.py,因为后者也会发生错误
首先下载catapult,https://github.com/catapult-project/catapult
trace2html.py路径://catapult/tracing/bin/ trace2html.py
转化命令是 trace2html.py trace.out
转载请注明出处:https://www.cnblogs.com/zzcperf/p/14054555.html
原文转载:http://www.shaoqun.com/a/494411.html
cicpa:https://www.ikjzd.com/w/1375
聚贸:https://www.ikjzd.com/w/1305
kili:https://www.ikjzd.com/w/238
-------------------------------------------------------------------------这篇文章的小目标:了解抓取开机过程systrace的步骤-------------------------------------------------------------------------手机开机的过程,涉及的代码很多,如果能用systra
tineye:tineye
cares:cares
广州大夫山森林公园自驾游如何走啊?:广州大夫山森林公园自驾游如何走啊?
警惕!如何防范外贸邮件诈骗,保障汇款安全?(案例):警惕!如何防范外贸邮件诈骗,保障汇款安全?(案例)
亚马逊专员---深圳(5000--12000+):亚马逊专员---深圳(5000--12000+)
No comments:
Post a Comment