当前位置: 首页 > ai >正文

相机Camera日志分析之二十五:高通相机Camx 基于预览1帧的process_capture_request四级日志分析详解

【关注我,后续持续新增专题博文,谢谢!!!】

上一篇我们讲了相机Camera日志分析之二十四:高通相机Camx 基于预览1帧的process_capture_request三级日志分析详解 ok

        这一篇我们开始讲 相机Camera日志分析之二十五:高通相机Camx 基于预览1帧的process_capture_request四级日志分析详解

目录

一、背景

二、:process_capture_request四级日志如下

三、:process_capture_request四级日志分析详解

四、:process_capture_request四级日志关键字

五、:总结


一、背景

1:【效率决定成长空间】无论什么开发,分析日志是解决问题的法宝。且是最有效最常用的调试工具,特别是在Android或Linux领域下,log分析是开发必备技能,然而log分析效率参差不齐,你分析一份日志要一天,别人分析只需要一个小时,作何感想?别人一年的学习成果可能是你几年才能学会。

2:【巨量日志降低了开发效率】接触过Android日志,就清楚日志量非常大。几十个进程几百个线程同时并行打印日志。而Camera领域日志量极大,因为预览一般是每秒30帧的日志量,录屏一般是每秒60帧的日志量,少则几万行日志,多则几十万行日志,更多则多个日志总量几百万行日志。

3:【日志梯度分级来提效】开发追求效率,如何快速有效挖掘出问题,并如何解决问题变得尤为重要。此专题将以梯度分级日志来分析日志,让日志流程变得简单化,提高解决问题的效率。

4:【举一反三】当前以高通CamX架构为例讲解Camera日志,方式通用,其他领域模块均可效仿借鉴。

5:【开发思维决定成长高度】当前讲述的是Camera领域log分析梯度分级讲解,讲究的是一种分析技巧,分析思维,一种感悟。技术路线的提升空间,需要更多开发技巧和开发学习能力去提升。技术大拿分析问题,可以从日志快速定位问题并解决问题,有充分的时间去学习更多知识,成长速度极快。同一起跑线,学习能力,开发效率等等都决定了程序员的成长提升空间。记得我毕业三年,同学之间的差距无限拉大,一些人还在几千块薪水,你已经是他的四五倍了,人与人的差距就是短短几年就拉开了。

二、:process_capture_request四级日志如下

PS:搜索类似【Start proc】中括号就有颜色体现了。

这里添加了【 关键字,过滤的是核心简化的核心流程日志过程,更加直观调用整个流程。

