相机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过程:
- 当前日志重要性一般。
- 由于node与node之间的处理,无非就是buffer的输入输出,也就是数据流的传递,并进行二次处理,所有经常拿buffer指针传递。
- 之前有讲pipeline的拓扑图,node与node之间的port和link关系错综复杂。这里需要SetupRequestOutputPortFence设置request对应node的outport fence来处理。
【关注我,后续持续新增专题博文,谢谢!!!】
下一篇讲解: