【Camera Sensor Driver笔记】三、点亮指南之Sensor DTS

2024-04-20 18:04

本文主要是介绍【Camera Sensor Driver笔记】三、点亮指南之Sensor DTS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

== camera sensor 接口配置
xxsensor.cpp  -> xxxsensor.so

CalculateExposure 函数
    pCalculateExposure函数

        (平台)输入参数:
        pCalculateExposureData
            realgain :total gain,ae算法传过来的值或者手动曝光的值
            linecount:经过平台已经转换过的曝光时间
            middlerealgain
            middlelinecount
            shortrealgain
            shortlinecount
             ::作用于shdr
            sensorResolutionIndex
            ...

        输出参数:
        pExposureInfo
            analogRealGain:sensor的模拟gain
            analogRegisterGain:sensor的模拟gain对应的寄存器的值
            digitalRealGain:sensor的数字gain
            digitalRegisterGain:sensor的数字gain对应的寄存器的值
            ISPDigitalGain isp的数字gain
            ...

        
        LineCount = ExposureTime / Tline
        
        
        Tline = HTS * 1 / vt_clk , lineLengthPixelClock(一行要处理多少个pixel) * 1 / VTPixelClock(处理一个pixel的时间)
        
        
        vt_clk = VTS * HTS * FPS, frameLengthLines * lineLengthPixelClock * FPS
        
        
        Tline  = 1 / (VTS * FPS),1/ (frameLengthLines * FPS)
        

FillExposureSettings 函数
    pFillExposureSettings函数

        输入参数:
        pExposureData
            曝光寄存器信息
            analogRealGain:sensor的模拟gain
            digitalRealGain:sensor的数字gain
            ...

        输出参数:
        pRegSettingsInfo
            regSettingCount:sensor的寄存器数量
            regSetting[]:sensor的寄存器数组
            

== Camera Sensor KMD DTS 配置


什么是DTS:DTS是一种用于描述硬件信息的数据结构和语言,它是树状结构的。


bengal-camera-sensor-qrd.dtsi
    camera模组相关硬件描述(sensor,eeprom,actuator,flash,etc)
bengal-camera.dtsi
    平台相关camera硬件描述(ife,ipe,csiphy,csid,cci,etc)


soc 节点(flash,cam-res-mgr)
    &soc {
        led_flash_rear: qcom,camera-flash@0 {
            cell-index = <0>;                          //唯一标号  flash固定标号
            compatible = "qcom,camera-flash";       //和driver匹配,匹配后调驱动probe
                ::struct of_device_id cam_flash_dt_match[] = {
                ::   .compatible = "qcom,camera-flash"
                ::}
            
            flash-source  = <&pmi632_flash0 &pmi632_flash1>;     //引用flash节点,由BSP实现
            torch-source  = <&pmi632_torch0 &pmi632_torch1>;    //引用torch节点,由BSP实现
            switch-source = <&pmi632_switch0 &pmi632_switch1>;     //引用switch节点
            status = "ok"; //ok or disable
        };
        ,,,

        qcom,cam-res-mgr {    //管理GPIO资源,封装kernel API 接口
            compatible = "qcom,cam-res-mgr"; //和driver匹配,probe
            status = "ok"; //ok or disable
        };
    };