CamX    : 【setRepeatingRequest】----------------------------------------------------------【app开始下发请求,开始预览】
CamX    : [ERROR][HAL    ] camxhaldevice.cpp:1325 【PopulateFrameworkRequestBuffer()】 : 【填充预览setRepeatingRequest或拍照Capture的buffer,预览不断调用,拍照调用一次 】
CHIUSECASE: [FULL   ] chxusecase.cpp:1000 UpdateFeatureModeIndex() 【UpdateFeatureModeIndex E】【更新FeatureMode Index】
CHIUSECASE: [ERROR  ] chxadvancedcamerausecase.cpp:5007 ExecuteCaptureRequest() AdvancedCameraUsecase::ExecuteCaptureRequest 0 0,【beauty_open_flag 0】【美颜开关】
CHIUSECASE: [INFO   ] chxadvancedcamerausecase.cpp:5026 ExecuteCaptureRequest() AdvancedCameraUsecase::ExecuteCaptureRequest 0 0,【beauty_param_level 1】【美颜级别】
CHIUSECASE: [FULL   ] chxutils.cpp:872 GetFeature1Mode() Utils 【Feature1 mode 0】【获取Feature Mode】
CHIUSECASE: [VERBOSE] chxutils.cpp:1307 【FillTuningModeData()】【填充效果数据】 SensorMode 0 UC 0 feature 0 0 scene 0 effect 0
CHIUSECASE: [ERROR  ] chxutils.cpp:932 【PopulateHALToChiStreamBuffer()】 bruceChiLog: 	【填充HAL到ChiStreamBuffer】
CHIUSECASE: [ERROR  ] chxadvancedcamerausecase.cpp:2245 GetOutputBufferFromRDIQueue() bruceChiLog: GetTargetBufferPointer【获取目标buffer指针】
CHIUSECASE: [ERROR  ] chxusecaseutils.cpp:2498 GetImageBufferInfo() bruceChiLog:  pGetImageBuffer【获取ImageBuffer】
CamX    : [ERROR][HAL    ] camxchi.cpp:1737 ChiBufferManagerGetImageBuffer() bruceChiLog: 【通过ImageBufferManager获取ImageBuffer】
CHIUSECASE: [ERROR  ] chxusecaseutils.cpp:2498 GetImageBufferInfo() bruceChiLog:  pGetImageBuffer【获取ImageBuffer】
CamX    : [ERROR][HAL    ] camxchi.cpp:1737 ChiBufferManagerGetImageBuffer() bruceChiLog: 【通过ImageBufferManager获取ImageBuffer】
CHIUSECASE: [FULL   ] chxadvancedcamerausecase.cpp:6456 【SetRequestToFeatureMapping()】【设置Request到Feature Map】 Current index 0 RequestCount 0 sessionId 1 requestId 0 pFeature 0x74a962e800 type 1
CamX    : [ERROR][HAL    ] camxsession.cpp:2531 【ProcessRequest()】【Request传递到session】 : 
CamX    : [ERROR][HAL    ] camxpipeline.cpp:802 【OpenRequest()】【Request传递到pipeline】 : 
CamX    : [ERROR][HAL    ] camxnode.cpp:1442 【SetupRequest()】【Request传递到node】 : 
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【ChiNodeWrapper】Node设置Request Output Port Fence】, Request 1, PortId 0, GroupID 1, Fence 1, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【ChiNodeWrapper】Node设置Request Output Port Fence】,Fence 1, total refCount 2, port[0] count 2
CamX    : [ERROR][HAL    ] camxhaldevice.cpp:1325 PopulateFrameworkRequestBuffer() : 【填充预览setRepeatingRequest或拍照Capture的buffer,预览不断调用,拍照调用一次 】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】Node设置Request Output Port Fence】, Request 1, PortId 6, GroupID 5, Fence 2, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】Node设置Request Output Port Fence】,Fence 2, total refCount 4, port[6] count 4
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 9, GroupID 8, Fence 3, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 3, total refCount 2, port[9] count 2
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 17, GroupID 3, Fence 4, primary 1
CHIUSECASE: [FULL   ] chxusecase.cpp:1000 UpdateFeatureModeIndex() 【UpdateFeatureModeIndex E】【更新feature mode index】
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 4, total refCount 3, port[17] count 3
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 21, GroupID 3, Fence 4, primary 0
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 4, total refCount 6, port[21] count 3
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 18, GroupID 3, Fence 4, primary 0
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 4, total refCount 9, port[18] count 3
CHIUSECASE: [ERROR  ] chxadvancedcamerausecase.cpp:2245 GetOutputBufferFromRDIQueue() bruceChiLog: GetTargetBufferPointer【获取目标buffer指针】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 16, GroupID 3, Fence 4, primary 0
CHIUSECASE: [ERROR  ] chxusecaseutils.cpp:2498 GetImageBufferInfo() bruceChiLog:  pGetImageBuffer【获取ImageBuffer】
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 4, total refCount 11, port[16] count 2
CamX    : [ERROR][HAL    ] camxchi.cpp:1737 ChiBufferManagerGetImageBuffer() bruceChiLog: 【通过ImageBufferManager获取ImageBuffer】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 19, GroupID 3, Fence 4, primary 0
CHIUSECASE: [ERROR  ] chxusecaseutils.cpp:2498 GetImageBufferInfo() bruceChiLog:  pGetImageBuffer【获取ImageBuffer】
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 4, total refCount 13, port[19] count 2
CamX    : [ERROR][HAL    ] camxchi.cpp:1737 ChiBufferManagerGetImageBuffer() bruceChiLog: 【通过ImageBufferManager获取ImageBuffer】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 12, GroupID 3, Fence 4, primary 0
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 4, total refCount 16, port[12] count 3
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【FDHw】】, Request 1, PortId 2, GroupID 2, Fence 10, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【FDHw】】,Fence 10, total refCount 2, port[2] count 2
CamX    : [ERROR][HAL    ] camxhaldevice.cpp:1325 PopulateFrameworkRequestBuffer() : 【填充预览setRepeatingRequest或拍照Capture的buffer,预览不断调用,拍照调用一次 】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【LRME】】, Request 1, PortId 0, GroupID 2, Fence 11, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【LRME】】,Fence 11, total refCount 2, port[0] count 2
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:402 【AddDependencyEntry() 】【DRQ增加依赖】Adding dependencies for node: 0 NodeName: 【【Sensor:0】】 pipeline: 0 request: 36 seqId: 1 bindIOBuffers: 0
CamX    : [ERROR][HAL    ] camxnode.cpp:2656 【ProcessRequestIdDone】() : PipelineName:【【ZSLPreviewRaw】】 Node 【【ZSLPreviewRaw_Stats0】】, pipeline: 0, is done with request 35
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:402 AddDependencyEntry() Adding dependencies for node: 5 NodeName: 【【AutoFocus:0】】 pipeline: 0 request: 36 seqId: 1 bindIOBuffers: 1
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:1137 GetUnpublishedList() Unpublished list [0] for NodeName:【【AutoFocus】】 property: 30000007, request 36 pipeline: 0
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:402 AddDependencyEntry() Adding dependencies for node: 5 NodeName: 【【AutoFocus:0】】 pipeline: 0 request: 36 seqId: 2 bindIOBuffers: 1
CHIUSECASE: [ERROR  ] chxadvancedcamerausecase.cpp:2245 GetOutputBufferFromRDIQueue() bruceChiLog: GetTargetBufferPointer【获取目标buffer指针】
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:1137 GetUnpublishedList() Unpublished list [0] for NodeName:【【IFE】】 property: 30000042, request 36 pipeline: 0
CHIUSECASE: [ERROR  ] chxusecaseutils.cpp:2498 GetImageBufferInfo() bruceChiLog:  pGetImageBuffer【获取ImageBuffer】
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:1137 GetUnpublishedList() Unpublished list [1] for NodeName:【【IFE】】 property: 30000000, request 36 pipeline: 0
CamX    : [ERROR][HAL    ] camxchi.cpp:1737 ChiBufferManagerGetImageBuffer() bruceChiLog: 【通过ImageBufferManager获取ImageBuffer】

