0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Systrace分析知识点介绍

哆啦安全 来源:程序员Android 2023-06-18 14:58 次阅读

一、抓取Systrace

1.1 使用手机抓取

使用Google 预留的开发者模式中的 系统跟踪 功能抓取systrace。

步骤:

设置--开发者模式--系统跟踪

trace文件保存路径:

/data/local/traces

22d80396-0da5-11ee-962d-dac502259ad0.png

手机抓取trace

抓取完之后使用adb 命令 pull 出来即可

C:Users >adb pull /data/local/traces .
/data/local/traces/: 1 file pulled, 0 skipped. 95.1 MB/s (51342186 bytes in 0.515s)

C:Users >

1.2 python 命令抓取

参考命令如下:

 python systrace.py -o mynewtrace.html sched freq idle am wm gfx view binder_driver hal dalvik camera input res

比较麻烦,需要安装环境,不推荐,有成熟脚本除外。

二、CPU模块知识点

2.1 CPU频率,CPU loading 计算

CPU loading 计算公式

CPU 负载loading = Wall duration ÷ 选择CPU 个数÷ 选择CPU的范围

22f2ec74-0da5-11ee-962d-dac502259ad0.png

CPU Loading

2.2 Thread 在CPU中的状态

绿色:运行中 Running

对于在CPU上执行的进程,需要查看其运行时间、是否跑在该跑的核上、频率是否够等。

浅绿色:可运行 Runnable

对于在等待序列中的进程,需要查看是否有过多任务在等待、等待时间是否过长等。

白色:休眠中 Sleeping

这里一般是在等事件驱动。

橘色:不可中断的睡眠态_IO_Block Uninterruptible Sleep | WakeKill - Block I/O

线程在I / O上被阻塞或等待磁盘操作完成。

紫色:不可中断的睡眠态 Uninterruptible Sleep

线程在另一个内核操作(通常是内存管理)上被阻塞。

举例如下:

233d9684-0da5-11ee-962d-dac502259ad0.png

Thread 在CPU中的状态

2.3 CPU 唤醒关系查看

首先点击查看当前线程正在哪个 CPU 中运行

23621b1c-0da5-11ee-962d-dac502259ad0.png

CPU 唤醒关系查看一

点击查看 Thread 的 箭头,既可以查看是被谁唤醒的

237d9afe-0da5-11ee-962d-dac502259ad0.png

CPU 唤醒关系查看二

三、input 点击事件处理流程

3.1 Android 点击事件处理流程概览

SystemServer AppLaunch_dispatchPtr:Up 处理点击up事件

SystemServer 通过InputReader读取屏幕点击事件后,将点击事件通过InputDispatcher 进行分发

SystemServer OutboundQueue 接收存放即将派发给AppConnection 的点击事件

SystemServer WaitQueue接收存放已经派发给AppConnection ,但 App还在处理且没有返回成功的点击事件

Launcher deliverInputEvent: Launcher 桌面 被input事件唤醒

Camera APP bind 通过跟SystemServer bind 调用,开始启动Camera

3.2 Android 点击事件处理流程图

Android 点击事件处理流程图如下:

23af855a-0da5-11ee-962d-dac502259ad0.png

Android 点击事件处理流程图

3.2 Android 点击事件处理关键TAG

TAG名字 所在进程 备注
AppLaunch_dispatchPtr:Down SystemServer 点击Down事件
AppLaunch_dispatchPtr:Up SystemServer 点击up事件
InputReader SystemServer 点击事件读取
InputDispatcher SystemServer 点击事件分发
oq SystemServer OutBoundQueue 点击事件存放
wq SystemServer WaitQueue 点击事件待消费返回
deliverInputEvent Launcher app 点击事件消费

四、Vsync 事件处理

Vsync 信号可以由硬件产生,也可以用软件模拟,不过现在基本上都是硬件产生,负责产生硬件 Vsync 的是 HWC,HWC 可生成 VSYNC 事件并通过回调将事件发送到 SurfaceFlinger , DispSync 将 Vsync 生成由 Choreographer 和 SurfaceFlinger 使用的 VSYNC_APP 和 VSYNC_SF 信号

4.1 VSYNC_app信号app处理

第一阶段:
App 在收到 Vsync-App 的时候,在主线程进行 measure、layout、draw(构建 DisplayList , 里面包含 OpenGL 渲染需要的命令及数据) 。这里对应的 Systrace 中的主线程 doFrame 操作

第二阶段:
CPU 将数据上传(共享或者拷贝)给 GPU,这里 ARM 设备 内存一般是 GPU 和 CPU 共享内存。这里对应的 Systrace 中的渲染线程的 flush drawing commands 操作

