高通平台Display显示架构

目录


一、显示整体架构


二、SurfaceFlinger

SurfaceFlinger是一个系统服务,如:audioflinger等等,这个系统服务主要实现了Surface的建立、控制、管理等功能。换种说法就是,在Android 的实现中它是一个service,提供系统范围内的surface composer功能,它能够将各种应用程序的2D、3D surface进行组合。

SurfaceFlinger是整个Android系统渲染的核心进程。所有应用的渲染逻辑最终都会来到SF中进行处理,最终会把处理后的图像数据交给CPU或者GPU进行绘制,在每一个应用中都以Surface作为一个图元传递单元,向SF这个服务端传递图元数据。
目前SurfaceFlinger中支持两种合成方式,一种是Device合成,一种是Client合成。SurfaceFlinger 在收集可见层的所有缓冲区之后,便会询问Hardware Composer应如何进行合成。

  • 1、Device合成
    Device合成方式是相对与硬件合成来说的,其合成方式是,将各个Layer的内容用GPU渲染到暂存缓冲区中,最后将暂存缓冲区传送到显示硬件。这个暂存缓冲区,我们称为FBTarget,每个Display设备有各自的FBTarget。Device合成,之前称为GLES合成,我们也可以称之为GPU合成。Device合成,采用RenderEngine进行合成。
  • 2、Client合成
    Client合成就是用专门的硬件合成器进行合成HWComposer,所以硬件合成的能力就取决于硬件的实现。其合成方式是将各个Layer的数据全部传给显示硬件,并告知它从不同的缓冲区读取屏幕不同部分的数据。

三、HWC

HWC是Android中进行窗口合成和显示的HAL层模块,通常是由OEM实现并完成,为SurfaceFlinger提供硬件支持。

SurfaceFlinger可以使用OpenGL ES合成Layer,这需要占用并消耗GPU资源。大多数GPU都没有针对图层合成进行优化,因此当SurfaceFlinger通过GPU合成图层时,应用程序无法使用GPU进行自己的渲染。而HWC通过硬件设备进行图层合成,可以减轻GPU的合成压力

HWC合成机制:

  1. SurfaceFlinger向HWC提供所有Layer的完整列表,让HWC根据其硬件能力,决定如何处理这些Layer
  2. HWC会为每个Layer标注合成方式,表明是通过GPU还是通过HWC合成
  3. SurfaceFlinger负责先把所有注明GPU合成的Layer合成到一个输出Buffer,然后把这个输出Buffer和其他Layer(注明HWC合成的Layer)一起交给HWC,让HWC完成剩余Layer的合成和显示

四、Gralloc

在android中,HAL层的gralloc库负责申请图形缓冲区的所有工作,HAL层之上的Surface、BufferQueue最终都是调用gralloc库去申请图形缓冲区,然后返回给上层一个buffer_handle_t

gralloc分配framebuff图形缓冲区

gralloc调用gralloc_alloc_framebuffer()分配framebuffer的内存,其核心是对fb设备/dev/graphics/fb或者/dev/fb执行mmap(),映射到用户空间

gralloc分配普通图形缓冲区

普通图形缓冲去则是通过gralloc_alloc_buffer()分配内存的


五、DisplayManagerService

DisplayManagerServices主要是用来管理显示的生命周期,它决定如何根据当前连接的物理显示设备控制其逻辑显示,并且在状态更改时,向系统和应用程序发送通知。

默认支持4种显示类型:

  1. LocalDisaplay:本地物理屏幕显示设备,DMS启动之后通过SurfaceFlinger获取物理屏数据
  2. OverlayDisplay: 模拟辅助显示设备, 开发者选项->模拟辅助显示
  3. WIFIDisplay: 无线连接显示设备, Wifi连接显示的物理屏幕
  4. VirtualDisplay: 虚拟显示设备,如VR ,屏幕录制

提供上层访问的主要接口:

  • public Display[ ] getDisplays():获取当前所有有效的logic display列表
  • public Display getDisplay(int displayId):根据displayId获取logic display的信息
  • public void registerDisplayListener(DisplayListener listener, Handler handler):
    注册显示器监听事件,用来监听显示器的新增,删除,变更等事件
  • public void unregisterDisplayListener(DisplayListener listener):
    取消显示器监听事件

六、WindowManagerService

WindowManagerService是WindowManager的管理者,负责窗口的启动、添加和删除,WindowManager会监控窗口的生命周期、输入事件、屏幕方向、旋转、动画、位置等多种状态,同时会将所有窗口的元数据发送给SurfaceFlinger,SurfaceFlinger使用这些数据在屏幕上合成Surface。


相关推荐
studyForMokey5 小时前
kotlin 函数类型接口lambda写法
android·开发语言·kotlin
梁同学与Android8 小时前
Android --- 新电脑安装Android Studio 使用 Android 内置模拟器电脑直接卡死,鼠标和键盘都操作不了
android·ide·android studio
山雨楼10 小时前
ExoPlayer架构详解与源码分析(14)——ProgressiveMediaPeriod
android·架构·音视频·源码·exoplayer·media3
IsaacBan12 小时前
XJBX-6-Android启动App进程
android
DoubleYellowIce12 小时前
Android Studio阅读frameworks源码的正确姿势
android·android studio
分享者花花12 小时前
最佳 iPhone 解锁软件工具,可免费下载用于电脑操作的
android·windows·macos·ios·pdf·word·iphone
小菜琳17 小时前
Android显式启动activity和隐式启动activity分别都是怎么启动?请举例说明二者使用时的注意事项。
android
许进进17 小时前
FlutterWeb渲染模式及提速
android·flutter·web
helson赵子健18 小时前
Rust 在 Android 中的应用
android·架构·rust
2401_8523867119 小时前
苹果ios安卓apk应用APP文件怎么修改手机APP显示的名称
android·智能手机