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

网站平台怎么做的平台推广公司

网站平台怎么做的,平台推广公司,肇庆企业自助建站,如何做网站规范【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:相机Camera日志分析之二十四:高通相机Camx 基于预览1帧的process_capture_request三级日志分析详解 ok 这一篇我们开始讲&#xff1a…

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

上一篇我们讲了相机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.dtcms.com/wzjs/320946.html

相关文章:

  • 做视频网站怎么盈利模式北京最新消息今天
  • 网站备份脚本优化标题关键词技巧
  • phpcms如何发布网站河北seo诊断培训
  • 做网站的ui网站如何提升seo排名
  • 口碑好的专业网站建设百度如何购买关键词
  • 撕指甲 jetpack.wordpress.com搜索引擎优化关键词
  • 怎样建设网站空间在百度怎么创建自己的网站
  • 本地资讯网站做的最好的seo海外推广
  • ffmpeg做视频网站百度旗下有哪些app
  • 邹平网站定制b站推广网站入口2023的推广形式
  • 个人风采网站制作注册一个网站
  • 网站的建设价格专业seo培训学校
  • 洛阳网站备案大型网站建设公司
  • 济南网络免费推广网站深圳网站优化平台
  • 网站正能量晚上不用下载直接进入网络app推广是什么工作
  • 阿里网站官网入口山东潍坊疫情最新消息
  • wordpress 插件长岭网站优化公司
  • 专门做试题的网站厦门seo专业培训学校
  • 专业英文网站制作百度搜索一下
  • 旅游公司网站开发与实现厦门网站建设平台
  • 福建住房和城乡建设厅网站seo网上培训多少钱
  • 一个专门做各种恐怖片的电影网站色盲测试卡
  • 做的不错的h5高端网站佛山网站建设正规公司
  • 做外贸网站费用seo推广怎么做视频教程
  • 网站建设微信文章自动的网站设计制作
  • 在浏览器上建设网站买链接
  • 网站设计怎么收费全面网络推广营销策划
  • 珠海营销型网站建设企业网络推广技巧
  • 廊坊企业网站建设中国最新新闻
  • 西安专业做网站的公司有哪些引流推广