高通camera-sensor分辨率简单梳理


记录学习高通关于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.youkuaiyun.com/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 流程

<think>嗯,用户的问题聚焦于CamX架构中添加自定义node的具体方法。从引用内容看,用户已经接触过一些零散的添加node的步骤片段,但需要系统化的技术指导。用户可能是Camera HAL层开发工程师,正在做定制化功能开发,比如添加图像处理算法或硬件适配。 用户引用的资料[3]和[4]特别关键,提到Usecase XML配置和Pipeline定义,这应该是核心切入点。需要强调三点技术要点:一是Pipeline和Node的包含关系,二是XML配置的物理路径位置,三是编译依赖。考虑到用户可能遇到环境配置问题,还要提醒vendor makefile修改。 注意到用户引用中频繁出现"oem/qcom/topology"路径,这暗示不同平台(如mimas)路径可能有差异。在回答时需要明确说明路径可变性,避免用户直接复制粘贴导致错误。 用户没有提到具体芯片平台(比如SM8550/SM8650),但CamX的node开发通常会涉及芯片级HWL(Hardware Layer)适配。要不要追问用户具体平台呢?不过用户当前问题聚焦方法论,先提供通用方案更合适。 技术难点在于External Node的接口实现,特别是Chi对CamX的跨层调用。引用[2]提到"Node在Camx/Chi中均会存在",这点需要展开说明双架构下的开发差异,比如CamX侧的SWL/HWL位置和Chi侧的Node入口。 </think>在高通CamX架构中添加自定义Node需要遵循以下步骤,依据引用内容整合关键环节: ### 一、Node代码开发 1. **位置规划** Node代码需放置在`vendor/qcom/proprietary/camx/src/`目录下: - **硬件相关Node**:置于`hwl/`子目录(如Sensor/IFE等) - **软件处理Node**:置于`swl/`子目录(如自定义算法节点) ```c // 示例节点基本结构 class CustomNode final : public CHINODE { public: static CHINODECreateFunction Create; // 创建函数声明 virtual CDKResult ExecuteProcessRequest(...); // 核心处理逻辑 }; ``` 2. **实现接口函数** 必须实现以下核心接口: - `Create()`:节点实例化 - `ExecuteProcessRequest()`:数据处理入口 - `QueryMetadataPublishList()`:元数据发布声明 --- ### 二、拓扑配置修改 1. **添加Pipeline引用** 在Usecase配置文件(如`camxUsecaseZSL.xml`)中声明自定义节点: ```xml <CamxInclude>PipelineCustomNode.xml</CamxInclude> <!-- 引用自定义管线 --> ``` *路径通常位于`oem/qcom/topology/<平台名>/usecase-components/` [^3][^4]* 2. **定义节点拓扑** 在自定义管线文件(如`PipelineCustomNode.xml`)中配置节点连接关系: ```xml <Node name="CustomNode" type="CustomNode"> <InputPorts> <Port srcNode="PreviousNode" srcPort="OutputPort0" /> </InputPorts> <OutputPorts> <Port dstNode="NextNode" dstPort="InputPort0" /> </OutputPorts> </Node> ``` --- ### 三、编译集成 1. **修改Makefile** 在`Android.mk`中添加新节点编译目标: ```makefile LOCAL_SRC_FILES += src/swl/CustomNode.cpp LOCAL_C_INCLUDES += $(CAMX_PATH)/src/swl ``` 2. **注册节点类型** 在`chi_camera_ext.xml`中声明节点类型ID: ```xml <NodeType name="CustomNode" id="CustomNodeID" /> ``` --- ### 四、调试验证 1. **日志分析** 通过`adb logcat | grep CamX`检查节点初始化日志: ``` CamX: [INFO] Created node CustomNode instance 0x7A4B ``` 2. **数据流追踪** 使用`camxhal3test`工具验证节点间数据传递 > **关键注意事项**: > 1. 节点ID需在`camx_types.h`的`NodeId`枚举中扩展 [^2] > 2. OEM层自定义节点路径需与高通原生代码隔离(建议放在`oem/qcom/`下) > 3. 需同步修改`usecaseoverride.xml`启用新管线 [^4]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

永不秃头的程序员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值