相机预览闪花屏条纹问题处理方法

和你一起终身学 习,这里是程序员Android
经典好文推荐,通过阅读本文,您将收获以下知识点:

一、问题描述

测试同事报了一个拍照后预览闪绿条纹问题

现象大概如下图:

image.png

二、问题分析

1. 复现问题 dump 图分析查看是哪个阶段导致的预览花屏问题

1.1 整个P2S I/O buffer 的 dump 方法

go 复制代码
adb root
adb remount
adb shell setenforce 0
adb shell setprop persist.vendor.mtk.camera.log_level 3
::P1 dump
::adb shell setprop vendor.debug.camera.dump.en 1
::adb shell setprop vendor.debug.feature.forceEnableIMGO 1
::adb shell setprop vendor.debug.camera.dump.p1.imgo 1

:: 预览魔法数字开启
adb shell setprop debug.cam.drawid 1
::enable img3o
adb shell setprop vendor.debug.fpipe.force.img3o 1
adb shell rm -rf /data/vendor/camera_dump/*
adb shell setprop vendor.debug.p2f.dump.enable 1
adb shell setprop vendor.debug.p2f.dump.mode 1
adb shell setprop vendor.debug.camera.preview.dump 1
::adb shell setprop vendor.debug.camera.preview.dump 0 复现问题后请关闭dump
adb shell pkill camera*
pause

1.2 camera_dump文件夹下的文件名称命令格式

UniqueKey-RequestNo-FrameNo-SensorDev-Port-BufferWidth-BufferHeight-BufferStride_ImageWidthxImageHeight_xxx.Format

在/data/vendor/camera_dump 下会dump 不同阶段的内容

image.png

  • sub P1 rrzo buffer

    142407049-109-137-sub-rrzo-PW1280-PH960-BW2400__1280x960_10_3.packed_word

  • img3o buffer (P2Anode 下过了ISP 但是还没过MDP 的buffer,供3DNR用)

    142407049-109-137-sub-img3o-PW1280-PH960-BW1280__1280x960_8_s0.yv12

  • sub 的P1 lcso buffer

    142407049-109-137-sub-PW384-PH384-BW768__326x244_12_s0.lcso ---> sub sensor 的P1 lcso buffer

  • previewCallback ,也就是P2S 最终输出的sub sensor 的previewCallback buffer

    142407049-109-137-sub-undef-PW960-PH720-BW960__960x720_8_s0.nv21

  • wdmao 代表判断为 display output buffer,也就是P2S 最终输出的sub sensor的display buffer

    142407049-109-137-sub-wdmao-PW960-PH720-BW960__960x720_8_s0.nv21

通过 dump 查看 经过P2Anode 输出的yv12 图就有条纹问题,然后需要查看有条纹问题那一帧附近的log。

1.3 dump 异常图Android log 分析

出现问题帧时间点: 14:25:21.430129 附近

image.png

1.4 查看14:25:21.430129 附件对应的 kernel log

go 复制代码
kernel log时间 +8 H +10ms 即kernel 时间 295 附近  = android 异常帧时间: 14:25:21.430129 
  异常条纹帧是,sensor driver 有调用set_max_framerate 更新 framelength =3008 导致预览坏帧发生。
go 复制代码
[  285.672406][T603753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
     [  285.726555][T603753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
      // +8 H +10ms 即kernel 时间 295 附近  = android 异常帧时间: 14:25:21.430129
    [  285.823289][T500109] wdtk-5: [thread:109] 2025-03-10 06:25:11.875381 UTC;android time 2025-03-10 06:25:11.875381
     [  285.832074][ T3753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
     [  285.876262][ T3753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
     ... ...
     [  294.567745][T703753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
     [  294.594359][T703753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
     [  295.217019][T203753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
     //+8 H +10ms 即kernel 时间 295 附近  = android 异常帧时间: 14:25:21.430129 
     // 异常条纹帧是,sensor driver 有调用set_max_framerate 更新 framelength =3008 导致预览坏帧发生
     [  295.268061][ T3753] 3AEventThd: xxx_SensroDriver[set_max_framerate] xxx_SensroDriver set_max_framerate():framerate = 300, min framelength should enable = 1
     [  295.269492][ T3753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3008,mini_framelegth=2506
     [  295.308503][T403753] 3AEventThd: xxx_SensroDriver[set_max_framerate] xxx_SensroDriver set_max_framerate():framerate = 240, min framelength should enable = 1
     [  295.309832][T403753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
     [  295.341744][T403753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133
     [  295.396582][ T3753] 3AEventThd: xxx_SensroDriver[set_shutter] CST_004:xxx_SensroDriver set_shutter(): ratio = 64, real_shutter =6016, framelength =3133,mini_framelegth=3133

三、问题解决

发现Camera sensor驱动文件的流程存在少许问题,错误调节了framelength,导致预览出现概率性坏帧发生, 找到问题点后,修改framelength update 流程,此问题后续压测不复现。

至此,本篇已结束。转载网络的文章,小编觉得很优秀,欢迎点击阅读原文,支持原创作者,如有侵权,恳请联系小编删除,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!

点个在看,为大佬点赞!

相关推荐
几道之旅2 小时前
ROS2相机技术要点
数码相机
格林威4 小时前
印刷电路板阻焊层缺失识别:防止短路风险的 7 个核心策略,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·机器学习·计算机视觉·视觉检测·工业相机
中达瑞和-高光谱·多光谱7 小时前
MAX-S810机载多光谱相机在草地森林覆盖面统计中的应用
数码相机
_李小白7 小时前
【Android 美颜相机】第一天:认识Android-GPUImage项目
android·数码相机
努力犯错8 小时前
Qwen-Image-Edit-2511-Multiple-Angles LoRA:多角度AI图像生成完全指南
人工智能·数码相机·计算机视觉
格林威8 小时前
基于灰度投影的快速图像配准:适用于产线在线对位的 5 个核心方法,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·机器学习·计算机视觉·视觉检测·工业相机
qianbo_insist1 天前
基于图像尺寸的相机内参拼接视频
数码相机·音视频·拼接
双翌视觉2 天前
深入解析远心镜头的工作原理与选型
人工智能·数码相机·机器学习
Hi202402173 天前
如何通过选择正确的畸变模型解决相机标定难题
人工智能·数码相机·计算机视觉·自动驾驶
线束线缆组件品替网3 天前
Bulgin 防水圆形线缆在严苛环境中的工程实践
人工智能·数码相机·自动化·软件工程·智能电视