高通camera-sensor分辨率简单梳理_qualcomm camx sensor-程序员宅基地

技术标签: c#  c++  android的camera学习  


记录学习高通关于sensor分辨率的相关笔记

一、高通分辨率的配置文件

高通将分辨率配置到对应的xml配置里面
文件目录:

vendor/qcom/proprietary/chi-cdk/vendor/sensor/default/xxx/xxxx_sensor.xml

内容大致如下,具体的请自己去看源码

<sensorDriverData>
	<slaveInfo>
	  	  <!--  包含寄存器的配置,sensor 名字、地址、ID、MCLK,上下电时序   -->
	</slaveInfo>
	-----------------------------------
	<regAddrInfo>
	  	  <!--  主要是包含曝光寄存器的配置   -->
	</regAddrInfo>
	-----------------------------------
	<resolutionInfo>
	  	  <!--  主要是包含sensor输出的分辨率,最大的帧率、帧长、行长、数据流等   -->
	 </resolutionInfo>
	-------------------------------
	 <exposureControlInfo>
		  	  <!--  主要是包含曝光寄的信息配置,支持的最大增益gain   -->
	 </exposureControlInfo>
	 -----------------
	<streamOnSettings>
		  	  <!--  主要是包开流寄存器   -->  	
	</streamOnSettings>
	 -----------------
	<streamOffSettings>
		  	  <!--  主要是包关流寄存器   -->  	
	</streamOffSettings>
	-------------------
	<initSettings>
			<!-- 全局初始化配置  -->
	</initSettings>
</sensorDriverData>

我们在编译的时候会把这个xml文件编译为对应的bin文件,在烧录的时候会把这个bin文件放在对应的目录下。
在同一份代码中,我们会有很多的xml文件,也会有多个对应的.bin文件。
xml配置文件比较难,修改的话需要联系对应的FAE,让他提供一些支持。

二、 解析xml配置文件

解析文件目录(该目录在编译后生成):

vendor/qcom/proprietary/chi-cdk/ cdk/generated/g_sensor $ ls
camxactuatordriver.cpp  camxflashdriver.cpp   camxoisdriver.cpp   camxsensorcommon.cpp  imagesensormodulesetmanager.cpp
camxactuatordriver.h    camxflashdriver.h     camxoisdriver.h     camxsensorcommon.h    imagesensormodulesetmanager.h
camxeepromdriver.cpp    camxmoduleconfig.cpp  camxpdafconfig.cpp  camxsensordriver.cpp
camxeepromdriver.h      camxmoduleconfig.h    camxpdafconfig.h    camxsensordriver.h

通过这些名字可以看出来,imagesensormodulesetmanager.cpp 作为管理员进行这些管理,也是解析xml的主要工作者,参考源码可以得出大致的逻辑
imagesensormodulesetmanager.cpp 主要是去创建多个对象,包括 EEPROMDriverData、sensorDriverData、

flashDriverData…等等,然后通过对应的驱动去解析不同的xml,camxsensordriver.cpp去解析对应的sensor的xml, camxoisdriver.cpp解析对应的OIS的xml,camxeepromdriver.cpp去解析对应的eeprom的xml

最后会把解析的数据存放到对应的Data数据指针里面去

//imagesensormodulesetmanager.cpp
CamX::SensorDriverData* ImageSensorModuleSetManager::GetModule_sensorDriverData(
 TuningMode* modeBranch,
 UINT32 modeCount)
{
    
 ParameterModule* pModule = GetModule((const CHAR *)"sensorDriverData",
 modeBranch, modeCount);
return (CamX::SensorDriverData*)(CamX::SensorDriverDataClass*)pModule;
}

具体的详细的过程目前我还不清楚,所以后续需要仔细去看源码了

在这里插入图片描述

具体的流程图可以看这个图片,这个图已经把对应的文件说的很清楚了 里面有对应的函数和对应的文件名。
到这里对应的sensor的分辨率就已经说完了。

三、 xml配置文件如何生效

当我们解析完xml文件后,其最终的目的都是去修改寄存器,让sensor达到这个要求,所以我们xml的生效是在注册函数里面去进行寄存器的设定
详细的过程请看下图:

在这里插入图片描述

其实这个函数图我自己去跟了下,添加一写log后,抓取log进行跟踪,发现的确是这样的,但是也有部分函数没有看懂

