开机性能-如何抓取开机systrace

一、理论

1.背景

       抓取开机 trace 需要使用 userdebug 版本,而我们测试开机性能问题时都要求使用 user 版本,否则会有性能损耗问题。因此想要在抓取开机性能trace 时,需要在 user 版本上打开 atrace 功能之后才能抓取 trace,默认 release user 版本是无法直接抓取 trace 的。

2.sepolicy修改

        涉及的更改主要是 atrace.te domain.te 文件, prebuilts/api/30.0/private 下的文件更改是因为需要与 private下的文件保持一致。
private/atrace.te
       atrace 配置原先只在 userdebug eng 版本中才生效,这里是放开对版本类型的限制,使 atrace 配 置对user 版本同样有效。
private/domain.te
同理,因为 atrace domain 类型,这里是放开 user 版本下 atrace debugfs_tracing_debug 类型的
读写权限。

Android版本    Api Level  SDK

Android 14 (Developer Preview)
Android 13.0(T)    33
Android 12.0(S)    31,32
Android 11.0(R)    30
Android 10.0(Q)    29
Android 9.0(Pie)    28
Android 8.1(Oreo)    27
Android 8.0(Oreo)    26
Android 7.1(Nougat)    25
Android 7.0(Nougat)    24
Android 6.0(Marshmallow)    23
Android 5.1(Lollipop)    22
Android 5.0(Lollipop)    21
Android 4.4W(KitKat Wear)    20
Android 4.4(KitKat)    19
Android 4.3(Jelly Bean)    18
Android 4.2(Jelly Bean)    17
Android 4.1(Jelly Bean)    16
Android 4.0.3(IceCreamSandwich)    15
Android 4.0(IceCreamSandwich)    14
Android 3.2(Honeycomb)    13
Android 3.1(Honeycomb)    12
Android 3.0(Honeycomb)    11
Android 2.3.3(Gingerbread)    10
Android 2.3(Gingerbread)    9
Android 2.2(Froyo)    8
Android 2.1(Eclair)    7
Android 2.0.1(Eclair)    6
Android 2.0(Eclair)    5
Android 1.6(Dout)    4
Android 1.5(Cupcake)    3
Android 1.1(Base)    2
Android 1.0(Base)    1

3. 抓取trace

3.1 QCOM平台

3.1.1 抓取atrace日志

替换 atrace.rc 系统中预置的atrace.rc user 版本的 rc ,需要替换成我们修改过的 atrace.rc 。命令如下:
adb push atrace.rc /system/etc/init/atrace.rc
关闭原生 trace 功能,设置 atrace 触发器。命令如下:
$ adb shell
# setprop persist.traced.enable 0
# setprop persist.debug.atrace.boottrace 1
重启设备
设备重启后,在适当的位置抓取 atrace 数据。建议尽快抓取,否则可能出现缓冲区不足导致前面数
据被冲掉的情况。命令如下:
$ adb shell atrace --async_stop -z -c -o /data/local/tmp/atrace.out
/data/local/tmp/atrace.out 下的数据 pull 出来,然后使用 sdk 中的 systrace.py 工具将 atrace 数据
转换成 html 格式。
$ python systrace.py --from-file=atrace.out

3.1.2 抓取zygote启动阶段的trace数据

       由于上面的抓取 atrace 数据的方式是通过 persist.debug.atrace.boottrace 属性来出来的,而 persist 属性 触发器的触发时机是在加载data 分区 persist 属性文件之后。这个时间点远远晚于 zygote 的启动时间,所 以是抓不到zygote 启动阶段的 trace 数据。
       如果想要抓取 zygote 启动阶段的 trace 数据,需要手动将 boottrace 的启动时间调整到 zygote 启动之前。
关闭属性触发器
$ adb shell
# setprop persist.debug.atrace.boottrace 0

修改设备上的init.rc文件

首先将设备中的init.rc文件pull出来

$ adb pull /system/etc/init/hw/init.rc

修改init.rc文件

这里是在启动 zygote-start 的位置,直接将 boottrace 服务启动起来
init.rc push 回设备
$ adb push init.rc /system/etc/init/hw/
重启设备
接下来的操作与 3.1.1 章节重启后的内容一致。

3.2 MTK平台

3.2.1 抓取atrace日志

关闭原生 trace 功能
$ adb shell
# setprop persist.traced.enable 0
打开 mtk systrace 工具
# setprop persist.vendor.boot_trace 1
重启设备
抓取 trace 数据
$ adb shell "cat /sys/kernel/tracing/trace" > SYS_FRACE
通过 trace2html 工具将 trace 数据转换成 html 格式

二、执行操作

如需在启动过程中启用 systrace,请执行以下操作:

在 frameworks/native/cmds/atrace/atrace.rc 中,修改如下:

  write /sys/kernel/debug/tracing/tracing_on 0write /sys/kernel/tracing/tracing_on 0

更改为:

  write /sys/kernel/debug/tracing/tracing_on 1write /sys/kernel/tracing/tracing_on 1