cam_cci 节点
actuator
&cam_cci0 {     //平台cci0 控制器
    actuator_rear: qcom,actuator0 {    
        cell-index = <0>;   //唯一标号
        compatible = "qcom,actuator";      //和driver匹配,匹配后调驱动probe
        cci-master = <0>;                 //cci index
        cam_vaf-supply = <&L5P>;        //电源引用节点,由BSP实现
        regulator-names = "cam_vaf";       //电源名称
        rgltr-cntrl-support;             //regulator 精确控制使能
        rgltr-min-voltage = <2800000>;     //最小电压值,单位µV
        rgltr-max-voltage = <2800000>;    //最大电压值,单位µV
        rgltr-load-current = <100000>;     //电流,单位µA
        status = "ok";
    };

    actuator_rear_aux: qcom,actuator1 {
        cell-index = <1>;
        compatible = "qcom,actuator";
        cci-master = <1>;
        cam_vaf-supply = <&L5P>;
        regulator-names = "cam_vaf";
        rgltr-cntrl-support;
        rgltr-min-voltage = <2800000>;
        rgltr-max-voltage = <2800000>;
        rgltr-load-current = <100000>;
        status = "ok";
    };

sensor
    qcom,cam-sensor0 {
        cell-index = <0>;                     //唯一标号slot id ,和 module xml id唯一匹配
        compatible = "qcom,cam-sensor";      //和driver匹配,匹配后调驱动probe
        csiphy-sd-index = <0>;                 //csiphy id, 绑定csiphy,这个sensor用的哪个phy
        sensor-position-roll = <270>;      //会被xml配置覆盖
        sensor-position-pitch = <0>;       
        sensor-position-yaw = <180>;
        actuator-src = <&actuator_rear>;    //绑定actuator节点
        led-flash-src = <&led_flash_rear>;  //绑定flash节点
        eeprom-src = <&eeprom_rear>;      //绑定eeprom节点
        cam_vio-supply = <&L7P>;         //引用IOvdd 节点,由BSP具体实现
        cam_vana-supply = <&L4P>;        //引用Avdd 节点,由BSP具体实现
        cam_vdig-supply = <&L2P>;         //引用Dvdd 节点,由BSP具体实现
        cam_vaf-supply = <&L5P>;          //引用AFvdd 节点,由BSP具体实现
        cam_clk-supply = <&gcc_camss_top_gdsc>; //引用gdsc 时钟,由BSP实现
        regulator-names = "cam_vio", "cam_vana", "cam_vdig",
            "cam_clk", "cam_vaf";            //和上面的cam_ 没有顺序关系
                                            //和下面的rgltr-  有顺序关系
        rgltr-cntrl-support;                //regulator 精确控制使能
        rgltr-min-voltage = <1800000 2800000 1050000 0 2800000>;
        rgltr-max-voltage = <1800000 2800000 1050000 0 2800000>;
        rgltr-load-current = <120000 80000 1200000 0 100000>;
        
        gpio-no-mux = <0>;  //gpio复用
        pinctrl-names = "cam_default", "cam_suspend";   //active, deactive
        pinctrl-0 = <&cam_sensor_mclk0_active
                     &cam_sensor_rear0_reset_active>;  //active  0对应 cam_default
                
        pinctrl-1 = <&cam_sensor_mclk0_suspend
                     &cam_sensor_rear0_reset_suspend>; //deactive  1对应cam_suspend
                
        gpios = <&tlmm 20 0>,  // 平台tlmm pin 20 作为mclk 默认输出低电平
                <&tlmm 18 0>;  // 平台tlmm pin 18 作为reset 默认输出低电平
            
        gpio-reset = <1>;       //指定上面哪一个作为GPIO RESET使用
        gpio-req-tbl-num = <0 1>;    // GPIO 数组index
        gpio-req-tbl-flags = <1 0>;  //GPIO direction, 0:输出,1:输入; mclk作为输入,gpio作为输出
        
        gpio-req-tbl-label = "CAMIF_MCLK0",
                            "CAM_RESET0";
        cci-master = <0>;     //cci总线
        clocks = <&gcc GCC_CAMSS_MCLK0_CLK>;  //引用MCLK节点,由BSP提供具体实现
        clock-names = "cam_clk";   //MCLK时钟名称
        clock-cntl-level = "turbo";   
        clock-rates = <19200000>;  //MCLK时钟频率,19.2M or 24M
        status = "ok";
    };

EEPROM
    eeprom_triple_rear_macro: qcom,eeprom@4 {
        cell-index = <4>;
        compatible = "qcom,eeprom";
        reg = <0x4>;
        cam_vio-supply = <&L6P>;
        cam_vana-supply = <&L4P>;
        cam_clk-supply = <&cam_cc_titan_top_gdsc>;
        regulator-names = "cam_vio", "cam_vana", "cam_clk";
        cci-device = <0>;
        cci-master = <0>;
        qcom,cam-sensor@4 {
            cell-index = <4>;
            compatible = "qcom,cam-sensor";
            reg = <0x4>;
            cam_vio-supply = <&L6P>;
            cam_vana-supply = <&L4P>;
            cam_clk-supply = <&cam_cc_titan_top_gdsc>;
            regulator-names = "cam_vio", "cam_vana", "cam_clk";
            sensor-mode = <0>;
            cci-device = <0>;
            cci-master = <0>;
        }
    }

这篇关于【Camera Sensor Driver笔记】三、点亮指南之Sensor DTS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/920948

相关文章

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

论文阅读笔记: Segment Anything

文章目录 Segment Anything摘要引言任务模型数据引擎数据集负责任的人工智能 Segment Anything Model图像编码器提示编码器mask解码器解决歧义损失和训练 Segment Anything 论文地址: https://arxiv.org/abs/2304.02643 代码地址:https://github.com/facebookresear

数学建模笔记—— 非线性规划

数学建模笔记—— 非线性规划 非线性规划1. 模型原理1.1 非线性规划的标准型1.2 非线性规划求解的Matlab函数 2. 典型例题3. matlab代码求解3.1 例1 一个简单示例3.2 例2 选址问题1. 第一问 线性规划2. 第二问 非线性规划 非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法。运筹学的一个重要分支。2

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

查看提交历史 —— Git 学习笔记 11

查看提交历史 查看提交历史 不带任何选项的git log-p选项--stat 选项--pretty=oneline选项--pretty=format选项git log常用选项列表参考资料 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的 工具是 git log 命令。 接下来的例子会用一个用于演示的 simplegit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