第三阶段:
通知 GPU 渲染,真机一般不会阻塞等待 GPU 渲染结束,CPU 通知结束后就返回继续执行其他任务,使用 Fence 机制辅助 GPU CPU 进行同步操作

第四 阶段:
swapBuffers,并通知 SurfaceFlinger 图层合成。这里对应的 Systrace 中的渲染线程的 eglSwapBuffersWithDamageKHR 操作
VSYNC_app信号处理流程如下:

23e6e7fc-0da5-11ee-962d-dac502259ad0.png

VSYNC_app信号处理

4.2 VSYNC_sf 信号SF处理

第五阶段:
SurfaceFlinger 开始合成图层,如果之前提交的 GPU 渲染任务没结束,则等待 GPU 渲染完成,再合成(Fence 机制),合成依然是依赖 GPU,不过这就是下一个任务了.这里对应的 Systrace 中的 SurfaceFlinger 主线程的 onMessageReceived 操作(包括 handleTransaction、handleMessageInvalidate、handleMessageRefresh)SurfaceFlinger 在合成的时候,会将一些合成工作委托给 Hardware Composer,从而降低来自 OpenGL 和 GPU 的负载,只有 Hardware Composer 无法处理的图层,或者指定用 OpenGL 处理的图层,其他的 图层偶会使用 Hardware Composer 进行合成

第六阶段 :
最终合成好的数据放到屏幕对应的 Frame Buffer 中,固定刷新的时候就可以看到了
VSYNC_sf 信号SF处理流程如下:

24226340-0da5-11ee-962d-dac502259ad0.png

VSYNC_sf 信号SF处理

五、Android 绘制一帧流程分析

5.1 显示一帧流程概览

244e5450-0da5-11ee-962d-dac502259ad0.jpg

程序员Android

5.1.1 Android 显示一帧大致分为下面 八步:

App 接收到 vsync-app 信号后开始工作。

App 主线程被Message唤醒,执行onVsync。

App 执行 doFrame ,处理input、animation、traversal、draw等。

App UIThread 跟RenderThread sync 数据。

App 执行DrawFrame,从SurfaceFlinger(后续简称SF) 的 BufferQueue 中 Dequeue buffer,取出一个bufffer后,执行渲染绘制,接着将绘制好的Buffer 通过queuebuffer 放回到。BufferQueue中给 SF消费。

App queuebuffer 后, SF 中对应的 app buffer 会增加 +1。

Vsync-sf 到来后,SF 从BufferQueue 中 acquireBuffer一个Buffer 进行消费, 对应SF 中的 app buffer 会减 - 1 , SF 消费处理后,通过 releaseBuffer 将buffer 归还到BufferQueue 中。

SF 通过 bind 跟 Hardware Composer HAL(简称HWC) 进行通信,通过一些处理后显示到手机屏幕上。

5.2 生产者,消费者 BufferQueue 流转图

24806774-0da5-11ee-962d-dac502259ad0.jpg

生产者,消费者 BufferQueue 流转图

dequeue(生产者发起) :
当生产者需要缓冲区时,它会通过调用 dequeueBuffer() 从 BufferQueue 请求一个可用的缓冲区,并指定缓冲区的宽度、高度、像素格式和使用标记。

queue(生产者发起):
生产者填充缓冲区并通过调用 queueBuffer() 将缓冲区返回到队列。

acquire(消费者发起) :
消费者通过 acquireBuffer() 获取该缓冲区并使用该缓冲区的内容

release(消费者发起) :
当消费者操作完成后,它会通过调用 releaseBuffer() 将该缓冲区返回到队列

5.3 App ,SF Buffer 交互图

24a23426-0da5-11ee-962d-dac502259ad0.jpg

App ,SF Buffer 交互图

App 通过bind 向SF dequeuebuffer 进行buffer申请

SF 对端完成对bufferQueue 的dequeuebuffer的申请

App 处理合成完后,通过binder向SF queuebuffer 申请buffer 入队。

SF 对端通过queuebuffer 完成buffer 对BufferQueue的入队申请,供SF消费并显示到屏幕上

5.4 SF 跟 HWC 交互图

SurfaceFlinger 接受来自多个来源的数据缓冲区,对它们进行合成,然后发送到显示设备。

24d17696-0da5-11ee-962d-dac502259ad0.jpg

SF 送显图

24e64094-0da5-11ee-962d-dac502259ad0.jpg

SF 跟 HWC 交互图

vsync-sf 周期到来,SF 开始绘制准备工作

