骁龙相机启动流程分析

2024-06-21 13:12

本文主要是介绍骁龙相机启动流程分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、骁龙相机启动流程分析

1. 相机启动阶段关键TAG

关键字解释
deliverInputEvent点击事件
bindApplicationApp 冷启动 创建application
activityStart创建camera activity
activityResumecamera UI界面开始显示
connectDevicecameraFWK 开始链接并open sensor
CameraHal::openSessionCamera FWK 响应 opencamera
camera_module->openHAL 响应 opencamera
HAL3OpenHAL 开始准备opencamera
constructDefaultRequestSettings获取Camera request setting 比如一下metadata等
createStream创建配流信息,可以查看配几路流
endConfigure配流结束
CameraHal::configureStreamsCamera FWK 配流阶段常用搜索关键字
HAL3ConfigureStreamsCamera HAL 配流阶段常用关键字
AdvancedCameraUsecase::Initializechi usecase 初始化
submitRequestList,setRepeatingRequests发起预览请求
CameraHal::processBatchCaptureRequests下发预览请求
HAL3ProcessCaptureRequestcamera HAL 响应第0帧预览请求
CSLStreamOn,KMDStreamON: DevType20sensor 开始streamon
HAL3ProcessCaptureRequest : 1Camera HAL 响应第一次预览请求
Stream 0: first full bufferCamera FWK接收到返回第一帧
SurfaceView[org.codeaurora.snapcam/com.android.camera.CameraLauncher]#1(BLAST Consumer)1Camera app 接收第一帧
BufferTX - SurfaceVieworg.codeaurora.snapcam/com.android.camera.CameraLauncher#529Surfaceflinger bufferTX 用来存储buffer 供SF 消费
VSYNC-sfSF 开始绘制处理,对应的BufferTX - 1
prepareFrameSF开始预处理帧
HwcPresentOrValidateDisplaySF 与HWC进行通信验证显示
postComposition Last HWVsyncHintpost 显示合成结果
presentFence fence 155,waiting for presentFence 155,REThreaded::mapExternalTextureBuffer上屏显示(SF不太熟大致是这个时候屏幕可以显示处理)

2. 相机启动阶段拆解

阶段模块关键字备注
S0systemdeliverInputEvent---> ZygoteInit之前 app 开始running的地方创建 camera app
S1APPapp 开始running的地方--->connectDevice 开始Camera App 开始请求openCamera
S2Camera HALconnectDeviceHAL 处理open camera 操作
S3Camera APP、FWKconnectDevice 结束--->CameraHidlHal::constructDefaultRequestSettings-->createStream-->endConfigure start请求配流
S4Camera HALCameraHal::configureStreamsCamera HAL 响应配流
S5Camera APPCameraHal::configureStreams 结束 -->submitRequestList、setRepeatingRequests请求预览
S6Camera HALsubmitRequestList、setRepeatingRequests--> first full bufferCamera HAL 返回第一帧
S7SFfirst full buffer-->上屏显示SF送显阶段

3. 相机启动阶段概览

01b95bae78b1d192c86773a8f80c4171.png
相机启动阶段概览

4. 相机启动阶段详解

S0 :Launcher 点击Camera Icon 响应事件到Camera app 创建

d96bd79725fa0c6f5ee9259fd2dee567.png
S0 :Launcher 点击Camera Icon 响应事件到Camera app 创建

S1: Camera APP UI 创建 到 OpenCamera 开始

5b9deae566f0dba4c6c95861df5dae66.png
S1: Camera APP UI 创建 到 OpenCamera 开始

S2 Camera HAL 响应 opencamera

0f192aaf52b1fec5df1159d6ab8a7ad3.png
S2 : Camera HAL 响应 opencamera

S3:APP开始下发请求配流

703fbf9ef51c1f0e1f6b3224a65ba552.png
S3:APP开始下发请求配流

对应log中创建的2路流如下:

Line 10538: 06-19 18:09:04.173  1907  3718 I CameraDeviceClient: createStream : stream size is 960 x 720Line 10543: 06-19 18:09:04.180  1907  3718 I CameraDeviceClient: createStream : stream size is 4608 x 3456

S4: Camera HAL 响应配流

f6180143ddf01ab5b7d64a0dd001f180.png
S4: Camera HAL 响应配流

S5:请求预览 startpreview

3cd817449cd6abef63707db26a5d936d.png
S5:请求预览 startpreview

S6: Camera HAL callback 首帧请求结果

71e3bfa92e6c4aaebb725ba41f5c0cea.png
S6: Camera HAL callback 首帧请求结果
6.1 一帧callback流程

一帧数据传输通过Binder 进行
Camera HAL: HAL3ProcessCaptureResult
--->
Camera FWK: processCaptureResult
--->
Camera App: onFrameAvaillable
--->
SF: SurfaceView +1
SF: BufferTX SurfaceView +1
SF:QueueBuffer +1


c21d240f5dd0ed0b8517c65953c5dd84.png
一帧callback流程

S7: Surface 送显上屏阶段

  1. App queuebuffer 后SurfaceView +1
  2. Vsync-sf 到来后SF 从BufferQueue中取出app 送显帧进行消费合成
  3. SF跟HWC通过bind通信后,调用postComposition Last HWVsyncHint ,在对应 presentFence fence 到来后,调用SF的REThreaded::mapExternalTextureBuffer 开始上屏显示(非display研发,待理清上屏显示的真正时间)


    d4e885d73d789db4a6cc88b8e466535a.png
    Surface 送显上屏阶段

这篇关于骁龙相机启动流程分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

Spring事务中@Transactional注解不生效的原因分析与解决

《Spring事务中@Transactional注解不生效的原因分析与解决》在Spring框架中,@Transactional注解是管理数据库事务的核心方式,本文将深入分析事务自调用的底层原理,解释为... 目录1. 引言2. 事务自调用问题重现2.1 示例代码2.2 问题现象3. 为什么事务自调用会失效3

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

找不到Anaconda prompt终端的原因分析及解决方案

《找不到Anacondaprompt终端的原因分析及解决方案》因为anaconda还没有初始化,在安装anaconda的过程中,有一行是否要添加anaconda到菜单目录中,由于没有勾选,导致没有菜... 目录问题原因问http://www.chinasem.cn题解决安装了 Anaconda 却找不到 An

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑

Spring AI ectorStore的使用流程

《SpringAIectorStore的使用流程》SpringAI中的VectorStore是一种用于存储和检索高维向量数据的数据库或存储解决方案,它在AI应用中发挥着至关重要的作用,本文给大家介... 目录一、VectorStore的基本概念二、VectorStore的核心接口三、VectorStore的

Spring、Spring Boot、Spring Cloud 的区别与联系分析

《Spring、SpringBoot、SpringCloud的区别与联系分析》Spring、SpringBoot和SpringCloud是Java开发中常用的框架,分别针对企业级应用开发、快速开... 目录1. Spring 框架2. Spring Boot3. Spring Cloud总结1. Sprin