三、:process_capture_request四级日志分析详解

CamX    : [ERROR][HAL    ] camxhaldevice.cpp:1325 【PopulateFrameworkRequestBuffer()】 : 【填充预览setRepeatingRequest或拍照Capture的buffer,预览不断调用,拍照调用一次 】
CHIUSECASE: [FULL   ] chxusecase.cpp:1000 UpdateFeatureModeIndex() 【UpdateFeatureModeIndex E】【更新FeatureMode Index】
CHIUSECASE: [ERROR  ] chxadvancedcamerausecase.cpp:5007 ExecuteCaptureRequest() AdvancedCameraUsecase::ExecuteCaptureRequest 0 0,【beauty_open_flag 0】【美颜开关】
CHIUSECASE: [INFO   ] chxadvancedcamerausecase.cpp:5026 ExecuteCaptureRequest() AdvancedCameraUsecase::ExecuteCaptureRequest 0 0,【beauty_param_level 1】【美颜级别】
CHIUSECASE: [FULL   ] chxutils.cpp:872 GetFeature1Mode() Utils 【Feature1 mode 0】【获取Feature Mode】
CHIUSECASE: [VERBOSE] chxutils.cpp:1307 【FillTuningModeData()】【填充效果数据】 SensorMode 0 UC 0 feature 0 0 scene 0 effect 0
CHIUSECASE: [ERROR  ] chxutils.cpp:932 【PopulateHALToChiStreamBuffer()】 bruceChiLog:     【填充HAL到ChiStreamBuffer】
CHIUSECASE: [ERROR  ] chxadvancedcamerausecase.cpp:2245 GetOutputBufferFromRDIQueue() bruceChiLog: GetTargetBufferPointer【获取目标buffer指针】
CHIUSECASE: [ERROR  ] chxusecaseutils.cpp:2498 GetImageBufferInfo() bruceChiLog:  pGetImageBuffer【获取ImageBuffer】
CamX    : [ERROR][HAL    ] camxchi.cpp:1737 ChiBufferManagerGetImageBuffer() bruceChiLog: 【通过ImageBufferManager获取ImageBuffer】
CHIUSECASE: [ERROR  ] chxusecaseutils.cpp:2498 GetImageBufferInfo() bruceChiLog:  pGetImageBuffer【获取ImageBuffer】
CamX    : [ERROR][HAL    ] camxchi.cpp:1737 ChiBufferManagerGetImageBuffer() bruceChiLog: 【通过ImageBufferManager获取ImageBuffer】
CHIUSECASE: [FULL   ] chxadvancedcamerausecase.cpp:6456 【SetRequestToFeatureMapping()】【设置Request到Feature Map】 Current index 0 RequestCount 0 sessionId 1 requestId 0 pFeature 0x74a962e800 type 1
CamX    : [ERROR][HAL    ] camxsession.cpp:2531 【ProcessRequest()】【Request传递到session】 : 
CamX    : [ERROR][HAL    ] camxpipeline.cpp:802 【OpenRequest()】【Request传递到pipeline】
CamX    : [ERROR][HAL    ] camxnode.cpp:1442 【SetupRequest()】【Request传递到node】 : 
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【ChiNodeWrapper】Node设置Request Output Port Fence】, Request 1, PortId 0, GroupID 1, Fence 1, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【ChiNodeWrapper】Node设置Request Output Port Fence】,Fence 1, total refCount 2, port[0] count 2
CamX    : [ERROR][HAL    ] camxhaldevice.cpp:1325 PopulateFrameworkRequestBuffer() : 【填充预览setRepeatingRequest或拍照Capture的buffer,预览不断调用,拍照调用一次 】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】Node设置Request Output Port Fence】, Request 1, PortId 6, GroupID 5, Fence 2, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】Node设置Request Output Port Fence】,Fence 2, total refCount 4, port[6] count 4
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 9, GroupID 8, Fence 3, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 3, total refCount 2, port[9] count 2
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 17, GroupID 3, Fence 4, primary 1
CHIUSECASE: [FULL   ] chxusecase.cpp:1000 UpdateFeatureModeIndex() 【UpdateFeatureModeIndex E】【更新feature mode index】
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 4, total refCount 3, port[17] count 3
CHIUSECASE: [ERROR  ] chxadvancedcamerausecase.cpp:2245 GetOutputBufferFromRDIQueue() bruceChiLog: GetTargetBufferPointer【获取目标buffer指针】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 16, GroupID 3, Fence 4, primary 0
CHIUSECASE: [ERROR  ] chxusecaseutils.cpp:2498 GetImageBufferInfo() bruceChiLog:  pGetImageBuffer【获取ImageBuffer】
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【IFE】】,Fence 4, total refCount 11, port[16] count 2
CamX    : [ERROR][HAL    ] camxchi.cpp:1737 ChiBufferManagerGetImageBuffer() bruceChiLog: 【通过ImageBufferManager获取ImageBuffer】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【IFE】】, Request 1, PortId 19, GroupID 3, Fence 4, primary 0
CamX    : [ERROR][HAL    ] camxhaldevice.cpp:1325 PopulateFrameworkRequestBuffer() : 【填充预览setRepeatingRequest或拍照Capture的buffer,预览不断调用,拍照调用一次 】
CamX    : [ERROR][CORE   ] camxnode.cpp:5322 SetupRequestOutputPortFence() NodeName:【【LRME】】, Request 1, PortId 0, GroupID 2, Fence 11, primary 1
CamX    : [ERROR][CORE   ] camxnode.cpp:5368 SetupRequestOutputPortFence()  NodeName:【【LRME】】,Fence 11, total refCount 2, port[0] count 2
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:402 【AddDependencyEntry() 】【DRQ增加依赖】Adding dependencies for node: 0 NodeName: 【【Sensor:0】】 pipeline: 0 request: 36 seqId: 1 bindIOBuffers: 0
CamX    : [ERROR][HAL    ] camxnode.cpp:2656 【ProcessRequestIdDone】() : PipelineName:【【ZSLPreviewRaw】】 Node 【【ZSLPreviewRaw_Stats0】】, pipeline: 0, is done with request 35
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:402 AddDependencyEntry() Adding dependencies for node: 5 NodeName: 【【AutoFocus:0】】 pipeline: 0 request: 36 seqId: 1 bindIOBuffers: 1
CamX    : [ERROR][CORE   ] camxdeferredrequestqueue.cpp:1137 GetUnpublishedList() Unpublished list [0] for NodeName:【【AutoFocus】】 property: 30000007, request 36 pipeline: 0

