美文网首页
【Camera专题】Qcom- QCFA (四合一)调试之旅

【Camera专题】Qcom- QCFA (四合一)调试之旅

作者: c枫_撸码的日子 | 来源:发表于2021-11-17 14:35 被阅读0次

一、QCFA 是什么?

The Quadra CFA feature improves performance in low light conditions and signal-to-noise ratio (SNR).
This feature provides bright and sharp pictures under low light conditions and highresolution pictures under normal light condition. Quadra CFA has 16 MP sensors. They operate in the following modes:

  • Binning mode – The Binning mode is enabled in low light conditions. This mode can combine four adjacent pixels into one pixel, thus 16 MP is converted into 4 MP. This ensures that every pixel has four times more light, which results in significantly brighter and sharper images than regular 4 MP sensors.

  • Non-binning mode – Non-binQning mode is enabled in normal light conditions. It offers 16 MP. However, its pixel pattern is not in the standard Bayer pattern. Thus, it needs formQat conversion before it can be processed by camera ISP pipelines.

简而言之:QCFA 全称: Quadra Color Filter Array:四色滤波器阵列
QCFA Sensor 也成为 4合一sensor,把4个像素合成一个像素,以此来提高亮度!

以16M(1600W像素)的QCFA Sensor为例子,4-cell mode(也称为Binning mode)输出就是400w。

  • 16M 为 非标准Bayer阵列
  • 4M 为标准Bayer阵列

二、预览和拍照模式

2.1 预览和拍照尺寸小于等于 4M(400W像素)

在预览和拍照尺寸是4M或者更小时,QFCA Sensor此时处于Binning模式(或者4-cell模式),
该模式会把4个相邻的像素合成一个像素,如下图:


因此,该模式下,QCFA Sensor出图是标准的Bayer图,ISP模块是可以直接处理的,当成普通Sensor一样使用即可。

2.1 拍照尺寸大于 4M(400W像素)

当拍照尺寸大于4M时,就不能以Binning模式出图了,此时QCFA Sensor出图如下:


这种就是非标准的Bayer图,ISP模块是无法识别的处理的,如果你强行给ISP处理,就会出现以下情况。


因此,我们第一步首先是转换成标准的Bayer图,在丢给ISP模块去处理。
我们把这个转换的过程,称之为Re-mosiac

三、QCFA 功能设计

Binning 模式

在binning模式下,QCFA sensor和正常的Bayer sensor是一致的

Non-binning 模式

在非binning模式下,由于出图不是标准的Bayer图,ISP模块无法直接处理,因此Sensor输出的帧需要经过以下三个阶段:

  • 1.通过RDI接口获取Raw图

  • 2.Remosic:把非标准的Bayer图转换成标准的Bayer图

  • 3.把帧丢给VFE模块进行处理


四、QCFA调试过程中踩过的坑

0.QCFA 相关adb

adb shell setprop persist.vendor.camera.quadcfa.pic_size "full" 
adb shell setprop persist.vendor.camera.quad.dummy 1 
adb shell setprop persist.vendor.camera.feature.restart 1

1.Invalid picture size requeste 问题?

02-07 18:38:36.261 537 2607 E QCamera : <HAL><ERROR> setPictureSize: 1737: Invalid picture size requested: 4208x3120
02-07 18:38:36.261 535 535 W /system/bin/hw/android.hidl.allocator@1.0-service: ashmem_create_region(32768) returning hidl_memory(0xa740ee10, 32768)
02-07 18:38:36.265 535 535 W /system/bin/hw/android.hidl.allocator@1.0-service: ashmem_create_region(32768) returning hidl_memory(0xa740ee10, 32768)
02-07 18:38:36.266 2559 2600 E Camera1 : camera open failed: java.lang.RuntimeException: setParameters failed
02-07 18:38:36.267 2559 2600 I CameraView: dispatchError,com.xtc.camera.app.widget.cameraview.core.CameraException: java.lang.Throwable: 摄像头启动失败

hardware/qcom/camera/QCamera2/HAL3/QCamera3HWI.cpp

property_get("persist.vendor.camera.quadcfa.pic_size", prop, "quarter");
只要不设置成"quarter"就ok

  • property_get("persist.vendor.camera.quadcfa.pic_size", prop, "QUADCFA");


2.QCFA 功能不生效问题

3种方案

  • 2.1
adb shell setprop persist.vendor.camera.feature.restart 1
  • 2.2


  • 2.3
    device/qcom/[Project]/system.prop

persist.vendor.camera.feature.restart=1

