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

相机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来处理。

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

下一篇讲解:

相关文章:

  • 搜广推特征数据变更灰度为什么实现很困难
  • PPT转图片拼贴工具 v4.3
  • 二叉树的遍历总结
  • 云原生思维重塑数字化基座:从理念到实践的深度剖析
  • 【图像处理入门】5. 形态学处理:腐蚀、膨胀与图像的形状雕琢
  • Android15 launcher3
  • javaweb -html -CSS
  • FPGA点亮ILI9488驱动的SPI+RGB接口LCD显示屏(一)
  • Declare规则
  • GDAL 内存数据集类型详解
  • 佰力博科技与您探讨压电d33测试有哪些注意事项
  • Maven的生命周期
  • 结构体指针与非指针 问题及解决
  • 数据迁移是什么?数据迁移过程中
  • 回溯算法复习(1)
  • 西门子SCL之IF-ELSIF语句详解及应用(安全控制代码)
  • Transformer实战——词嵌入技术详解
  • Linux环境-通过命令查看zookeeper注册的服务
  • 数据集-目标检测系列- 猴子 数据集 monkey >> DataBall
  • 哈希算法实战全景:安全加密到分布式系统的“核心引擎”
  • 《动态网站建设》第03章在线测试/利于seo的建站系统有哪些
  • wordpress 导航站模板/优化教程网官网
  • 汕头seo优化/免费seo排名优化
  • 高大上强企业网站/江苏营销型网站建设
  • 如何经营一个购物网站/关键词免费
  • 苏州营销型网站制作/厦门seo蜘蛛屯