四、:process_capture_request四级日志关键字

PopulateFrameworkRequestBuffer|FillTuningModeData|UpdateFeatureModeIndex|PopulateHALToChiStreamBuffer|GetOutputBufferFromRDIQueue|ChiBufferManagerGetImageBuffer|SetRequestToFeatureMapping|SetupRequestOutputPortFence

五、:总结

当前日志主要涉及request过程:

  1. 当前日志重要性一般。
  2. 由于node与node之间的处理,无非就是buffer的输入输出,也就是数据流的传递,并进行二次处理,所有经常拿buffer指针传递。
  3. 之前有讲pipeline的拓扑图,node与node之间的port和link关系错综复杂。这里需要SetupRequestOutputPortFence设置request对应node的outport fence来处理。

【关注我,后续持续新增专题博文,谢谢!!!】

下一篇讲解:

http://www.xdnf.cn/news/11990.html

相关文章:

  • STM32中自动生成Flash地址的方法
  • 昇腾+ds+dify部署
  • 基于SpringBoot和PostGIS的OSM时空路网数据入库实践
  • 服务器CPU被WMI Provider Host系统进程占用过高,导致系统偶尔卡顿的排查处理方案
  • Spring AI学习一
  • qt network 整体框架
  • 将图形可视化工具的 Python 脚本打包为 Windows 应用程序
  • 【安全攻防与漏洞】​​量子计算对HTTPS的威胁:后量子密码学进展
  • MyBatis-Plus LambdaQuery 高级用法:JSON 路径查询与条件拼接的全场景解析
  • Linux系统-基本指令(6)
  • Python 多线程编程全面学习指南
  • 优化技巧--滑动窗口
  • AI物体识别原理综述与Auto Drive实践
  • 光学系统常用光学参数的测量
  • 武汉火影数字|互动多媒体展项打造:开启沉浸式互动体验
  • python打卡训练营打卡记录day44
  • ShardingSphere 如何解决聚合统计、分页查询和join关联问题
  • 导出onnx的两种方法
  • 高性能图片优化方案
  • 使用PyInstaller将Python脚本打包成可执行文件
  • C++抽象类与多态实战解析
  • [leetcode ] 5.29week | dp | 组合数学 | 图 | 打家劫舍
  • 68 VG的基本信息查询
  • SQL 中 JOIN 的执行顺序优化指南
  • RAMSUN分享全新超值型MM32F0050系列MCU
  • 理解继承与组合的本质:Qt 项目中的设计选择指南
  • 如何量化创新项目的成功标准
  • js鼠标事件大全
  • 滚珠导轨在光学设备中如何实现微米级运动?
  • 简单网络拓扑实验