SF 通过 acquirebuffer 从BufferQueue 中取出一帧进行消费

App 对应的BufferQueue 在SF acquirebuffer 后对那个的值会 -1

App 对应的buffer 值为 2

App 对应的buffer值 在SF acquirebuffer 后变为 1

SF 跟HWC 通过binder 通信处理完后,通过rleasebuffer将buffer 归还到BufferQueue中,紧接着一帧就可以显示出来

六、Camx Trace TAG开启方法

6.1 打开 Camx HAL 层 camx log tag

执行以下命令,打开camx trace log tag

     adb root
     adb remount
     adb shell mkdir /vendor/etc/camera
     adb shell rm -rf  /vendor/etc/camera/camxoverridesettings.txt
     adb shell touch  /vendor/etc/camera/camxoverridesettings.txt
     adb shell "echo traceGroupsEnable=0x10080 >> /vendor/etc/camera/camxoverridesettings.txt"
     adb shell "echo traceErrorEnable=TRUE >> /vendor/etc/camera/camxoverridesettings.txt"
     adb shell "echo traceOutputEnable=0x10080 >> /vendor/etc/camera/camxoverridesettings.txt"
     adb shell cat /vendor/etc/camera/camxoverridesettings.txt
     adb reboot

6.2 重启手机后打开kernel 的trace开关

重启后打开kernel trace 开关

       adb root
       adb remount
       adb shell "echo 1 > /sys/kernel/tracing/events/camera/enable"





审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • ARM
    ARM
    +关注

    关注

    134

    文章

    9042

    浏览量

    366734
  • OpenGL
    +关注

    关注

    1

    文章

    85

    浏览量

    29214
  • python
    +关注

    关注

    55

    文章

    4779

    浏览量

    84440
  • HAL库
    +关注

    关注

    1

    文章

    114

    浏览量

    6168

原文标题:Systrace分析知识点

文章出处:【微信号:哆啦安全,微信公众号:哆啦安全】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    C语言链表知识点(2)

    C语言链表知识点(2)
    发表于 08-22 10:38 313次阅读
    C语言链表<b class='flag-5'>知识点</b>(2)

    电机与拖动知识点及其试题

    电机与拖动知识点分析一、基本知识与基础知识知识点常考题目二、直流电机一、基本知识与基础
    发表于 06-29 07:10

    计算机组成原理考研知识点归纳

    计算机组成原理考研知识点归纳 写在前面的话:理科知识重在于理解知识点本身,对于每一个知识点,大家都有自己理解的方式。这篇
    发表于 04-13 14:06 1918次阅读

    高一数学知识点总结

    高一数学知识点总结高一数学知识点总结高一数学知识点总结
    发表于 02-23 15:27 0次下载

    高二数学知识点总结

    高二数学知识点总结高二数学知识点总结高二数学知识点总结
    发表于 02-23 15:27 0次下载

    SI、PI、EMC、RF知识点

    SI、PI、EMC、RF知识点
    发表于 01-14 02:53 17次下载

    PWM知识点详解

    PWM知识点
    发表于 03-16 08:00 44次下载

    Python的基础语法知识点大全

    本文档的主要内容详细介绍的是Python的基础语法知识点大全。
    发表于 06-12 08:00 1次下载

    嵌入式知识点总结

    嵌入式知识点总结(arm嵌入式开发led过程)-嵌入式知识点总结                    
    发表于 07-30 14:20 23次下载
    嵌入式<b class='flag-5'>知识点</b>总结

    电力基础知识点合集

    电力基础知识点合集
    发表于 03-14 16:35 0次下载

    详解射频微波基础知识点

    详解射频微波基础知识点
    的头像 发表于 01-29 10:28 2302次阅读

    C语言最重要的知识点

    C语言知识点总结.doc
    发表于 02-16 16:37 9次下载

    数字电路知识点总结

    本文整理了数字电路课程中的相关基本的知识点和较为重要的知识点,用于求职的数电部分的知识准备,差缺补漏。
    的头像 发表于 05-30 15:07 4683次阅读
    数字电路<b class='flag-5'>知识点</b>总结

    滚珠螺杆的基本知识点

    滚珠螺杆的基本知识点
    的头像 发表于 07-07 17:40 1477次阅读
    滚珠螺杆的基本<b class='flag-5'>知识点</b>

    STM32 RTOS知识点

    电子发烧友网站提供《STM32 RTOS知识点.pdf》资料免费下载
    发表于 08-01 14:28 3次下载
    STM32 RTOS<b class='flag-5'>知识点</b>