Android性能:SurfaceFlinger与BufferQueue(3)

2024-05-15 08:28

本文主要是介绍Android性能:SurfaceFlinger与BufferQueue(3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android性能:SurfaceFlinger与BufferQueue(3)

Android显示系统的组成可以概括为两大部分:绘制(DrawFrame)+合成(SurfaceFlinger + HWC)
绘制:Surface中空的 GraphicBuffer->CPU或者GPU通过Canvas->将数据Draw到Surface。
合成:几块有数据的Buffer->叠合成一张Buffer->显示。
BufferQueue:android系统中每一张显示的图片都是GraphicBuffer,通过BufferQueue在不同进程间流动。SurfaceFlinger是Android渲染核心进程,应用的渲染最终都会来到SurfaceFlinger进行处理,最终会把处理后的图像数据交给CPU或者GPU进行绘制。
VYSNC:控制系统绘制与合成的节奏,按什么样的间隔出帧,也就是帧率。
● VSYNC-app 是app控制绘制帧率,Choregrapher,响应VSYNC-app。
● VSYNC-sf 是SurfaceFlinger控制合成过程的帧率的
● VSYNC-app/sf 通常这两者之间不会同时开始,会有一些offset。

BufferTx

DrawFrame里queueBuffer以后BufferTx会增加,SF起来响应拿走Buffer合成时会减少; BufferTx内有可用Buffer,SF才会真正去合成。
SF主进程结束点附近有数字对应到waiting for presentFence
● presentFence: 结束点代表SF送来的这一帧被显示到了屏幕上,并signal前一帧的Fence。
● OverlayEngine: HWC的主要进程,Trigger display driver做显示动作。

VSYNC和Fence相辅相成,
VSYNC:表示什么时间开始做事(绘制/合成)
Fence: 表示什么时间事情做完了(屏幕显示)

BufferQueue 作为共享资源,连接 Surface 和 SurfaceFlinger。其中,Surface 是资源生产者,SurfaceFlinger 是资源消费者。
BufferQueue 有四个核心操作:
dequeueBuffer:向 BufferQueue 申请一块空闲缓冲区(主流最大缓冲区数量为 64 个,之前为 32 个,通常设置为 2 个或者 3 个,即黄油计划中的双缓冲和三缓冲机制),发起方为生产者(Surface)。之前已经申请过的缓冲区可以被复用,如果不符合要求(比如还没有申请过,缓冲区参数不匹配等)则需要重新申请新的缓冲区。
queueBuffer:向 BufferQueue 插入一块填充了有效数据的缓冲区,发起方为生产者(Surface)。
acquireBuffer:从 BufferQueue 摘取一块填充了有效数据的缓冲区用于合成或显示消费,发起方为消费者(SurfaceFlinger)。
releaseBuffer:将消费完毕的缓冲区释放,并送回 BufferQueue,发起方为消费者。(SurfaceFlinger)。
缓冲队列中的每一块缓冲区也有四个核心状态:
FREE:初始状态,或者已被消费者 release,持有者为 BufferQueue,只能用于 dequeue 操作,可被 Surface 访问。
DEQUEUED:表示该块缓冲区已被生产者 dequeue,持有者为 Surface,只能用于 queue 操作,可被 Surface 访问。
QUEUED:表示该块缓冲区已经被生产者 queue,持有者为 BufferQueue,只能用于 acquire 操作,可被 SurfaceFlinger 访问。
ACQUIRED:表示该块缓冲区已经被消费者 aquire,持有者为 SurfaceFlinger,只能用于 release 操作,可被 SurfaceFlinger 访问。
生产者(Surface)、BufferQueue、消费者(SurfaceFlinger)三者之间的通信过程和缓冲区状态迁移:

层次图:

交互结构:

HWComposer是 SurfaceFlinger 用于与 HWC HAL 进行交互的代理。

SurfaceFlinger 合成的流程:
1 HWC 触发 vsync 信号:vsync 信号将以回调的方式通知 SurfaceFlinger,SurfaceFlinger 收到 vsync 回调后开始执行下一帧的合成。
2 SurfaceFlinger 更新图层:SurfaceFlinger 遍历各个有效图层,从其对应的 BufferQueue 中获取最新的单元窗口绘制数据,以对图层进行更新。这一步的 BufferQueue 中的缓冲区来自于预分配内存。
3 HWC :SurfaceFlinger 更新并准备好所有图层后,将图层参数告知 HWC HAL,HWC HAL 决定哪些图层可以执行 Device合成。
4 SurfaceFlinger 执行 Client合成:如果有 HWC 不能处理的图层,SurfaceFlinger 统一将它们交给 OpenGL 执行合成,其合成的数据作为一个普通合成窗口也插入到其对应的 BufferQueue 中,同时 SurfaceFlinger 还充当该 BufferQueue 的消费者将普通合成窗口取出并作为一个新的合成图层与其它普通图层一起准备交与 HWC 进行 Device合成。这一步 BufferQueue 中的缓冲区来自于 framebuffer,也就是说 Client合成数据已经直接 post 到 framebuffer 中。
5 HWC 执行 Device合成:HWC 将其余的图层连同 Client合成图层一起进行 Device合成。
6 HWC 将合成的帧 post 到 framebuffer 显示:要将帧显示出来,最终还是要将其 post 到 framebuffer 的 frontbuffer 中,这样显示控制器(display controller)才能从 framebuffer 中读取帧数据进行扫描/最终显示。

Android GPU渲染SurfaceFlinger合成RenderThread的dequeueBuffer/queueBuffer与fence机制(2)-CSDN博客文章浏览阅读643次,点赞11次,收藏15次。t 时长,20s,20秒的trace文件。CPU返回后,会直接将GraphicBuffer提交给SurfaceFlinger,告诉SurfaceFlinger进行合成,但是这个时候GPU可能并未完成之前的图像渲染,这时候就牵扯到一个同步,Android中,用的是Fence机制,SurfaceFlinger合成前会查询Fence,如果GPU渲染没有结束,则等待GPU渲染结束,GPU结束后,会通知SurfaceFlinger进行合成,SF合成后,提交显示,最终完成图像的渲染显示。就是 Buffer。https://blog.csdn.net/zhangphil/article/details/138628225

Android GPU渲染SurfaceFlinger合成RenderThread的dequeueBuffer/queueBuffer与fence机制(2)-CSDN博客文章浏览阅读317次,点赞8次,收藏10次。t 时长,20s,20秒的trace文件。CPU返回后,会直接将GraphicBuffer提交给SurfaceFlinger,告诉SurfaceFlinger进行合成,但是这个时候GPU可能并未完成之前的图像渲染,这时候就牵扯到一个同步,Android中,用的是Fence机制,SurfaceFlinger合成前会查询Fence,如果GPU渲染没有结束,则等待GPU渲染结束,GPU结束后,会通知SurfaceFlinger进行合成,SF合成后,提交显示,最终完成图像的渲染显示。就是 Buffer。https://blog.csdn.net/zhangphil/article/details/138628225Android adb shell命令捕获systemtrace_android 抓trace-CSDN博客文章浏览阅读1.7k次,点赞2次,收藏5次。Android ADB调试真机设备Android ADB(Andorid Debug Bridge),是Android开发中有用的测试和调试工具。使用Android ADB调试设备,直接在Windows的dos命令窗口输入命名adb即可,如图:为什么执行adb命令后是这样?Android ADB(Andorid Debug Bridge)调试真机设备_adb在线执行器_zhangphil的博客-CSDN博客。-t 时长,20s,20秒的trace文件。-o 保存文件路径。_android 抓tracehttps://blog.csdn.net/zhangphil/article/details/131249820卡顿丢帧分析adb shell命令-CSDN博客文章浏览阅读207次,点赞3次,收藏3次。Android ADB调试真机设备Android ADB(Andorid Debug Bridge),是Android开发中有用的测试和调试工具。使用Android ADB调试设备,直接在Windows的dos命令窗口输入命名adb即可,如图:为什么执行adb命令后是这样?Android ADB(Andorid Debug Bridge)调试真机设备_adb在线执行器_zhangphil的博客-CSDN博客。-t 时长,20s,20秒的trace文件。https://blog.csdn.net/zhangphil/article/details/137919380

Android GPU渲染屏幕绘制显示基础概念(1)-CSDN博客文章浏览阅读705次,点赞20次,收藏12次。CPU返回后,会直接将GraphicBuffer提交给SurfaceFlinger,告诉SurfaceFlinger进行合成,但是这个时候GPU可能并未完成之前的图像渲染,这时候就牵扯到一个同步,Android中,用的是Fence机制,SurfaceFlinger合成前会查询Fence,如果GPU渲染没有结束,则等待GPU渲染结束,GPU结束后,会通知SurfaceFlinger进行合成,SF合成后,提交显示,最终完成图像的渲染显示。而对SF来说,只要有合成任务,它就得再去申请VSYNC-sf。https://blog.csdn.net/zhangphil/article/details/138585120Android性能:Double Buffer双缓冲/Triple Buffer三缓冲丢帧Jank与无丢帧No Jank-CSDN博客文章浏览阅读860次,点赞6次,收藏13次。Android ADB调试真机设备Android ADB(Andorid Debug Bridge),是Android开发中有用的测试和调试工具。使用Android ADB调试设备,直接在Windows的dos命令窗口输入命名adb即可,如图:为什么执行adb命令后是这样?_android 抓trace。三Buffer轮转情况下,基本不会有这种情况的发生,渲染线程一般在 dequeueBuffer 时,都可以顺利拿到可用的 Buffer (如果 dequeueBuffer 本身耗时那就也会拉长时间)。https://blog.csdn.net/zhangphil/article/details/138213964

这篇关于Android性能:SurfaceFlinger与BufferQueue(3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/991310

相关文章

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Java慢查询排查与性能调优完整实战指南

《Java慢查询排查与性能调优完整实战指南》Java调优是一个广泛的话题,它涵盖了代码优化、内存管理、并发处理等多个方面,:本文主要介绍Java慢查询排查与性能调优的相关资料,文中通过代码介绍的非... 目录1. 事故全景:从告警到定位1.1 事故时间线1.2 关键指标异常1.3 排查工具链2. 深度剖析:

深入解析Java NIO在高并发场景下的性能优化实践指南

《深入解析JavaNIO在高并发场景下的性能优化实践指南》随着互联网业务不断演进,对高并发、低延时网络服务的需求日益增长,本文将深入解析JavaNIO在高并发场景下的性能优化方法,希望对大家有所帮助... 目录简介一、技术背景与应用场景二、核心原理深入分析2.1 Selector多路复用2.2 Buffer

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、