3.Camera Open失败

直接使用QCameraQuadraCfa.cpp ,启动camera就失败了,
02-13 02:15:08.511 1240 1240 E mm-camera: <SHIM ><ERROR> 564: mct_shimlayer_start_session: Session creation for session =2 failed with err -1
02-13 02:15:08.511 1240 1240 E QCamera : <MCI><ERROR> mm_camera_open: 342: Failed to open session
02-13 02:15:08.511 1240 1240 E QCamera : <MCI><ERROR> camera_open: 3194: mm_camera_open err = -1

改动如下:

1. modules/module_imglib.h 
+void module_quadracfa_deinit(mct_module_t *p_mct_mod); 
2.modules/module_imglib_defs.h 
+#define MOD_IMGLIB_QUADRACFA { \ 
+ .name = "imglib_quadracfa", \ 
+ .init_mod = module_quadracfa_init, \ 
+ .deinit_mod = module_quadracfa_deinit, } \ 
+ 

+ { .feature_mask = CAM_QCOM_FEATURE_QUADRA_CFA, \ 
+ .stream_type = CAM_STREAM_TYPE_OFFLINE_PROC, \ 
+ .modules[0] = {MOD_IMGLIB_QUADRACFA}, \ 
+ .session_params = {CAM_INTF_PARM_HAL_VERSION, CAM_INTF_PARM_MAX}, \ 
+ }, \ 

3.modules/quadracfa/module_quadracfa.c 

+void module_quadracfa_deinit(mct_module_t *p_mct_mod) 
+{ 
+ module_imgbase_deinit(p_mct_mod); 
+}

原因
quadracfa 这个功能已经在pproc模块加进去了,我这里属于重复添加了,导致open异常。

vendor/qcom/proprietary/mm-camera/mm-camera2/media-controller/modules/pproc-new/pproc_module.c
quadracfa is init in pproc_modules_list [pproc_module.c]


解决方案:去掉上面的改动即可

4.fopen Failed

02-14 15:33:06.377 536 897 E zcf : zcf E
02-14 15:33:06.377 536 897 E zcf : zcf open file =otp/xtalk_otp.dat
02-14 15:33:06.377 536 897 E zcf : open otp/xtalk_otp.dat failed



fae那边提供了2个otp数据做校准,提供的源码使用例子直接使用open的方式。

#define XTALK_DATA        "otp/xtalk_otp.dat"
#define OTPDPC_DATA     "otp/dpc_otp.dat"

解决方案:
路径问题,把两个文件push到指定路径:vendor/etc/otp/
当然你也可以通过预编译的方式把文件编译进系统。

#define XTALK_DATA        "vendor/etc/otp/xtalk_otp.dat"
#define OTPDPC_DATA     "vendor/etc/otp/dpc_otp.dat"

不过模组有otp数据,就舍弃这种open的方式了,直接通过eeprom读取。

5.otp数据读出来为空

int32_t QCameraQuadraCfa::PresetConfig(img_base_ops_t *aOps, void *p_params) 
{ 
···
这里OTP数据为空
CDBG("zcf cal_data=%p num_bytes=%d",p_preload_param->custom_cal_data,p_preload_param->num_bytes); 
if (NULL == p_preload_param->custom_cal_data) { 
p_preload_param->custom_cal_data = (uint8_t*)temp_custom_data; 
} 
if (p_preload_param->num_bytes <= 0) { 
p_preload_param->num_bytes = eeprom_size; 
} 
}

解决方案:
在OTP中添加以下函数:

static void sensor_qtech_eeprom_get_custom_data(sensor_eeprom_data_t *e_ctrl) 
{ 
e_ctrl->eeprom_data.custom_data = (void*)(e_ctrl->eeprom_params.buffer + CUSTOM_DATA_OFFSET); 
e_ctrl->eeprom_data.num_bytes = 2568; 
SDBG("custom_data =%p buffer =%p num_byte=%d",
      e_ctrl->eeprom_data.custom_data,e_ctrl->eeprom_params.buffer,e_ctrl->eeprom_data.num_bytes); 
} 

sensor_qtech_eeprom_format_calibration_data(void *e_ctrl) {
  ov16a1q_qtech_eeprom_get_custom_data(ctrl);
}

目前通过这种方式传递otp数据

6.dump 输入和输出的图像失败

adb shell setprop persist.vendor.camera.imglib.dump  1

dump路径: /data/vendor/camera/
dump函数:mFrameOps.dump_frame(inFrame[0], "Quadracfa_input", 0, NULL);