这将启用跟踪功能(默认处于停用状态)。

在 device.mk 文件中,添加以下:

PRODUCT_PROPERTY_OVERRIDES +=    debug.atrace.tags.enableflags=802922
PRODUCT_PROPERTY_OVERRIDES +=    persist.traced.enable=0

在设备专属 init.rc 文件中,添加以下行:

on property:sys.boot_completed=1          // This stops tracing on boot complete
write /d/tracing/tracing_on 0
write /d/tracing/events/ext4/enable 0
write /d/tracing/events/f2fs/enable 0
write /d/tracing/events/block/enable 0

在设备启动后,提取跟踪记录:

adb root && adb shell atrace --async_stop -z -c -o /data/local/tmp/boot_trace
adb pull /data/local/tmp/boot_trace

三、项目中实际应用(MTK QCOM通用)

1.system/core/rootdir/init.rc 添加如下:开机完成关闭trace

on property:sys.boot_completed=1write /d/tracing/tracing_on 0write /d/tracing/events/ext4/enable 0write /d/tracing/events/f2fs/enable 0write /d/tracing/events/block/enable 0

2.frameworks/native/cmds/atrace/atrace.rc

原本start boottrace 触发条件是on late-init  persist.debug.atrace.boottrace=1

下面的修改是直接将on late-init 改成了on early-init 并将persist.debug.atrace.boottrace  条件去掉直接触发start boottrace   可以不用使用我下面的修改,可以按照你们需要调整start boottrace  例如可以在init.rc 不同的trigger阶段去启动boottrace  service.

3.device/qcom/xxx/xxxx.mk  或者build/target/product/base_system.mk 添加属性配置

4.BoardConfig.mk  BOARD_KERNEL_CMDLINE 追加下面字段

BOARD_KERNEL_CMDLINE += trace_buf_size=64M trace_event=cpu_frequency,sched_cpu_util,sched_boost_cpu,cpufreq_interactive,cpu_idle,cpu_frequency,cpu_frequency_limits,sched_wakeup,sched_switch,sched_blocked_reason,sched_cpu_hotplug

高通项目一般在device/qcom/xxxx/BoardConfig.mk

MTK项目一般在device/mediatek/xxxx/BoardConfig.mk

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/126690.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringMVC文件上传、文件下载多文件上传及jrebel的使用与配置

一.文件上传 1.导入依赖 <dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.3</version> </dependency> 2.配置文件上传解析器 在spring-mvc.xml文件中添加文件…

蓝牙方案|伦茨科技最新ESL蓝牙电子价签方案

随着电子货架标签市场无线标准的发布&#xff0c;蓝牙技术将协助零售业进行下一阶段的数字化转型&#xff0c;为商店和购物者提供更好的消费体验。电子货架标签提供了精准的自动定价&#xff0c;并增加了对实时促销和产品信息的访问&#xff0c;提供更令人满意且整合的全渠道体…

Mqtt学习笔记--交叉编译移植(1)

简述 Mqtt目前在物联网行业的应用比较多&#xff0c;mqtt属于应用层的一个中间件&#xff0c;这个中间件实现消息的订阅发布机制。网上介绍Mqtt的实现原来的比较多&#xff0c;这里不细介绍。 其实在我们之前的产品中&#xff0c;自己也开发的有类似的中间件&#xff0c;除了具…

uni-app:重置表单数据

效果 代码 <template><form><input type"text" v-model"inputValue" placeholder"请输入信息"/><input type"text" v-model"inputValue1" placeholder"请输入信息"/><input type&quo…

万里路,咫尺间:汽车与芯片的智能之遇

目前阶段&#xff0c;汽车产业有两个最闪耀的关键词&#xff0c;就是智能与低碳。 在践行双碳目标与产业智能化的大背景下&#xff0c;汽车已经成为了能源技术、交通技术、先进制造以及通信、数字化、智能化技术的融合体。汽车的产品形态与产业生态都在发生着前所未有的巨大变革…

2023国赛数学建模B题思路代码 - 多波束测线问题

# 1 赛题 B 题 多波束测线问题 单波束测深是利用声波在水中的传播特性来测量水体深度的技术。声波在均匀介质中作匀 速直线传播&#xff0c; 在不同界面上产生反射&#xff0c; 利用这一原理&#xff0c;从测量船换能器垂直向海底发射声波信 号&#xff0c;并记录从声波发射到…

【sgCreateAPI】自定义小工具:敏捷开发→自动化生成API接口脚本(接口代码生成工具)

<template><div :class"$options.name"><div class"sg-head">接口代码生成工具</div><div class"sg-container"><div class"sg-start "><div style"margin-bottom: 10px;">接口地…

大规模 Spring Cloud 微服务无损上下线探索与实践

文章目录 什么是无损上下线&#xff1f;大规模 Spring Cloud 微服务架构实现无损上下线的挑战无损上下线的实践1. 使用负载均衡器2. 使用数据库迁移工具3. 动态配置管理4. 错误处理和回滚 未来的趋势1. 容器编排2. 服务网格3. 自动化测试和验证 结论 &#x1f389;欢迎来到云原…