// 目录:vendor/qcom/proprietary/camx/src/core/camxhwenvironment.cpp
HwEnvironment::InitCaps() {
    
    ProbeImageSensorModules(); //进入参考1
}    

//参考1
// 目录: vendor/qcom/proprietary/camx/src/core/camxhwenvironment.cpp
VOID HwEnvironment::ProbeImageSensorModules() {
    
    result = pData->Probe(&detected, &deviceIndex); ///通过这里调用到对应的函数里面 从这里进入参考2
}

//参考2
// 目录 : vendor/qcom/proprietary/camx/src/core/camximagesensormoduledata.cpp
CamxResult ImageSensorModuleData::Probe()
{
    
     result = CmdBufferManager::Create("ImageSensorPacketManager", &packetResourceParams, &pPacketManager);
     result = CmdBufferManager::Create("ImageSensorCmdManagerSlaveInfo", &cmdResourceParams, &pCmdManagerSlaveInfo);
     result = CmdBufferManager::Create("ImageSensorCmdManagerPowerSequence", &cmdResourceParams, &pCmdManagerPowerSequence);
     // 这几个函数都能进入参考3
     result = CSLImageSensorProbe(pProbePacket->GetMemHandle(), pProbePacket->GetOffset(), &probeResult); //从这里进入参考4
     //最后调用完成后回到这里
     result = GetSensorDataObject()->LoadSensorLibrary();    //加载/vendor/lib64/camera/com.qti.sensor.*.so https://blog.csdn.net/shangbolei/article/details/106559537
}

// 参考3
// 目录: vendor/qcom/proprietary/camx/src/core/camxcmdbuffermanager.cpp
CamxResult CmdBufferManager::Create()
{
    
    //  函数作用未知
}