7.自己添加的模块加载失败

02-09 21:35:30.481 539 539 W mm-camera: <IMGLIB>< WARN> 747: module_imglib_create_topology: Can not init the module imglib_oem1
02-09 21:35:30.481 539 539 E mm-camera: <IMGLIB><ERROR> 46: module_ov16a1q_remosaic_init: zcf init
02-09 21:35:30.490 539 539 E mm-camera: <IMGLIB><ERROR> 1110: frameproc_comp_load_fn_ptrs: Loading img_algo_init error undefined symbol: img_algo_init
02-09 21:35:30.491 539 539 E mm-camera: <IMGLIB><ERROR> 1214: frameproc_comp_load: frameproc_comp_load:1214] cannot load libov16a1q_remosaic.so
02-09 21:35:30.491 539 539 E mm-camera: <IMGLIB><ERROR> 3509: module_imgbase_init: imglib_ov16a1q_remosaic] Error rc -7
02-09 21:35:30.491 539 539 W mm-camera: <IMGLIB>< WARN> 747: module_imglib_create_topology: Can not init the module imglib_ov16a1q_remosaic

解决方案:
vendor/qcom/proprietary/mm-camera/mm-camera2/media-controller/modules/imglib/Android.mk

+include $(LOCAL_IMGLIB_PATH)/components/my_remosaic/Android.mk

忘记添加引用了

8.调用ov_fcell_process 函数 crash


ov的技术人员一开始怀疑是xtalk的问题,建议我去掉xtalk校准看看是否还有崩溃


image.png

但我觉得应该是xtalk数据长度不是600,是log丢失的问题。


去掉xtalk后还是会crash


根本原因:


fcell.h定义了remosaic库相关的输入输出格式,如下:


E_OV_FCD_CFA16   --------------  input:16bit  /  output:16bit

E_OV_FCD_QUALCOMM_MIPI  -------------- input:MIPI raw10  /  output:MIPI raw10

E_OV_FCD_QUALCOMM_MIPI_CFA16   --------------- input: MIPI raw10  / output:16bit

其他两种格式E_OV_FCD_CFA10_MIPI 和 E_OV_FCD_CFA10_TIGHT请不要使用。

解决:

为啥addr2line显示是xtalk导致crash:

v19.3只支持CFA16格式输入,若传入MIPI格式,remosaic库当成CFA16处理内存访问越界出现crash很正常。内存都被踩坏了,我用addr2line工具定位调用栈代码显示在xtalk部分也没有什么意义了

关于补偿数据的疑问

9.1600W和400W亮度不一致问题


同一个位置,同一个场景,1600W的亮度 不如400W。
这是正常的,后续可以通过调试让1600W的亮度和400W的一致。

由于OV16A1Q是4C sensor,当前驱动中binning size采样方式为4 sum mode, 所以binning size raw data比full size raw data 亮度高是正常的。该问题可以通过后端ISP调试解决,在调试AE的时候会有参数设定preview 和capture 亮度关系。目前binning size 4C1 mode 亮度是full size的2.8x 左右。

一般来说 Full size 和4C1 mode binning size亮度比为1:2.857

修改预览的配置即可


因为:
3A算法里:

binning_multiplier = binning_factor/binning_method

/* Step 2 Calculate Snapshot Exposure Time */
snap_exp_time = (real_gain * preview_exp_time) / snap_sensor_gain;
snap_exp_time *= (float)(binning_multiplier);

10.ov_fcell_process 执行时间问题

  02-22 00:16:19.617   535  2693 E ovl6a1q_remosaic: ov_fcell_process E
  02-22 00:16:20.558   535  2693 E ovl6a1q_remosaic: ov_fcell_process sucess!!!
  ov_fcell_process 这个函数处理花了0.941s,这个时间有办法优化吗?

11.xtalk数据补偿有问题

image.png

12.拍照1600W crash

从调用栈信息定位代码发现是xtalk数据异常导致的,请确认测试用的xtalk数据是否正常数据,或去掉E_OV_FCD_FLAG_XTALK开关试试。

五、QCFA集成改动

1.点亮sensor

400w尺寸
先点亮400W的输出,当做普通sensor去点亮即可。

1600w尺寸
驱动配置上需要注意的地方:
a.


b.

2.需要改动的文件

参考文档
80-NN056-9 B

  • Stay hungry,Stay foolish!

相关文章

网友评论

      本文标题:【Camera专题】Qcom- QCFA (四合一)调试之旅

      本文链接:https://www.haomeiwen.com/subject/odvltrtx.html