wires hark抓包内容解析

1.Frame 22001&#xff1a;这是该数据包的序号&#xff0c;表示wires hark已经捕获并显示了22001个数据包&#xff1b; 2.225 bytes on wire (1800 bits)&#xff1a;该数据的原始大小、以字节和比特显示&#xff1b; 3.225 bytes captured (1800 bits)&#xff1a;wires har…

经管博士科研基础【19】齐次线性方程组

1. 线性方程组 2. 非线性方程组 非线性方程,就是因变量与自变量之间的关系不是线性的关系,这类方程很多,例如平方关系、对数关系、指数关系、三角函数关系等等。求解此类方程往往很难得到精确解,经常需要求近似解问题。相应的求近似解的方法也逐渐得到大家的重视。 3. 线…

【C++ • STL • 力扣】详解string相关OJ

文章目录 1、仅仅翻转字母2、字符串中的第一个唯一字符3、字符串里最后一个单词的长度4、验证一个字符串是否是回文5、字符串相加总结 ヾ(๑╹◡╹)&#xff89;" 人总要为过去的懒惰而付出代价 ヾ(๑╹◡╹)&#xff89;" 1、仅仅翻转字母 力扣链接 代码1展示&…

【 OpenGauss源码学习 —— 列存储(analyze)(四)】

列存储&#xff08;analyze&#xff09; AcquireSampleCStoreRows 函数es_get_attnums_to_analyze 函数CStoreRelGetCUNumByNow 函数CStore::GetLivedRowNumbers 函数InitGetValFunc 函数CStoreGetfstColIdx 函数CStore::GetCUDesc 函数CStore::IsTheWholeCuDeleted 函数CStore…

Android扫码连接WIFI实现

0&#xff0c;目标 APP中实现扫WIFI分享码自动连接WIFI功能 1&#xff0c;前提条件 设备需要有个扫码器&#xff08;摄像头拍照识别也行&#xff09;&#xff0c;APP调用扫码器读取WIFI连接分享码。 2&#xff0c;增加权限 在AndroidManifest.xml中增加权限 <uses-permissi…

机器学习笔记 - 使用具有triplet loss的孪生网络进行图像相似度估计

一、简述 孪生网络是一种网络架构,包含两个或多个相同的子网络,用于为每个输入生成特征向量并进行比较。 孪生网络可以应用于不同的场景,例如检测重复项、发现异常和人脸识别。 此示例使用具有三个相同子网的孪生网络。我们将向模型提供三张图像,其中两张是相似的(锚点和正…

redis持久化、主从和哨兵架构

一、redis持久化 1、RDB快照&#xff08;snapshot&#xff09; redis配置RDB存储模式&#xff0c;修改redis.conf文件如下配置&#xff1a; # 在300s内有100个或者以上的key被修改就会把redis中的数据持久化到dump.rdb文件中 # save 300 100# 配置数据存放目录&#xff08;现…

算法通关村十四关:青铜-堆结构

青铜挑战-堆结构 堆结构&#xff1a;重要的基础数据结构 明确什么类型的题目可以用堆&#xff0c;以及如何用堆来解决 堆的构造和维护过程都非常复杂 1.堆的概念与特征 1.1基本概念 堆&#xff1a;是将一组数据按照 完全二叉树 的存储顺序&#xff0c;将数据存储在一个一…

【前端】在Vue页面中引入其它vue页面 数据传输 相互调用方法等

主页面 home 从页面 headView 需求 在 home.vue 中引用 headView.Vue 方案: home.vue 代码: 只需要在home.vue 想要的地方添加 <headView></headView> <script>//聊天页面 import headView /view/headView.vueexport default {components: {headView},…

CSDN每日一练 |『括号上色』『严查枪火』『数组排序』2023-09-09

CSDN每日一练 |『括号上色』『严查枪火』『数组排序』2023-09-09 一、题目名称:括号上色二、题目名称:严查枪火三、题目名称:数组排序一、题目名称:括号上色 时间限制:1000ms内存限制:256M 题目描述: 小艺酱又得到了一堆括号。 括号是严格匹配的。 现在给括号进行上色。…

简化转换器:使用您理解的单词进行最先进的 NLP — 第 1 部分 — 输入

一、说明 变形金刚是一种深度学习架构&#xff0c;为人工智能的发展做出了杰出贡献。这是人工智能和整个技术领域的一个重要阶段&#xff0c;但也有点复杂。截至今天&#xff0c;变形金刚上有很多很好的资源&#xff0c;那么为什么要再制作一个呢&#xff1f;两个原因&#xff…

5147. 数量

题目&#xff1a; 样例1&#xff1a; 输入 4 输出 1 样例2&#xff1a; 输入 7 输出 2 样例3&#xff1a; 输入 77 输出 6 思路&#xff1a; 根据题意&#xff0c;如果直接 for 循环暴力&#xff0c;肯定会超时&#xff0c;但是我们换个思路想&#xff0c;只要包含 4 和 7的…