//参考4 
// 目录: vendor/qcom/proprietary/camx/src/csl/camxcsl.cpp
CamxResult CSLImageSensorProbe({
    
  // 没有找到对应的函数进入参考5  
}

// 参考5 
// 目录: vendor/qcom/proprietary/camx/src/csl/camxcslhw.cpp
CamxResult CSLImageSensorProbeHW()
{
    
    result = CSLHwInternalProbeSensorHW(hPacket, offset, &deviceIndex); //进入参考6
}

//参考6
// 目录:vendor/qcom/proprietary/camx/src/csl/hw/camxcslhwinternalsensor.cpp
CamxResult CSLHwInternalProbeSensorHW()
{
    
                    ioctlCmd.op_code     = CAM_SENSOR_PROBE_CMD;        //下发给kernel
}

参考博客: 高通camera驱动 camx read xml 和 probe 流程

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_51178981/article/details/126347612

智能推荐

Android最佳架构:MVI + LiveData + ViewModel | ProAndroidDev_android 视图 viewmodel 还原 viewstate-程序员宅基地

文章浏览阅读1.7k次。MVVM和MVI架构模式合并为一个最好的架构,为任何Android项目提供了完美的架构。有太多可用的体系结构模式,每种模式都有其优缺点。所有这些模式都试图实现相同的架构基本原理:1、关注点分离(SoC) :这是一种设计原则,用于将计算机程序分为不同的部分,以便每个部分都可以解决一个单独的关注点。关注点是提供问题解决方案时重要的事情。该原则与面向对象编程的“ 单一责任原则”密切相关,后者 指出..._android 视图 viewmodel 还原 viewstate

OS中关于父子进程的执行顺序和多个子进程之间的执行顺序(整理)_fork父子进程谁先运行-程序员宅基地

文章浏览阅读8.2k次,点赞7次,收藏28次。一、问:1.fork出一个子进程,父子进程执行的先后顺序是不确定的,如果先执行父进程,再执行子进程,父进程中没有wait和sleep。问,是否先把父进程执行完,再执行子进程?还是两个进程是一块执行的?2.如果父进程中有sleep,父进程中的程序执行到sleep进行休眠,转而执行子进程。问:子进程中的程序执行完了再返回父进程中执行,还是休眠时间到了返回父进程中执行,还是其他?答:进程的..._fork父子进程谁先运行

关于服务器部署流程-程序员宅基地

文章浏览阅读8.2k次,点赞3次,收藏27次。服务器部署_服务器部署

opencv 图像上画出目标运动的轨迹_OpenCV视频分析-Meanshift、Camshift&运动轨迹绘制...-程序员宅基地

文章浏览阅读1.9k次。基于均值迁移的对象移动分析(Meanshift)️ ️概述本质:️ Mean Shift均值漂移算法是无参密度估计理论的一种,无参密度估计不需要事先知道对象的任何先验知识,完全依靠训练数据进行估计,并且可以用于任意形状的密度估计,在某一连续点处的密度函数值可由该点邻域中的若干样本点估计得出。直观的理解:️ 一堆点集,一个圆形的窗口在不断的移动,移动的方向是沿着点的密度最大的区域移动,图示如..._通过图像计算目标运动

安全防御------防火墙_防火墙策略里local区域-程序员宅基地

文章浏览阅读563次。本章主要讲解了防火墙的相关知识,包括基本概念,技术类型,安全区域,状态检测等。还包含FTP协议的有关概念以及ASPF技术。_防火墙策略里local区域

openjudge1.3答案_openjudge题库答案1.3-程序员宅基地

该文章为程序代码,主要包括使用C++和C语言解决问题的代码片段。

随便推点

微信小程序:wx.navigateTo从子页面跳回父页面,页面不刷新的问题_navigateto 跳转再跳回时触发那个生命周期函数-程序员宅基地

文章浏览阅读1.8w次,点赞9次,收藏17次。先简要说说小程序的生命周期: 应用的生命周期:App({…}) 用来注册小程序,指定小程序的生命周期 页面的生命周期:Page({…}) 注册页面,指定页面的生命周期 具体注册函数的内容见小程序官网API其中有三个生命周期函数的触发顺序:onLoad-&gt;onShow-&gt;onReady (页面加载-&gt;页面显示-&gt;页面初次渲染) onLoad和onReady每个页面..._navigateto 跳转再跳回时触发那个生命周期函数

properties出现中文乱码解决方法(万能)_properties中文乱码-程序员宅基地

文章浏览阅读2.5k次。比如在vscode或者txt输入中文格式,在idea使用UTF-8表示,格式可不是真正的UTF-8!默认使用vscode或者txt编辑方式进行编辑,之后在idea进行打开,都会出现格式错误。可到了这一步,中文还是乱码(这一步改成功的网友可自动立场,没改成功的网友继续!至于改动不成功,原因在于文件编写的时候默认格式错误,于是怎么转换都出现问题(,在idea转换为UTF-8,格式可能乱码!正常思维来讲,估计是中文编码有问题,于是我将其改为UTF-8的编码方式。使用txt文件或者vscode文件,打开文件编写。_properties中文乱码

一个主题是王嘉尔的静态网页(html+css 附源代码)-程序员宅基地

文章浏览阅读1.1k次,点赞2次,收藏3次。【好像是没用到js 时间太久远所以忘记了】【没考虑多设备适配和弹性布局嗷 在大部分电脑上显示还是正常的】【依然很菜……纯粹写来玩的QAQ】【emo 最近好累吖】在我的电脑上(联想小新pro13呜呜呜大三的时候一定要换一台有独显的电脑)显示是这样的代码<html lang="en"><head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-

十六进制转换八进制_十六进制转换成八进制代码-程序员宅基地

文章浏览阅读6k次,点赞3次,收藏12次。代码如下#include&amp;lt;stdio.h&amp;gt;#include&amp;lt;math.h&amp;gt;#include&amp;lt;string.h&amp;gt;int main(){ int n,i,j,k,len,t; int b[10],c[10]; scanf(&quot;%d&quot;,&amp;amp;n); char a[10][99]; for(i_十六进制转换成八进制代码

用深度神经网络写一段股市预测代码-程序员宅基地

文章浏览阅读79次。根据历史数据建立模型,使用深度神经网络(DNN)训练模型,以预测股市走势:import numpy as npimport tensorflow as tf# 准备数据X = np.array([[1, 2, 3], [4, 5, 6]])y = np.array([7, 8])# 创建模型model = tf.keras.models.Sequential()model.add(tf...._深度学习股票预测代码

Linux updatedb命令教程:如何更新locate命令的文件名数据库(附实例详解和注意事项)-程序员宅基地

文章浏览阅读2k次,点赞60次,收藏42次。updatedb(update database)命令用于更新locate命令使用的文件名数据库。如果数据库已经存在,它的数据会被重用,以避免重新读取未改变的目录。updatedb通常由cron每日运行,以更新默认数据库。