查看: 24407|回复: 1
收起左侧

MTK Camera 开机启动流程

[复制链接]
发表于 2015-8-22 08:08:53 | 显示全部楼层 |阅读模式
一、MTK平台Camera框架
0 h7 l9 A6 a- @. @, I. Q4 e) }) y

         MTK平台的Camera的架构见下图,


0 \7 `( P  v( G/ P

     
5 B5 j+ F$ \3 K- O: Q4 N' ?这里主要介绍kernel部分和HAL层部分。

    1、Kernel 部分主要有两块:

           1.1、image sensordriver,负责具体型号的 sensor 的 id 检测,上电,以及在preview、capture、初始化、3A等等功能设定时的寄存器配置。

           1.2、isp driver,通过DMA将sensor数据流上传。

: v+ K$ Y: O: e

        2、HAL层部分主要有三部分组成:

           2.1、imageio,主要负责数据buffer上传的pipe。

          2.2、drv,包含imgsensor和isp的hal层控制。

          2.3、feature io,包含各种3A等性能配置。
# B2 R  L- V* W+ B! h6 h9 O0 \


3 ?; w' w8 o# c* ^8 w1 h# {5 s二、Camera打开流程分析

         Camera开启流程图如下:

        主要发生在两个时间点:

    1、开机时:camera完成了sensor框架初始化,id检测并匹配sensor,以及上下电操作。

    2、打开Camera应用时:camera会有上电,完成sensor的寄存器初始化配置,向上层传递基本参数和配置信息,以及preview和capture模式循环。. F, M- C# F3 @' ~- r8 m


8 E7 I% S+ i6 H; n8 f; n1、开机初始化过程

         由于一开始不知道上电camera初始化从哪开始,我们可以借助抓取的mtk mobile log去分析。先看hal层log开始处:


% q, M2 O4 N3 W$ M  @6 D" T% A8 [+ Z- T# c3 Y; f) t* F. t. n  }
" v1 O7 {7 D& A4 C7 V: G
  • 12-24 10:02:07.601   148   148 D MtkCam/module: [instantiate_camera_module]  
  • 12-24 10:02:07.601   148   148 D MtkCam/Utils/Property: [clear] pid/tid=148/148  
  • 12-24 10:02:07.601   148   148 I CameraService: Loaded "MediaTek Camera Module" camera module  
  • 12-24 10:02:07.601   148   148 D MtkCam/MtkCamUtils: [CamDevMetaInfoMap::clear] pid/tid=148/148  
  • 12-24 10:02:07.601   148   148 D SensorHal: [getInstance][SensorHalImp] getInstance  
  • 12-24 10:02:07.601   148   148 D SensorHal: [createImp][createImp]: 0  
  • 12-24 10:02:07.601   148   148 D SeninfDrvImp: [getInstance][getInstance]  
  • 12-24 10:02:07.601   148   148 D SeninfDrvImp: [SeninfDrvImp][SeninfDrvImp]  
  • 12-24 10:02:07.601   148   148 D SeninfDrvImp: [init][init]: 0  
    8 O1 U9 W' a+ n/ O
    ( I6 }9 E! q/ T* d) |+ {

! ]# F1 D* B1 ]" `- y, E0 I0 B

        通过sourceinsight搜索发现开始是从CamDeviceManagerImp.cpp函数的enumDeviceLocked()开始。该函数的源代码如下:

===>mediatek/platform/mt6582/hardware/mtkcam/devicemgr/CamDeviceManagerImp.cpp


, ^$ t: }. v  F
  • /******************************************************************************
  • *
  • ******************************************************************************/  
  • int32_t  
  • CamDeviceManagerImp::  
  • enumDeviceLocked()  
  • {  
  •     Utils::CamProfile _profile(__FUNCTION__, "CamDeviceManagerImp");  
  •     //  
  •     status_t status = OK;  
  •     int32_t i4DeviceNum = 0;  
  •     //  
  •     mEnumMap.clear();  
  • //------------------------------------------------------------------------------  
  • #if '1'==MTKCAM_HAVE_SENSOR_HAL  
  •   
  •     mEnumMap.clear();  
  •     DevMetaInfo::clear();  
  •     //  
  •     int32_t isFakeOrientation = 0;  
  •     int32_t i4DevSetupOrientation = 0;  
  •     camera_info camInfo;  
  •     camInfo.device_version = CAMERA_DEVICE_API_VERSION_1_0;  
  •     camInfo.static_camera_characteristics = NULL;  
  •     //  
  •     SensorHal* pSensorHal = SensorHal::createInstance();//创建sensor对象  
  •     if  ( ! pSensorHal )  
  •     {  
  •         MY_LOGE("pSensorHal == NULL");  
  •         return 0;  
  •     }  
  •     //  
  •     int32_t const iSensorsList = pSensorHal->searchSensor();//此函数是入口,主要查找匹配的硬件sensor  
  •     //  
  •     //  
  •     if  ( (iSensorsList & SENSOR_DEV_MAIN_3D) == SENSOR_DEV_MAIN_3D )  
  •     {  
  •         MY_LOGI("Stereo 3D Camera found");  
  • #warning "[TODO] Stereo 3D Camera"  
  •     }  
  •     //  
  •     if  ( (iSensorsList & SENSOR_DEV_MAIN) == SENSOR_DEV_MAIN )  
  •     {  
  •         int32_t const deviceId = i4DeviceNum;  
  •         //  
  •         halSensorDev_e const eHalSensorDev = SENSOR_DEV_MAIN;  
  •         pSensorHal->sendCommand(eHalSensorDev, SENSOR_CMD_GET_FAKE_ORIENTATION, (int)&isFakeOrientation);  
  •         pSensorHal->sendCommand(eHalSensorDev, SENSOR_CMD_GET_SENSOR_ORIENTATION_ANGLE, (int)&i4DevSetupOrientation);  
  •         pSensorHal->sendCommand(eHalSensorDev, SENSOR_CMD_GET_SENSOR_FACING_DIRECTION, (int)&camInfo.facing);  
  •         camInfo.orientation = i4DevSetupOrientation;  
  •         if  ( isFakeOrientation )  
  •         {  
  •             camInfo.orientation = (0==camInfo.facing) ? 90 : 270;  
  •             MY_LOGW("Fake orientation:%d instead of %d, facing=%d HalSensorDev=%#x", camInfo.orientation, i4DevSetupOrientation, camInfo.facing, eHalSensorDev);  
  •         }  
  •         DevMetaInfo::add(deviceId, camInfo, i4DevSetupOrientation, eDevId_ImgSensor, eHalSensorDev);  
  •         //  
  •         sp<EnumInfo> pInfo = new EnumInfo;  
  •         pInfo->uDeviceVersion       = CAMERA_DEVICE_API_VERSION_1_0;  
  •         pInfo->pMetadata            = NULL;  
  •         pInfo->iFacing              = camInfo.facing;  
  •         pInfo->iWantedOrientation   = camInfo.orientation;  
  •         pInfo->iSetupOrientation    = i4DevSetupOrientation;  
  •         mEnumMap.add(deviceId, pInfo);  
  •         //  
  •         i4DeviceNum++;  
  •     }  
  •     //  
  •     if  ( (iSensorsList & SENSOR_DEV_SUB) == SENSOR_DEV_SUB )  
  •     {  
  •         int32_t const deviceId = i4DeviceNum;  
  •         //  
  •         halSensorDev_e const eHalSensorDev = SENSOR_DEV_SUB;  
  •         pSensorHal->sendCommand(eHalSensorDev, SENSOR_CMD_GET_FAKE_ORIENTATION, (int)&isFakeOrientation);  
  •         pSensorHal->sendCommand(eHalSensorDev, SENSOR_CMD_GET_SENSOR_ORIENTATION_ANGLE, (int)&i4DevSetupOrientation);  
  •         pSensorHal->sendCommand(eHalSensorDev, SENSOR_CMD_GET_SENSOR_FACING_DIRECTION, (int)&camInfo.facing);  
  •         camInfo.orientation = i4DevSetupOrientation;  
  •         if  ( isFakeOrientation )  
  •         {  
  •             camInfo.orientation = (0==camInfo.facing) ? 90 : 270;  
  •             MY_LOGW("Fake orientation:%d instead of %d, facing=%d HalSensorDev=%#x", camInfo.orientation, i4DevSetupOrientation, camInfo.facing, eHalSensorDev);  
  •         }  
  •         DevMetaInfo::add(deviceId, camInfo, i4DevSetupOrientation, eDevId_ImgSensor, eHalSensorDev);  
  •         //  
  •         sp<EnumInfo> pInfo = new EnumInfo;  
  •         pInfo->uDeviceVersion       = CAMERA_DEVICE_API_VERSION_1_0;  
  •         pInfo->pMetadata            = NULL;  
  •         pInfo->iFacing              = camInfo.facing;  
  •         pInfo->iWantedOrientation   = camInfo.orientation;  
  •         pInfo->iSetupOrientation    = i4DevSetupOrientation;  
  •         mEnumMap.add(deviceId, pInfo);  
  •         //  
  •         i4DeviceNum++;  
  •     }  
  •     //  
  • //    if  ( (iSensorsList & SENSOR_DEV_ATV) == SENSOR_DEV_ATV )  
  •     {  
  •         int32_t const deviceId = 0xFF;  
  •         //  
  •         halSensorDev_e const eHalSensorDev = SENSOR_DEV_ATV;  
  •         camInfo.facing = 0;  
  •         camInfo.orientation = 0;  
  •         DevMetaInfo::add(deviceId, camInfo, camInfo.orientation, eDevId_AtvSensor, eHalSensorDev);  
  •         //  
  •         sp<EnumInfo> pInfo = new EnumInfo;  
  •         pInfo->uDeviceVersion       = CAMERA_DEVICE_API_VERSION_1_0;  
  •         pInfo->pMetadata            = NULL;  
  •         pInfo->iFacing              = camInfo.facing;  
  •         pInfo->iWantedOrientation   = camInfo.orientation;  
  •         pInfo->iSetupOrientation    = i4DevSetupOrientation;  
  •         mEnumMap.add(deviceId, pInfo);  
  •         //  
  • //        i4DeviceNum++;  
  •     }  
  •     //  
  •     //  
  •     if  ( pSensorHal )  
  •     {  
  •         pSensorHal->destroyInstance();  
  •         pSensorHal = NULL;  
  •     }  
  •     //  
  •     MY_LOGI("iSensorsList=0x%08X, i4DeviceNum=%d", iSensorsList, i4DeviceNum);  
  •     for (size_t i = 0; i < mEnumMap.size(); i++)  
  •     {  
  •         int32_t const deviceId = mEnumMap.keyAt(i);  
  •         sp<EnumInfo> pInfo = mEnumMap.valueAt(i);  
  •         uint32_t const uDeviceVersion   = pInfo->uDeviceVersion;  
  •         camera_metadata const*pMetadata = pInfo->pMetadata;  
  •         int32_t const iFacing           = pInfo->iFacing;  
  •         int32_t const iWantedOrientation= pInfo->iWantedOrientation;  
  •         int32_t const iSetupOrientation = pInfo->iSetupOrientation;  
  •         MY_LOGI(  
  •             "[0x%02x] orientation(wanted/setup)=(%d/%d) facing:%d metadata:%p DeviceVersion:0x%x",   
  •             deviceId, iWantedOrientation, iSetupOrientation,   
  •             iFacing, pMetadata, uDeviceVersion  
  •         );  
  •     }  
  •   
  • #else   //----------------------------------------------------------------------  
  •   
  •     #warning "[WARN] Simulation for CamDeviceManagerImp::enumDeviceLocked()"  
  •   
  •     mEnumMap.clear();  
  •     DevMetaInfo::clear();  
  •     {  
  •         int32_t const deviceId = 0;  
  •         //  
  •         camera_info camInfo;  
  •         camInfo.device_version  = CAMERA_DEVICE_API_VERSION_1_0;  
  •         camInfo.static_camera_characteristics = NULL;  
  •         camInfo.facing      = 0;  
  •         camInfo.orientation = 90;  
  •         DevMetaInfo::add(deviceId, camInfo, camInfo.orientation, eDevId_ImgSensor, 0x01/*SENSOR_DEV_MAIN*/);  
  •         //  
  •         sp<EnumInfo> pInfo = new EnumInfo;  
  •         pInfo->uDeviceVersion       = CAMERA_DEVICE_API_VERSION_1_0;  
  •         pInfo->pMetadata            = NULL;  
  •         pInfo->iFacing              = 0;  
  •         pInfo->iWantedOrientation   = 90;  
  •         pInfo->iSetupOrientation    = 90;  
  •         mEnumMap.add(deviceId, pInfo);  
  •     }  
  •     //  
  •     {  
  •         int32_t const deviceId = 0xFF;  
  •         //  
  •         camera_info camInfo;  
  •         camInfo.device_version  = CAMERA_DEVICE_API_VERSION_1_0;  
  •         camInfo.static_camera_characteristics = NULL;  
  •         camInfo.facing      = 0;  
  •         camInfo.orientation = 0;  
  •         DevMetaInfo::add(deviceId, camInfo, camInfo.orientation, eDevId_AtvSensor, 0x04/*SENSOR_DEV_ATV*/);  
  •         //  
  •         sp<EnumInfo> pInfo = new EnumInfo;  
  •         pInfo->uDeviceVersion       = CAMERA_DEVICE_API_VERSION_1_0;  
  •         pInfo->pMetadata            = NULL;  
  •         pInfo->iFacing              = 0;  
  •         pInfo->iWantedOrientation   = 0;  
  •         pInfo->iSetupOrientation    = 0;  
  •         mEnumMap.add(deviceId, pInfo);  
  •     }  
  •     //  
  •     i4DeviceNum = 1;  
  •   
  • #endif  
  • //------------------------------------------------------------------------------  
  •     //  
  •     _profile.print("");  
  •     return  i4DeviceNum;  
  • }  
    7 X1 P! n! j8 M+ ~

- L( N; }" I/ H  U& {

       7 R/ ]8 I% p( x* ~% F+ y

     函数pSensorHal->searchSensor()将调用SensorDrv::searchSensor(NULL)函数,该函数再调用ImgSensor_drv.cpp文件中中的ImgSensorDrv::impSearchSensor函数。

===>mediatek/platform/mt6582/hardware/mtkcam/core/drv/imgsensor/ImgSensor_drv.cpp


$ e0 k8 g* \( ^5 J7 w8 g
  • /*******************************************************************************
  • *
  • ********************************************************************************/  
  •   
  • MINT32   
  • ImgSensorDrv::impSearchSensor(pfExIdChk pExIdChkCbf)  
  • {  
  •     MUINT32 SensorEnum = (MUINT32) DUAL_CAMERA_MAIN_SENSOR;  
  •     MUINT32 i,id[KDIMGSENSOR_MAX_INVOKE_DRIVERS] = {0,0};  
  •     MBOOL SensorConnect=TRUE;  
  •     UCHAR cBuf[64];  
  •     MINT32 err = SENSOR_NO_ERROR;  
  •     MINT32 err2 = SENSOR_NO_ERROR;  
  •     ACDK_SENSOR_INFO_STRUCT SensorInfo;  
  •     ACDK_SENSOR_CONFIG_STRUCT SensorConfigData;  
  •     ACDK_SENSOR_RESOLUTION_INFO_STRUCT SensorResolution;  
  •     MINT32 sensorDevs = SENSOR_NONE;  
  •     IMAGE_SENSOR_TYPE sensorType = IMAGE_SENSOR_TYPE_UNKNOWN;  
  •     IMGSENSOR_SOCKET_POSITION_ENUM socketPos = IMGSENSOR_SOCKET_POS_NONE;  
  •   
  •   
  •     //! If imp sensor search process already done before,   
  •     //! only need to return the sensorDevs, not need to   
  •     //! search again.   
  •     if (SENSOR_DOES_NOT_EXIST != m_mainSensorId) {  
  •         //been processed.  
  •         LOG_MSG("[impSearchSensor] Already processed \n");   
  •         if (BAD_SENSOR_INDEX != m_mainSensorIdx) {  
  •             sensorDevs |= SENSOR_MAIN;  
  •         }  
  •   
  •         if (BAD_SENSOR_INDEX != m_subSensorIdx) {  
  •             sensorDevs |= SENSOR_SUB;  
  •         }  
  •   
  •         #ifdef  ATVCHIP_MTK_ENABLE  
  •   
  •             sensorDevs |= SENSOR_ATV;  
  •   
  •         #endif  
  •   
  •   
  •         return sensorDevs;   
  •     }  
  •       
  •     GetSensorInitFuncList(&m_pstSensorInitFunc);//----(1)获取hal层的sensor列表  
  •   
  •     LOG_MSG("SENSOR search start \n");  
  •   
  •     if (-1 != m_fdSensor) {  
  •         ::close(m_fdSensor);  
  •         m_fdSensor = -1;  
  •     }  
  •     sprintf(cBuf,"/dev/%s",CAMERA_HW_DEVNAME);  
  •     m_fdSensor = : : open(cBuf, O_RDWR);  
  •     if (m_fdSensor < 0) {  
  •          LOG_ERR("[impSearchSensor]: error opening %s: %s \n", cBuf, strerror(errno));   
  •         return sensorDevs;  
  •     }  
  •     LOG_MSG("[impSearchSensor] m_fdSensor = %d  \n", m_fdSensor);  
  •   
  •     // search main/main_2/sub 3 sockets  
  •    #ifdef MTK_SUB_IMGSENSOR   
  •     for (SensorEnum = DUAL_CAMERA_MAIN_SENSOR; SensorEnum <= DUAL_CAMERA_SUB_SENSOR; SensorEnum <<= 1)  {  
  •         LOG_MSG("impSearchSensor search to sub\n");  
  •    #else  
  •     for (SensorEnum = DUAL_CAMERA_MAIN_SENSOR; SensorEnum < DUAL_CAMERA_SUB_SENSOR; SensorEnum <<= 1)  {  
  •         LOG_MSG("impSearchSensor search to main\n");     
  •    #endif      
  •         //skip atv case  
  •         if ( 0x04 == SensorEnum ) continue;  
  •         //  
  •         for (i = 0; i < MAX_NUM_OF_SUPPORT_SENSOR; i++) {  
  •             //end of driver list  
  •             if (m_pstSensorInitFunc.getCameraDefault == NULL) {  
  •                 LOG_MSG("m_pstSensorInitFunc.getCameraDefault is NULL: %d \n", i);                  
  •                 break;  
  •             }  
  •                 //set sensor driver  
  •             id[KDIMGSENSOR_INVOKE_DRIVER_0] = (SensorEnum << KDIMGSENSOR_DUAL_SHIFT) | i;  
  •             LOG_MSG("set sensor driver id =%x\n", id[KDIMGSENSOR_INVOKE_DRIVER_0]);   
  •             err = ioctl(m_fdSensor, KDIMGSENSORIOC_X_SET_DRIVER,&id[KDIMGSENSOR_INVOKE_DRIVER_0] );//--(2)调用kernel层的kdSetDriver函数  
  •                 if (err < 0) {  
  •                     LOG_ERR("ERROR:KDCAMERAHWIOC_X_SET_DRIVER\n");  
  •                 }  
  •   
  •             
  •   
  •                 //err = open();  
  •                 err = ioctl(m_fdSensor, KDIMGSENSORIOC_T_CHECK_IS_ALIVE);//---(3)上下电camera并读取sensor的ID,如果匹配则成功  
  •                   
  •   
  •                   
  •                 if (err < 0) {  
  •                     LOG_MSG("[impSearchSensor] Err-ctrlCode (%s) \n", strerror(errno));//  
  •                 }  
  •             //  
  •             sensorType = this->getCurrentSensorType((SENSOR_DEV_ENUM)SensorEnum);  
  •             //  
  •             socketPos = this->getSocketPosition((CAMERA_DUAL_CAMERA_SENSOR_ENUM)SensorEnum);  
  •                 //check extra ID , from EEPROM maybe  
  •                 //may need to keep power here  
  •                 if (NULL != pExIdChkCbf) {  
  •                     err2 = pExIdChkCbf();  
  •                     if (err2 < 0) {  
  •                         LOG_ERR("Error:pExIdChkCbf() \n");  
  •                     }  
  •                 }  
  •   
  •                 //power off sensor  
  •                 close();  
  •   
  •                 if (err < 0 || err2 < 0) {  
  •                     LOG_MSG("sensor ID mismatch\n");  
  •                 }  
  •                 else {  
  •                     if (SensorEnum == DUAL_CAMERA_MAIN_SENSOR) {  
  •                 //m_mainSensorIdx = i;  
  •                 //m_mainSensorId = m_pstSensorInitFunc[m_mainSensorIdx].SensorId;  
  •                 m_mainSensorDrv.index[m_mainSensorDrv.number] = i;  
  •                 m_mainSensorDrv.type[m_mainSensorDrv.number] = sensorType;  
  •                 if ( IMAGE_SENSOR_TYPE_RAW == sensorType && BAD_SENSOR_INDEX == m_mainSensorDrv.firstRawIndex ) {  
  •                     m_mainSensorDrv.firstRawIndex = i;  
  •                 }  
  •                 else if ( IMAGE_SENSOR_TYPE_YUV == sensorType && BAD_SENSOR_INDEX == m_mainSensorDrv.firstYuvIndex ) {  
  •                     m_mainSensorDrv.firstYuvIndex = i;  
  •                 }  
  •                 m_mainSensorDrv.position = socketPos;  
  •                 m_mainSensorDrv.sensorID = m_pstSensorInitFunc[m_mainSensorDrv.index[m_mainSensorDrv.number]].SensorId;  
  •                 // LOG_MSG("MAIN sensor m_mainSensorDrv.number=%d, m_mainSensorDrv.index=%d\n",m_mainSensorDrv.number,m_mainSensorDrv.index[m_mainSensorDrv.number]);  
  •                 m_mainSensorDrv.number++;  
  •                 //  
  •                 m_pMainSensorInfo = m_pstSensorInitFunc.pSensorInfo;  
  •                 if  ( m_pMainSensorInfo )  
  •                 {  
  •                     NSFeature::SensorInfoBase* pSensorInfo = m_pstSensorInitFunc.pSensorInfo;  
  •                     LOG_MSG("found <%#x/%s/%s>", pSensorInfo->GetID(), pSensorInfo->getDrvName(), pSensorInfo->getDrvMacroName());  
  •                 }  
  •                 else  
  •                 {  
  •                     LOG_WRN("m_pMainSensorInfo==NULL\n");  
  •                 }  
  •                 LOG_MSG("MAIN sensor found:[%d]/[0x%x]/[%d]/[%d] \n",i,id[KDIMGSENSOR_INVOKE_DRIVER_0],sensorType,socketPos);  
  •                 //break;  
  •             }  
  •             else if (SensorEnum == DUAL_CAMERA_SUB_SENSOR) {  
  •                 //m_subSensorIdx = i;  
  •                 //m_subSensorId = m_pstSensorInitFunc[m_subSensorIdx].SensorId;  
  •                 m_subSensorDrv.index[m_subSensorDrv.number] = i;  
  •                 m_subSensorDrv.type[m_subSensorDrv.number] = sensorType;  
  •                 if ( IMAGE_SENSOR_TYPE_RAW == sensorType && BAD_SENSOR_INDEX == m_subSensorDrv.firstRawIndex ) {  
  •                     m_subSensorDrv.firstRawIndex = i;  
  •                 }  
  •                 else if ( IMAGE_SENSOR_TYPE_YUV == sensorType && BAD_SENSOR_INDEX == m_subSensorDrv.firstYuvIndex ) {  
  •                     m_subSensorDrv.firstYuvIndex = i;  
  •                 }  
  •                 m_subSensorDrv.position = socketPos;  
  •                 m_subSensorDrv.sensorID = m_pstSensorInitFunc[m_subSensorDrv.index[m_subSensorDrv.number]].SensorId;  
  •                 //LOG_MSG("SUB sensor m_subSensorDrv.number=%d, m_subSensorDrv.index=%d\n",m_subSensorDrv.number,m_subSensorDrv.index[m_subSensorDrv.number]);  
  •                 m_subSensorDrv.number++;  
  •                 //  
  •                 m_pSubSensorInfo = m_pstSensorInitFunc.pSensorInfo;  
  •                 if  ( m_pSubSensorInfo )  
  •                 {  
  •                     NSFeature::SensorInfoBase* pSensorInfo = m_pstSensorInitFunc.pSensorInfo;  
  •                     LOG_MSG("found <%#x/%s/%s>", pSensorInfo->GetID(), pSensorInfo->getDrvName(), pSensorInfo->getDrvMacroName());  
  •                 }  
  •                 else  
  •                 {  
  •                     LOG_WRN("m_pSubSensorInfo==NULL\n");  
  •                 }  
  •                 LOG_MSG("SUB sensor found:[%d]/[0x%x]/[%d]/[%d] \n",i,id[KDIMGSENSOR_INVOKE_DRIVER_0],sensorType,socketPos);  
  •                 //break;  
  •             }  
  •         }//  
  •          
  •         }  
  •     }  
  •     //close system call may be off sensor power. check first!!!  
  •     ::close(m_fdSensor);  
  •     m_fdSensor = -1;  
  •     //  
  •     if (BAD_SENSOR_INDEX != m_mainSensorDrv.index[0]) {  
  •         m_mainSensorId = m_mainSensorDrv.sensorID;  
  •         //init to choose first  
  •         m_mainSensorIdx = m_mainSensorDrv.index[0];  
  •         sensorDevs |= SENSOR_MAIN;  
  •     }  
  •   
  •     if (BAD_SENSOR_INDEX != m_subSensorDrv.index[0]) {  
  •         m_subSensorId = m_subSensorDrv.sensorID;  
  •         //init to choose first  
  •         m_subSensorIdx = m_subSensorDrv.index[0];  
  •         sensorDevs |= SENSOR_SUB;  
  •     }  
  •   
  •     #ifdef  ATVCHIP_MTK_ENABLE  
  •       
  •         sensorDevs |= SENSOR_ATV;  
  •       
  •     #endif  
  •   
  •   
  •     if (sensorDevs == SENSOR_NONE) {  
  •         LOG_ERR( "Error No sensor found!! \n");  
  •     }  
  •     //  
  •     LOG_MSG("SENSOR search end: 0x%x /[0x%x][%d]/[0x%x][%d]\n", sensorDevs,  
  •     m_mainSensorId,m_mainSensorIdx,m_subSensorId,m_subSensorIdx);  
  •   
  •     return sensorDevs;  
  • }//  
    & U6 X+ y. ?3 U) t# E2 @) h9 e& f

(1)、获取hal层sensor列表GetSensorInitFuncList(&m_pstSensorInitFunc);

===>mediatek/custom/common/hal/imgsensor/src/sensorlist.cpp


2 D/ U* |0 T) [* V4 g3 T. E; |
  • UINT32 GetSensorInitFuncList(MSDK_SENSOR_INIT_FUNCTION_STRUCT **ppSensorList)  
  • {  
  •     if (NULL == ppSensorList) {  
  •         ALOGE("ERROR: NULL pSensorList\n");  
  •         return MHAL_UNKNOWN_ERROR;  
  •     }  
  •     *ppSensorList = &SensorList[0];//这里直接调用hal层的sensor列表  
  •     return MHAL_NO_ERROR;  
  • } // GetSensorInitFuncList()  
    % d9 f5 i# }. X8 f! `. ?# r' w% a+ r, q

3 w5 }* I  W" \+ J8 F5 C===>mediatek/custom/common/hal/imgsensor/src/sensorlist.cpp
4 ^! n% x/ P% @) Q" a7 H
: }/ U& G5 o! f* Y. y0 ]
7 z8 i* {% {* X% I+ ^
  • MSDK_SENSOR_INIT_FUNCTION_STRUCT SensorList[] =  
  • {  
  •     //add by zym  
  • #if defined(GC2235_MIPI_RAW)  
  •     RAW_INFO(GC2235MIPI_SENSOR_ID, SENSOR_DRVNAME_GC2235_MIPI_RAW, NULL),   
  • #endif  
  • // add by zhouzuoyu  
  • #if defined(GC2235_KOTECH_MIPI_RAW)  
  •     RAW_INFO(GC2235MIPI_SENSOR_ID, SENSOR_DRVNAME_GC2235_MIPI_RAW, NULL),   
  • #endif  
  • #if defined(OV16825_MIPI_RAW)  
  •     RAW_INFO(OV16825MIPI_SENSOR_ID, SENSOR_DRVNAME_OV16825_MIPI_RAW,NULL),   
  • #endif  
  • #if defined(IMX135_MIPI_RAW)  
  •         RAW_INFO(IMX135_SENSOR_ID, SENSOR_DRVNAME_IMX135_MIPI_RAW,NULL),   
  • #endif  
  • #if defined(OV8830_RAW)  
  •     RAW_INFO(OV8830_SENSOR_ID, SENSOR_DRVNAME_OV8830_RAW, NULL),  
  • #endif  
  •   
  • /*  ADD sensor driver before this line */  
  •     {0,{0},NULL, NULL, NULL}//end of list  
  • };   
    ( P+ }$ `# }9 A# B$ b" _$ U
    " k  g6 k, A% m; A- u) u+ C
) w: }% v8 h( w2 m+ O  s6 D
* s" ?6 N6 H7 f% m* Z' o% J
( @) n* Q6 V; j+ y

(2)、获取kernel层的kdSetDriver函数err = ioctl(m_fdSensor, KDIMGSENSORIOC_X_SET_DRIVER,&id[KDIMGSENSOR_INVOKE_DRIVER_0] );

===>mediatek/custom/mt6582/kernel/imgsensor/src/kd_sensorlist.c

2 K2 y7 u# ]4 J7 w' B9 @( ~" T1 ?

# ]; _5 j" n) S' }: R0 O7 O2 h- d
  • /*******************************************************************************
  • * kdSetDriver
  • ********************************************************************************/  
  • int kdSetDriver(unsigned int* pDrvIndex)  
  • {  
  •     ACDK_KD_SENSOR_INIT_FUNCTION_STRUCT *pSensorList = NULL;  
  •     u32 drvIdx[KDIMGSENSOR_MAX_INVOKE_DRIVERS] = {0,0};  
  •     u32 i;  
  •   
  •     PK_XLOG_INFO("pDrvIndex:0x%08x/0x%08x \n",pDrvIndex[KDIMGSENSOR_INVOKE_DRIVER_0],pDrvIndex[KDIMGSENSOR_INVOKE_DRIVER_1]);  
  •     //set driver for MAIN or SUB sensor  
  •   
  •     if (0 != kdGetSensorInitFuncList(&pSensorList))//----(2.1)获取kernel层的sensor列表  
  •     {  
  •         PK_ERR("ERROR:kdGetSensorInitFuncList()\n");  
  •         return -EIO;  
  •     }  
  •   
  •     for ( i = KDIMGSENSOR_INVOKE_DRIVER_0; i < KDIMGSENSOR_MAX_INVOKE_DRIVERS ; i++ ) {  
  •         //  
  •         spin_lock(&kdsensor_drv_lock);  
  •         g_bEnableDriver = FALSE;  
  •         g_invokeSocketIdx = (CAMERA_DUAL_CAMERA_SENSOR_ENUM)((pDrvIndex & KDIMGSENSOR_DUAL_MASK_MSB)>>KDIMGSENSOR_DUAL_SHIFT);  
  •     spin_unlock(&kdsensor_drv_lock);  
  •   
  •         drvIdx = (pDrvIndex & KDIMGSENSOR_DUAL_MASK_LSB);//----(2.2)g_invokeSocketIdx,drvIdx解释  
  •         //  
  •         if ( DUAL_CAMERA_NONE_SENSOR == g_invokeSocketIdx ) { continue; }  
  •   
  •   
  •         //ToDo: remove print information  
  •         PK_XLOG_INFO("[kdSetDriver] i,g_invokeSocketIdx[%d] = %d :\n",i,i,drvIdx);  
  •         PK_XLOG_INFO("[kdSetDriver] i,drvIdx[%d] = %d :\n",i,i,drvIdx);  
  •         //  
  •         if ( MAX_NUM_OF_SUPPORT_SENSOR > drvIdx ) {  
  •             if (NULL == pSensorList[drvIdx].SensorInit) {  
  •                 PK_ERR("ERROR:kdSetDriver()\n");  
  •                 return -EIO;  
  •             }  
  •   
  •             pSensorList[drvIdx].SensorInit(&g_pInvokeSensorFunc);//----(2.3)获取指定sensor的fun函数,例如ov5670的func  
  •             if (NULL == g_pInvokeSensorFunc) {  
  •                 PK_ERR("ERROR:NULL g_pSensorFunc[%d]\n",i);  
  •             return -EIO;  
  •             }  
  •             //  
  •             spin_lock(&kdsensor_drv_lock);  
  •             g_bEnableDriver = TRUE;  
  •             spin_unlock(&kdsensor_drv_lock);  
  •             //get sensor name  
  •             memcpy((char*)g_invokeSensorNameStr,(char*)pSensorList[drvIdx].drvname,sizeof(pSensorList[drvIdx].drvname));  
  •             //return sensor ID  
  •             //pDrvIndex[0] = (unsigned int)pSensorList[drvIdx].SensorId;  
  •             PK_XLOG_INFO("[kdSetDriver] :[%d][%d][%d][%s][%d]\n",i,g_bEnableDriver,g_invokeSocketIdx,g_invokeSensorNameStr,sizeof(pSensorList[drvIdx].drvname));  
  •         }  
  •     }  
  •     return 0;  
  • }  
    3 ~! d- n8 q+ y: @, ]
    5 ?8 B( G4 T0 T+ P" @

# v. z% y8 i$ z2 o  D1 \1 V( ^' Q( ~: C
; [; C# S8 q( g( P2 u1 u

(2.1)获取kernel层的sensor列表kdGetSensorInitFuncList(&pSensorList)

===>mediatek/custom/mt6582/kernel/imgsensor/src/kd_sensorlist.c; X0 j' M7 |. I


( J) y4 y2 m% a3 d- l" B: k1 z8 y
  • /*******************************************************************************
  • * general camera image sensor kernel driver
  • *******************************************************************************/  
  • UINT32 kdGetSensorInitFuncList(ACDK_KD_SENSOR_INIT_FUNCTION_STRUCT **ppSensorList)  
  • {  
  •     if (NULL == ppSensorList)  
  •     {  
  •         PK_DBG("[kdGetSensorInitFuncList]ERROR: NULL ppSensorList\n");  
  •         return 1;  
  •     }  
  •     *ppSensorList = &kdSensorList[0];  
  •     return 0;  
  • } // kdGetSensorInitFuncList()  
    % i% m& K: U7 h# s
    * k3 l- j0 P* C' o9 M7 x

; N1 Z+ X# ^- ^% o5 e  }
===>mediatek/custom/mt6582/kernel/imgsensor/src/kd_sensorlist.h
. C6 S7 v- `" q, p: W

       hal层和kernel层的sensor列表顺序必须保持一致


5 Q! C6 D2 E, x/ Q3 {0 [4 {3 o
' @9 i- g1 C( X6 Y8 u
7 F/ p/ G: r# z- N, z/ d
  • ACDK_KD_SENSOR_INIT_FUNCTION_STRUCT kdSensorList[MAX_NUM_OF_SUPPORT_SENSOR+1] =  
  • {  
  • //add by zym  
  • #if defined(GC2235_MIPI_RAW)  
  •     {GC2235MIPI_SENSOR_ID, SENSOR_DRVNAME_GC2235_MIPI_RAW, GC2235MIPISensorInit},   
  • #endif  
  •   
  • // add by zhouzuoyu  
  • #if defined(GC2235_KOTECH_MIPI_RAW)  
  •     {GC2235MIPI_SENSOR_ID, SENSOR_DRVNAME_GC2235_MIPI_RAW, GC2235MIPISensorInit},   
  • #endif  
  •   
  • #if defined(OV16825_MIPI_RAW)  
  •         {OV16825MIPI_SENSOR_ID, SENSOR_DRVNAME_OV16825_MIPI_RAW, OV16825MIPISensorInit},   
  • #endif  
  • #if defined(IMX135_MIPI_RAW)  
  •         {IMX135_SENSOR_ID, SENSOR_DRVNAME_IMX135_MIPI_RAW, IMX135_MIPI_RAW_SensorInit},   
  • #endif  
  • #if defined(OV8830_RAW)  
  •     {OV8830_SENSOR_ID, SENSOR_DRVNAME_OV8830_RAW, OV8830SensorInit},   
  • #endif  
  • /*  ADD sensor driver before this line */  
  •     {0,{0},NULL}, //end of list  
  • };  
  • //e_add new sensor driver here<span style="font-size:18px;"><span style="font-size:18px;">         </span>   </span>   <span style="font-size:18px;"><span style="font-size:18px;">  
  • </span></span>  ; W3 y/ r; b! K& a0 n7 l% Y$ F

    + ?% J8 [7 ?' B: l& q. Z1 X

' [; u) e2 a0 L) q$ s' H" p2 x: p! x" D3 C+ f& V


2 A5 Y8 _. Y, N/ M

(2.2)g_invokeSocketIdx,drvIdx解释

      上层传下来的 id 参数解析成两部分 g_invokeSocketIdx 区分目前正在匹配的是 main 还是sub,drvIdx 是 sensor 列表的序列号 。

3 G- r' k. q1 d( g, p  U# B( G" E

(2.3)获取指定sensor的func函数,例如ov5670的func,pSensorList[drvIdx].SensorInit(&g_pInvokeSensorFunc);

         调用的函数是OV5670_MIPI_RAW_SensorInit()。

; `2 I/ ]7 J, x" e/ x' m8 [  I5 o: Q
  • #if defined(OV5670_MIPI_RAW)  
  •     {OV5670_SENSOR_ID, SENSOR_DRVNAME_OV5670_MIPI_RAW, OV5670_MIPI_RAW_SensorInit},   
  • #endif  - L. F' {# n9 ]5 K' j# W# Q

  |6 d/ W+ ^, r- H2 P3 d            
2 a+ a) T8 w" l( @- t/ B+ S' |( R/ d) b( A- p" R* H# @

===>mediatek/custom/common/kernel/imgsensor/ov5670_mipi_raw/ov5670mipiraw_Sensor.c

9 q: k6 P5 i2 ]8 K

# ~( v, ^6 C7 t, ^) h( W
  • SENSOR_FUNCTION_STRUCT  SensorFuncOV5670=  
  • {  
  •     OV5670Open,  
  •     OV5670GetInfo,  
  •     OV5670GetResolution,  
  •     OV5670FeatureControl,  
  •     OV5670Control,  
  •     OV5670Close  
  • };  
  •   
  • UINT32 OV5670_MIPI_RAW_SensorInit(PSENSOR_FUNCTION_STRUCT *pfFunc)//---调用此函数  
  • {  
  •     if (pfFunc!=NULL)  
  •         *pfFunc=&SensorFuncOV5670;  
  •   
  •     return ERROR_NONE;  
  • }  + d/ R( H: `+ l, a+ t
% g" {  M! Q( D. C( K3 ^

   5670的sensorinit实现,主要是未了pfFunc这个函数指针的结构体指针赋值,这样我们就实现了驱动代码的分离,hal层只需要调用sensorlist.c这样一个虚拟设备的驱动,就可以和具体的Sensor Driver驱动通信。这样的做法与platform driver的设计思想差不多,在tp,lcm等驱动中也有体现。

9 Y, I' z/ [2 f# T5 n

(3)上下电camera并读取ID,err = ioctl(m_fdSensor, KDIMGSENSORIOC_T_CHECK_IS_ALIVE);

===>mediatek/custom/mt6582/kernel/imgsensor/src/kd_sensorlist.c


6 z# E4 W7 |8 a; e$ y9 p2 n  {) b5 R0 g
  • /*******************************************************************************
  • * adopt_CAMERA_HW_CheckIsAlive
  • ********************************************************************************/  
  • inline static int adopt_CAMERA_HW_CheckIsAlive(void)  
  • {  
  •     UINT32 err = 0;  
  •     UINT32 err1 = 0;  
  •     UINT32 i = 0;  
  •     MUINT32 sensorID = 0;  
  •     MUINT32 retLen = 0;  
  •   
  •   
  •     KD_IMGSENSOR_PROFILE_INIT();  
  •     //power on sensor  
  •     kdModulePowerOn((CAMERA_DUAL_CAMERA_SENSOR_ENUM*)g_invokeSocketIdx, g_invokeSensorNameStr,true, CAMERA_HW_DRVNAME1);//----(3.1)sensor上电  
  •     //wait for power stable  
  •     mDELAY(10);  
  •     KD_IMGSENSOR_PROFILE("kdModulePowerOn");  
  •   
  •     if (g_pSensorFunc) {  
  •         for ( i = KDIMGSENSOR_INVOKE_DRIVER_0 ; i < KDIMGSENSOR_MAX_INVOKE_DRIVERS ; i++ ) {  
  •             if(DUAL_CAMERA_NONE_SENSOR != g_invokeSocketIdx){  
  •                 err = g_pSensorFunc->SensorFeatureControl(g_invokeSocketIdx, SENSOR_FEATURE_CHECK_SENSOR_ID, (MUINT8*)&sensorID, &retLen);//---(3.2)获取sensor ID  
  •                 if (sensorID == 0) {    //not implement this feature ID  
  •                     PK_DBG(" Not implement!!, use old open function to check\n");  
  •                     err = ERROR_SENSOR_CONNECT_FAIL;  
  •                 }  
  •                 else if (sensorID == 0xFFFFFFFF) {    //fail to open the sensor  
  •                     PK_DBG(" No Sensor Found");  
  •                     err = ERROR_SENSOR_CONNECT_FAIL;  
  •                 }  
  •                 else {  
  •   
  •                     PK_DBG(" Sensor found ID = 0x%x\n", sensorID);  
  •                     err = ERROR_NONE;  
  •                 }  
  •                 if(ERROR_NONE != err)  
  •                 {  
  •                     PK_DBG("ERROR:adopt_CAMERA_HW_CheckIsAlive(), No imgsensor alive \n");  
  •                 }  
  •             }  
  •         }  
  •     }  
  •     else {  
  •         PK_DBG("ERROR:NULL g_pSensorFunc\n");  
  •     }  
  •   
  •     //reset sensor state after power off  
  •     err1 = g_pSensorFunc->SensorClose();  
  •     if(ERROR_NONE != err1) {  
  •         PK_DBG("SensorClose \n");  
  •     }  
  •     //  
  •     kdModulePowerOn((CAMERA_DUAL_CAMERA_SENSOR_ENUM*)g_invokeSocketIdx, g_invokeSensorNameStr, false, CAMERA_HW_DRVNAME1);      
  •     //  
  •     KD_IMGSENSOR_PROFILE("CheckIsAlive");  
  •   
  •     return err?-EIO:err;  
  • }   /* adopt_CAMERA_HW_Open() */  
    $ \: k8 R8 b% `) K3 B( R
: i. R# t3 c+ b* v& H* n; `6 c

* z; |5 |5 b9 w4 L8 q(3.1)Sensor 上电, kdModulePowerOn((CAMERA_DUAL_CAMERA_SENSOR_ENUM*)g_invokeSocketIdx, g_invokeSensorNameStr,true, CAMERA_HW_DRVNAME1);5 M0 R, E$ V4 t  z( g% G8 R+ R
( ~; I, m5 X' Q3 E  f1 s
/ v4 [  k, z5 y) k9 V3 d4 P
  • /*******************************************************************************
  • * kdModulePowerOn
  • ********************************************************************************/  
  • int  
  • kdModulePowerOn(  
  • CAMERA_DUAL_CAMERA_SENSOR_ENUM socketIdx[KDIMGSENSOR_MAX_INVOKE_DRIVERS],  
  • char sensorNameStr[KDIMGSENSOR_MAX_INVOKE_DRIVERS][32],  
  • BOOL On,  
  • char* mode_name )  
  • {  
  • MINT32 ret = ERROR_NONE;  
  • u32 i = 0;  
  •   
  •     for ( i = KDIMGSENSOR_INVOKE_DRIVER_0 ; i < KDIMGSENSOR_MAX_INVOKE_DRIVERS ; i++ ) {  
  •         if ( g_bEnableDriver ) {  
  •             //PK_XLOG_INFO("[%s][%d][%d][%s][%s]\r\n",__FUNCTION__,g_bEnableDriver,socketIdx,sensorNameStr,mode_name);  
  •             ret = kdCISModulePowerOn(socketIdx,sensorNameStr,On,mode_name);//实际上电的func  
  •             if ( ERROR_NONE != ret ) {  
  •                 PK_ERR("[%s]",__FUNCTION__);  
  •                 return ret;  
  •             }  
  •         }  
  •     }  
  •     return ERROR_NONE;  
  • }  . _: U' z) P! D: J; _7 Q: u4 e

# Z( M' z# V* j! Z
( w4 a% _; ?# p' S2 K5 C6 h+ a===>mediatek/custom/huaqin82_slwt_2s_td/kernel/camera/camera/kd_camera_hw.c
) P  Y1 n, ?; r1 c7 C& `! C; K& V( X0 U, u7 R/ r5 J. L+ Z

, p* m9 Q, I$ b! E$ }$ ]1 A
  • int kdCISModulePowerOn(CAMERA_DUAL_CAMERA_SENSOR_ENUM SensorIdx, char *currSensorName, BOOL On, char* mode_name)  
  • {  
  •     PK_DBG("[camera] **kdCISModulePowerOn:SensorIdx:%d,pinSetIdx:%d",SensorIdx,pinSetIdx);  
  •     //dump_stack();  
  •     if (DUAL_CAMERA_MAIN_SENSOR == SensorIdx){  
  •     if (currSensorName &&   
  •        ((0 == strcmp(SENSOR_DRVNAME_OV5648_MIPI_RAW,currSensorName))  
  •        ||(0 == strcmp(SENSOR_DRVNAME_OV88251_MIPI_RAW,currSensorName))  
  •        ||(0 == strcmp(SENSOR_DRVNAME_OV88252_MIPI_RAW,currSensorName))  
  •           ||(0 == strcmp(SENSOR_DRVNAME_S5K3H7Y_MIPI_RAW,currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_S5K3H7Y_2LANE_MIPI_RAW,currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_S5K4E1GA_MIPI_RAW,currSensorName))  
  •       ||(0 == strcmp(SENSOR_DRVNAME_GC2235_MIPI_RAW,currSensorName))  
  •        ||(0 == strcmp(SENSOR_DRVNAME_HI258MIPI_YUV,currSensorName))  
  •         || (0 == strcmp(SENSOR_DRVNAME_OV8858_MIPI_RAW,currSensorName))  
  •         || (0 == strcmp(SENSOR_DRVNAME_T4K35_MIPI_RAW,currSensorName))  
  •        ||(0 == strcmp(SENSOR_DRVNAME_HI544_MIPI_RAW,currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_A5142_MIPI_RAW, currSensorName))  
  •               ||(0 == strcmp(SENSOR_DRVNAME_OV2680_MIPI_RAW,currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_OV5648_LARGEN_MIPI_RAW,currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_GC0310_MIPI_YUV, currSensorName))  
  •         || (0 == strcmp(SENSOR_DRVNAME_GC2145_MIPI_YUV, currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_S5K4H5YX_MIPI_RAW, currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_OV5670_MIPI_RAW,currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_HI551_MIPI_RAW,currSensorName))  
  •         //|| to add other main camera here  
  •        ))  
  •             pinSetIdx = 0;  
  •     else  
  •     {  
  •         PK_DBG("[ryf-main]kdCISModulePowerOn get in---  sensorIdx not compare with sensor name: %s\n", currSensorName);  
  •         //if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2035_YUV,currSensorName)))  
  •         //{  
  •         //      pinSetIdx = 1;  
  •         //}  
  •         //else{  
  •             goto _kdCISModulePowerOn_exit_;  
  •         //}  
  •     }  
  •     }  
  •     else if (DUAL_CAMERA_SUB_SENSOR == SensorIdx) {  
  •     if (currSensorName &&   
  •         ((0 == strcmp(SENSOR_DRVNAME_GC2035_YUV,currSensorName))  
  •         || (0 == strcmp(SENSOR_DRVNAME_S5K3H72Y_MIPI_RAW,currSensorName))  
  •         || (0 == strcmp(SENSOR_DRVNAME_S5K3H7Y_2LANE_MIPI_RAW, currSensorName))  
  •           || (0 == strcmp(SENSOR_DRVNAME_OV5648A_MIPI_RAW,currSensorName))  
  •           || (0 == strcmp(SENSOR_DRVNAME_OV5648B_MIPI_RAW,currSensorName))     
  •          || (0 == strcmp(SENSOR_DRVNAME_GC0329_YUV,currSensorName))   
  •           || (0 == strcmp(SENSOR_DRVNAME_GC2235_MIPI_RAW,currSensorName))   
  •         || (0 == strcmp(SENSOR_DRVNAME_OV5648_MIPI_RAW,currSensorName))  
  •         || (0 == strcmp(SENSOR_DRVNAME_GC2235_RAW,currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_A5142_MIPI_RAW, currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_GC0312_YUV, currSensorName))  
  •         ||(0 == strcmp(SENSOR_DRVNAME_HI704_YUV, currSensorName))  
  •               //||(0 == strcmp(SENSOR_DRVNAME_GC0310_MIPI_YUV, currSensorName))  
  •         //|| to add other sub camera here  
  •        ))  
  •             pinSetIdx = 1;  
  •     else  
  •     {  
  •         //if (currSensorName &&  
  •            //((0 == strcmp(SENSOR_DRVNAME_OV5648_MIPI_RAW,currSensorName))  
  •             //|| to add other main camera here  
  •            //))  
  •         //{  
  •         //  pinSetIdx = 0;  
  •         //}  
  •         PK_DBG("{ryf-sub}kdCISModulePowerOn get in---  sensorIdx not compare with sensro:%s\n",currSensorName);  
  •         goto _kdCISModulePowerOn_exit_;  
  •     }  
  •     }  
  •     else if (DUAL_CAMERA_MAIN_2_SENSOR == SensorIdx) {  
  •        // pinSetIdx = 2;  
  •     }  
  •   
  •     PK_DBG("kdCISModulePowerOn:SensorIdx:%d,pinSetIdx:%d",SensorIdx,pinSetIdx);  
  •     Rst_PDN_Init();  
  •   
  •     //power ON  
  •     if (On)   
  •     {  
  •      PK_DBG("kdCISModulePowerOn -on:currSensorName=%s\n",currSensorName);  
  •         if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5648_MIPI_RAW,currSensorName))) {  
  •             PK_DBG("is ov5648mipi on\n");  
  •             if (0 == pinSetIdx) {  
  •                 if (TRUE != kd_ov5648_main_poweron(mode_name))  
  •                     goto _kdCISModulePowerOn_exit_;  
  •             } else if (1 == pinSetIdx) {  
  •                 if (TRUE != kd_ov5648_sub_poweron(mode_name))  
  •                     goto _kdCISModulePowerOn_exit_;  
  •             }  
  •         }   
  •     else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_S5K4E1GA_MIPI_RAW,currSensorName)))            
  •         {  
  •         PK_DBG("is s5k4e1ga on \n");  
  •             if(TRUE != kd_s5k4e1gamipi_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }   
  •     else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI544_MIPI_RAW,currSensorName)))            
  •         {  
  •         PK_DBG("is hi544 on \n");  
  •             if(TRUE != kd_hi544raw_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }   
  •        else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2235_MIPI_RAW,currSensorName)))            
  •         {  
  •          PK_DBG("is gc2235 on\n");  
  •             if(TRUE != kd_gc2235mipiraw_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2235_RAW,currSensorName))) {  
  •             PK_DBG("is gc2235_raw on\n");  
  •               
  •             if (TRUE != kd_gc2235raw_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }   
  • /*  else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI253_YUV,currSensorName)))
  •         {
  •          PK_DBG("is hi253 on\n");
  •             if(TRUE != kd_hi253yuv_poweron(mode_name))
  •                  goto _kdCISModulePowerOn_exit_;
  •         }*/  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV88251_MIPI_RAW,currSensorName))) {   
  •         PK_DBG("is ov88251 on \n");   
  •         if(TRUE != kd_ov88251mipiraw_poweron(mode_name))      
  •                 goto _kdCISModulePowerOn_exit_;  
  •         }else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV88252_MIPI_RAW,currSensorName))) {   
  •         PK_DBG("is ov88252 on \n");   
  •         if(TRUE != kd_ov88252mipiraw_poweron(mode_name))      
  •                 goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV8858_MIPI_RAW,currSensorName))) {  
  •             PK_DBG("is ov8858 on \n");  
  •             kd_a5142mipiraw_sub_poweron(mode_name);  
  •             kd_a5142mipiraw_sub_powerdown(mode_name);  
  •             if(TRUE != kd_ov8858mipiraw_poweron(mode_name))   
  •                 goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_S5K4H5YX_MIPI_RAW,currSensorName))) {  
  •             PK_DBG("is s5k4h5yx on \n");  
  •             kd_a5142mipiraw_sub_poweron(mode_name);  
  •             kd_a5142mipiraw_sub_powerdown(mode_name);  
  •             if (TRUE != kd_s5k4h5yxmipiraw_poweron(mode_name))   
  •                 goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_T4K35_MIPI_RAW,currSensorName))) {  
  •             PK_DBG("is t4k35 on \n");     
  •             if(TRUE != kd_t4k35mipiraw_poweron(mode_name))   
  •                 goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && ((0 == strcmp(SENSOR_DRVNAME_S5K3H7Y_MIPI_RAW,currSensorName))   
  •         || (0 == strcmp(SENSOR_DRVNAME_S5K3H7Y_2LANE_MIPI_RAW,currSensorName)))) {  
  •             if(pinSetIdx==0)  
  •             {  
  •                 if(TRUE != kd_s5k3h7ymipiraw_poweron(mode_name))  
  •                     goto _kdCISModulePowerOn_exit_;  
  •             }  
  •             else  
  •             {  
  •                 if(TRUE != kd_s5k3h72ymipiraw_poweron(mode_name))  
  •                     goto _kdCISModulePowerOn_exit_;  
  •             }  
  •         } else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2035_YUV,currSensorName))) {  
  •          PK_DBG("is gc2035 on\n");  
  •             if(TRUE != kd_gc2035_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }   
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5648A_MIPI_RAW,currSensorName)))  
  •         {  
  •             if(TRUE != kd_ov5648a_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5670_MIPI_RAW,currSensorName)))  
  •         {  
  •             if(TRUE != kd_ov5670_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI551_MIPI_RAW,currSensorName)))  
  •         {  
  •             if(TRUE != kd_hi551_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5648B_MIPI_RAW,currSensorName)))  
  •         {  
  •             if(TRUE != kd_ov5648b_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         } else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5648_LARGEN_MIPI_RAW,currSensorName))) //lili add  
  •         {  
  •             if(TRUE != kd_ov5648_main_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         } else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_S5K3H72Y_MIPI_RAW,currSensorName))) {  
  •          PK_DBG("is s5k3h72ymipi on\n");  
  •             if(TRUE != kd_s5k3h72ymipiraw_poweron(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         } else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC0329_YUV,currSensorName)))              
  •                 {  
  •                    PK_DBG("is gc0329 on\n");  
  •                        if(TRUE != kd_gc0329_poweron(mode_name))  
  •                                 goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_A5142_MIPI_RAW, currSensorName))) {  
  •             if (0 == pinSetIdx) {  
  •                 PK_DBG("is A5142 main on \n");  
  •                 if(TRUE != kd_a5142mipiraw_main_poweron(mode_name))  
  •                     goto _kdCISModulePowerOn_exit_;  
  •             } else {  
  •                 PK_DBG("is A5142 sub on \n");  
  •                 if(TRUE != kd_a5142mipiraw_sub_poweron(mode_name))  
  •                     goto _kdCISModulePowerOn_exit_;  
  •             }  
  •               
  •            }else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC0312_YUV,currSensorName)))            
  •                 {  
  •                    PK_DBG("is gc0312 on\n");   
  •                        if(TRUE != kd_gc0312_poweron(mode_name))  
  •                                 goto _kdCISModulePowerOn_exit_;  
  •            }   
  •            else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI704_YUV,currSensorName)))              
  •                 {  
  •                    PK_DBG("is hi704 on\n");   
  •                        if(TRUE != kd_hi704yuv_poweron(mode_name))  
  •                                 goto _kdCISModulePowerOn_exit_;  
  •            }   
  •                else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC0310_MIPI_YUV,currSensorName)))            
  •                 {  
  •                    PK_DBG("is gc0310 on\n");  
  •                        if(TRUE != kd_gc0310_poweron(mode_name))  
  •                                 goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2145_MIPI_YUV,currSensorName))) {  
  •             PK_DBG("is gc2145 on\n");  
  •   
  •             if (TRUE != kd_gc2145_poweron(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI258MIPI_YUV,currSensorName)))  
  •         {     
  •             PK_DBG("is hi258 on \n");   
  •             if(TRUE != kd_hi258mipiraw_poweron(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •         }  
  •          else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV2680_MIPI_RAW,currSensorName))) {  
  •             PK_DBG("is ov2680 on \n");   
  •             if(TRUE != kd_ov2680mipiraw_poweron(mode_name))   
  •                 goto _kdCISModulePowerOn_exit_;  
  •         }  
  •     else   
  •     {  
  •         PK_DBG("kdCISModulePowerOn get in---  other , please add the power on code!!!!!!\n");  
  •         goto _kdCISModulePowerOn_exit_;  
  •         }  
  •   }  
  •   else {//power OFF  
  •   
  •     PK_DBG("kdCISModulePowerOn -off:currSensorName=%s\n",currSensorName);  
  •   
  •   
  •      if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5648_MIPI_RAW,currSensorName)))           
  •         {  
  •             PK_DBG("is ov5648_mipi_raw down\n");  
  •             if (0 == pinSetIdx) {  
  •                 if(TRUE != kd_ov5648_main_powerdown(mode_name))  
  •                     goto _kdCISModulePowerOn_exit_;  
  •             } else if (1 == pinSetIdx) {  
  •                 if(TRUE != kd_ov5648_sub_powerdown(mode_name))  
  •                     goto _kdCISModulePowerOn_exit_;  
  •             }  
  •         } else  if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_S5K4E1GA_MIPI_RAW,currSensorName)))              
  •         {  
  •          PK_DBG("is s5k4e1ga down\n");  
  •             if(TRUE != kd_s5k4e1gamipi_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else  if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI544_MIPI_RAW,currSensorName)))           
  •         {  
  •          PK_DBG("is hi544 down\n");  
  •             if(TRUE != kd_hi544raw_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV88251_MIPI_RAW,currSensorName)))  
  •         {  
  •             PK_DBG("is ov88251 down\n");  
  •              if(TRUE != kd_ov88251mipiraw_powerdown(mode_name))  
  •               goto _kdCISModulePowerOn_exit_;     
  •          
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5670_MIPI_RAW,currSensorName)))  
  •         {  
  •             PK_DBG("is ov5670 down\n");  
  •              if(TRUE != kd_ov5670mipiraw_powerdown(mode_name))  
  •               goto _kdCISModulePowerOn_exit_;     
  •          
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI551_MIPI_RAW,currSensorName)))  
  •         {  
  •             PK_DBG("is hi551 down\n");  
  •              if(TRUE != kd_hi551mipiraw_powerdown(mode_name))  
  •               goto _kdCISModulePowerOn_exit_;     
  •          
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV88252_MIPI_RAW,currSensorName)))  
  •         {  
  •             PK_DBG("is ov88252 down\n");  
  •              if(TRUE != kd_ov88252mipiraw_powerdown(mode_name))  
  •               goto _kdCISModulePowerOn_exit_;            
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV8858_MIPI_RAW,currSensorName))) {  
  •             PK_DBG("is ov8858 down\n");  
  •             if(TRUE != kd_ov8858mipiraw_powerdown(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_S5K4H5YX_MIPI_RAW, currSensorName))) {  
  •             PK_DBG("is s5k4h5yx down\n");  
  •             if (TRUE != kd_s5k4h5yxmipiraw_powerdown(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_T4K35_MIPI_RAW,currSensorName))) {  
  •             PK_DBG("is t4k35 down\n");  
  •             if(TRUE != kd_t4k35mipiraw_powerdown(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •         }  
  •     else  if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2235_MIPI_RAW,currSensorName)))              
  •         {  
  •          PK_DBG("is gc2235 down\n");  
  •             if(TRUE != kd_gc2235mipiraw_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2235_RAW,currSensorName))) {  
  •             PK_DBG("is gc2235 down\n");  
  •               
  •             if (TRUE != kd_gc2235raw_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  • /*  else  if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI253_YUV,currSensorName)))
  •         {
  •          PK_DBG("is hi253 down\n");
  •             if(TRUE != kd_hi253yuv_powerdown(mode_name))
  •                  goto _kdCISModulePowerOn_exit_;
  •         }*/   
  •         else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_A5142_MIPI_RAW, currSensorName))) {  
  •             if (0 == pinSetIdx) {  
  •                 PK_DBG("is A5142 main down \n");  
  •                 if (TRUE != kd_a5142mipiraw_main_powerdown(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •             } else {  
  •                 PK_DBG("is A5142 sub down \n");  
  •                 if (TRUE != kd_a5142mipiraw_sub_powerdown(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •             }  
  •         } else if (currSensorName && ((0 == strcmp(SENSOR_DRVNAME_S5K3H7Y_MIPI_RAW,currSensorName))   
  •         || (0 == strcmp(SENSOR_DRVNAME_S5K3H7Y_2LANE_MIPI_RAW,currSensorName))))      
  •         {  
  •                     PK_DBG("is s5k3h7 down\n");  
  •                 if(pinSetIdx==0)  
  •                         {  
  •                  if(TRUE != kd_s5k3h7ymipiraw_powerdown(mode_name))  
  •                   goto _kdCISModulePowerOn_exit_;  
  •                 }  
  •                 else {  
  •                 if(TRUE != kd_s5k3h72ymipiraw_powerdown(mode_name))  
  •                           goto _kdCISModulePowerOn_exit_;  
  •                 }  
  •   
  •         }  
  •           else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2035_YUV,currSensorName)))              
  •         {  
  •          PK_DBG("is gc2035 down\n");  
  •             if(TRUE != kd_gc2035_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_S5K3H72Y_MIPI_RAW,currSensorName)))            
  •         {  
  •          PK_DBG("is s5k3h72y_mipi_raw down\n");  
  •             if(TRUE != kd_s5k3h72ymipiraw_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5648A_MIPI_RAW,currSensorName)))  
  •         {  
  •             if(TRUE != kd_ov5648a_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5648B_MIPI_RAW,currSensorName)))  
  •         {  
  •             if(TRUE != kd_ov5648b_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV5648_LARGEN_MIPI_RAW,currSensorName))) //lili add  
  •         {  
  •             if(TRUE != kd_ov5648_main_powerdown(mode_name))  
  •                  goto _kdCISModulePowerOn_exit_;  
  •         }  
  •       else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC0329_YUV,currSensorName)))              
  •        {  
  •                 PK_DBG("is gc0329 down\n");  
  •                     if(TRUE != kd_gc0329yuv_powerdown(mode_name))  
  •                             goto _kdCISModulePowerOn_exit_;  
  •         }   
  •        else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC0312_YUV,currSensorName)))            
  •        {  
  •                 PK_DBG("is gc0312 down\n");  
  •                     if(TRUE != kd_gc0312_powerdown(mode_name))  
  •                             goto _kdCISModulePowerOn_exit_;  
  •         }   
  •           else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI704_YUV,currSensorName)))           
  •        {  
  •                 PK_DBG("is hi704 down\n");  
  •                     if(TRUE != kd_hi704yuv_powerdown(mode_name))  
  •                             goto _kdCISModulePowerOn_exit_;  
  •         }  
  •           else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC0310_MIPI_YUV,currSensorName)))            
  •        {  
  •                 PK_DBG("is gc0310 down\n");  
  •                     if(TRUE != kd_gc0310_powerdown(mode_name))  
  •                             goto _kdCISModulePowerOn_exit_;  
  •         } else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_GC2145_MIPI_YUV,currSensorName))) {  
  •             PK_DBG("is gc2145 down\n");  
  •   
  •             if (TRUE != kd_gc2145_powerdown(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •         }   
  •         else if(currSensorName && (0 == strcmp(SENSOR_DRVNAME_HI258MIPI_YUV,currSensorName)))  
  •         {  
  •             PK_DBG("is hi258 down\n");  
  •             if(TRUE != kd_hi258mipiraw_powerdown(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •     }  
  •         else if (currSensorName && (0 == strcmp(SENSOR_DRVNAME_OV2680_MIPI_RAW,currSensorName)))  
  •          {  
  •             PK_DBG("is ov2680 down\n");  
  •             if(TRUE != kd_ov2680mipiraw_powerdown(mode_name))  
  •                 goto _kdCISModulePowerOn_exit_;  
  •     }   
  •     else   
  •     {  
  •         PK_DBG("kdCISModulePowerDown get in---  other , please add the power down code!!!!!!\n");  
  •         goto _kdCISModulePowerOn_exit_;  
  •         }  
  •   
  •   }  
  •     return 0;  
  •   
  • _kdCISModulePowerOn_exit_:  
  •     return -EIO;  
  • }  
  • EXPORT_SYMBOL(kdCISModulePowerOn);    M! V# F# c, q( T: Y# F5 D

9 }/ m6 }% D' m" [( Z2 j2 k. b. D; R' E$ k
9 ]% @, Z7 C6 g, M0 K( Q* K  _0 l

以ov5670为例,其上电code如下:

; p$ v7 W) j8 \3 F$ e
  • static int kd_ov5670_poweron( char *mode_name)  
  • {  
  •     int ret;  
  •         printk("kd_ov5670_poweron1 start..\n");  
  •   
  •         ret = kd_poweron_main_devices(VOL_1800, VOL_2800, VOL_1200, VOL_2800, mode_name,0);//给camera上三路电  
  •      PK_DBG("kd_ov88251mipiraw_poweron start..\n");  
  •         mdelay(10);// wait power to be stable   
  •         //disable_inactive_sensor();//disable inactive sensor  
  •         if(mt_set_gpio_out(pinSet[0][IDX_PS_CMPDN],pinSet[0][IDX_PS_CMPDN+IDX_PS_OFF])){PK_DBG("[CAMERA LENS] set gpio failed!! \n");}  
  •         mdelay(10);  
  •         if(mt_set_gpio_out(pinSet[0][IDX_PS_CMPDN],pinSet[0][IDX_PS_CMPDN+IDX_PS_ON])){PK_DBG("[CAMERA LENS] set gpio failed!! \n");}  
  •         mdelay(1);  
  •       
  •     if(mt_set_gpio_out(pinSet[0][IDX_PS_CMRST],pinSet[0][IDX_PS_CMRST+IDX_PS_ON])){PK_DBG("[CAMERA SENSOR] set gpio failed!! \n");}  
  •     if(mt_set_gpio_out(pinSet[0][IDX_PS_CMRST],pinSet[0][IDX_PS_CMRST+IDX_PS_OFF])){PK_DBG("[CAMERA SENSOR] set gpio failed!! \n");}  
  •     mdelay(10);  
  •     if(mt_set_gpio_out(pinSet[0][IDX_PS_CMRST],pinSet[0][IDX_PS_CMRST+IDX_PS_ON])){PK_DBG("[CAMERA SENSOR] set gpio failed!! \n");}  
  •     mdelay(5);  
  • poweronerr:  
  •     return ret;  
  • }  6 i( x3 a2 I" g9 l

$ a% x) Z/ i- ~  @7 M& I) T$ t+ n. G- ~8 m" Z' S1 \
(3.2)获取sensor ID,err = g_pSensorFunc->SensorFeatureControl(g_invokeSocketIdx, SENSOR_FEATURE_CHECK_SENSOR_ID, (MUINT8*)&sensorID, &retLen);
) W. u" }4 N# D1 o5 D

    此函数调用具体sensor的func,例如ov5670,则调用的

2 u3 p# U4 k7 N4 U  m3 m2 S
  • OV5670FeatureControl  
    % l: M  e9 ?1 l: \

; s8 D+ B6 o/ f* M- V1 ^8 Q' \" r===>mediatek/custom/common/kernel/imgsensor/ov5670_mipi_raw, x; q$ {3 j, ^+ h7 t  B
4 i) i$ D- I+ R
5 x; L' l) j. K3 x$ X: h$ }
  • UINT32 OV5670FeatureControl(MSDK_SENSOR_FEATURE_ENUM FeatureId,  
  •                                                                 UINT8 *pFeaturePara,UINT32 *pFeatureParaLen)  
  • {  
  •     UINT16 *pFeatureReturnPara16=(UINT16 *) pFeaturePara;  
  •     UINT16 *pFeatureData16=(UINT16 *) pFeaturePara;  
  •     UINT32 *pFeatureReturnPara32=(UINT32 *) pFeaturePara;  
  •     UINT32 *pFeatureData32=(UINT32 *) pFeaturePara;  
  •     UINT32 SensorRegNumber;  
  •     UINT32 i;  
  •     PNVRAM_SENSOR_DATA_STRUCT pSensorDefaultData=(PNVRAM_SENSOR_DATA_STRUCT) pFeaturePara;  
  •     MSDK_SENSOR_CONFIG_STRUCT *pSensorConfigData=(MSDK_SENSOR_CONFIG_STRUCT *) pFeaturePara;  
  •     MSDK_SENSOR_REG_INFO_STRUCT *pSensorRegData=(MSDK_SENSOR_REG_INFO_STRUCT *) pFeaturePara;  
  •     MSDK_SENSOR_GROUP_INFO_STRUCT *pSensorGroupInfo=(MSDK_SENSOR_GROUP_INFO_STRUCT *) pFeaturePara;  
  •     MSDK_SENSOR_ITEM_INFO_STRUCT *pSensorItemInfo=(MSDK_SENSOR_ITEM_INFO_STRUCT *) pFeaturePara;  
  •     MSDK_SENSOR_ENG_INFO_STRUCT *pSensorEngInfo=(MSDK_SENSOR_ENG_INFO_STRUCT *) pFeaturePara;  
  •   
  •     switch (FeatureId)  
  •     {  
  •         case SENSOR_FEATURE_GET_RESOLUTION:  
  •             *pFeatureReturnPara16++= OV5670_IMAGE_SENSOR_FULL_WIDTH;  
  •             *pFeatureReturnPara16= OV5670_IMAGE_SENSOR_FULL_HEIGHT;  
  •             *pFeatureParaLen=4;  
  •             break;  
  •         case SENSOR_FEATURE_GET_PERIOD:  
  •                                 *pFeatureReturnPara16++= OV5670_FeatureControl_PERIOD_PixelNum;  
  •                                 *pFeatureReturnPara16= OV5670_FeatureControl_PERIOD_LineNum;  
  •                                 *pFeatureParaLen=4;  
  •                                 break;  
  •         case SENSOR_FEATURE_GET_PIXEL_CLOCK_FREQ:  
  •                         switch(OV5670CurrentScenarioId)  
  •                         {  
  •                                 case MSDK_SCENARIO_ID_CAMERA_PREVIEW:  
  •                                         *pFeatureReturnPara32 = OV5670_PREVIEW_PCLK;  
  •                                         *pFeatureParaLen=4;  
  •                                         break;  
  •                                 case MSDK_SCENARIO_ID_VIDEO_PREVIEW:  
  •                                         *pFeatureReturnPara32 = OV5670_VIDEO_PCLK;  
  •                                         *pFeatureParaLen=4;  
  •                                         break;  
  •                                 case MSDK_SCENARIO_ID_CAMERA_CAPTURE_JPEG:  
  •                                 case MSDK_SCENARIO_ID_CAMERA_ZSD:  
  •                                         *pFeatureReturnPara32 = OV5670_CAPTURE_PCLK;  
  •                                         *pFeatureParaLen=4;  
  •                                         break;  
  •                                 default:  
  •                                         *pFeatureReturnPara32 = OV5670_PREVIEW_PCLK;  
  •                                         *pFeatureParaLen=4;  
  •                                         break;  
  •                         }  
  •                     break;  
  •   
  •         case SENSOR_FEATURE_SET_ESHUTTER:  
  •             OV5670_SetShutter(*pFeatureData16);  
  •             break;  
  •         case SENSOR_FEATURE_SET_NIGHTMODE:  
  •             OV5670_NightMode((BOOL) *pFeatureData16);  
  •             break;  
  •         case SENSOR_FEATURE_SET_GAIN:  
  •            OV5670_SetGain((UINT16) *pFeatureData16);  
  •             break;  
  •         case SENSOR_FEATURE_SET_FLASHLIGHT:  
  •             break;  
  •         case SENSOR_FEATURE_SET_ISP_MASTER_CLOCK_FREQ:  
  •             //OV5670_isp_master_clock=*pFeatureData32;  
  •             break;  
  •         case SENSOR_FEATURE_SET_REGISTER:  
  •             OV5670_write_cmos_sensor(pSensorRegData->RegAddr, pSensorRegData->RegData);  
  •             break;  
  •         case SENSOR_FEATURE_GET_REGISTER:  
  •             pSensorRegData->RegData = OV5670_read_cmos_sensor(pSensorRegData->RegAddr);  
  •             break;  
  •         case SENSOR_FEATURE_SET_CCT_REGISTER:  
  •             SensorRegNumber=FACTORY_END_ADDR;  
  •             for (i=0;i<SensorRegNumber;i++)  
  •             {  
  •                 spin_lock(&ov5670mipiraw_drv_lock);  
  •                 OV5670SensorCCT.Addr=*pFeatureData32++;  
  •                 OV5670SensorCCT.Para=*pFeatureData32++;  
  •                                 spin_unlock(&ov5670mipiraw_drv_lock);  
  •             }  
  •             break;  
  •         case SENSOR_FEATURE_GET_CCT_REGISTER:  
  •             SensorRegNumber=FACTORY_END_ADDR;  
  •             if (*pFeatureParaLen<(SensorRegNumber*sizeof(SENSOR_REG_STRUCT)+4))  
  •                 return FALSE;  
  •             *pFeatureData32++=SensorRegNumber;  
  •             for (i=0;i<SensorRegNumber;i++)  
  •             {  
  •                 *pFeatureData32++=OV5670SensorCCT.Addr;  
  •                 *pFeatureData32++=OV5670SensorCCT.Para;  
  •             }  
  •             break;  
  •         case SENSOR_FEATURE_SET_ENG_REGISTER:  
  •             SensorRegNumber=ENGINEER_END;  
  •             for (i=0;i<SensorRegNumber;i++)  
  •             {  
  •                 spin_lock(&ov5670mipiraw_drv_lock);  
  •                 OV5670SensorReg.Addr=*pFeatureData32++;  
  •                 OV5670SensorReg.Para=*pFeatureData32++;  
  •                                 spin_unlock(&ov5670mipiraw_drv_lock);  
  •             }  
  •             break;  
  •         case SENSOR_FEATURE_GET_ENG_REGISTER:  
  •             SensorRegNumber=ENGINEER_END;  
  •             if (*pFeatureParaLen<(SensorRegNumber*sizeof(SENSOR_REG_STRUCT)+4))  
  •                 return FALSE;  
  •             *pFeatureData32++=SensorRegNumber;  
  •             for (i=0;i<SensorRegNumber;i++)  
  •             {  
  •                 *pFeatureData32++=OV5670SensorReg.Addr;  
  •                 *pFeatureData32++=OV5670SensorReg.Para;  
  •             }  
  •             break;  
  •         case SENSOR_FEATURE_GET_REGISTER_DEFAULT:  
  •             if (*pFeatureParaLen>=sizeof(NVRAM_SENSOR_DATA_STRUCT))  
  •             {  
  •                 pSensorDefaultData->Version=NVRAM_CAMERA_SENSOR_FILE_VERSION;  
  •                 pSensorDefaultData->SensorId=OV5670_SENSOR_ID;  
  •                 memcpy(pSensorDefaultData->SensorEngReg, OV5670SensorReg, sizeof(SENSOR_REG_STRUCT)*ENGINEER_END);  
  •                 memcpy(pSensorDefaultData->SensorCCTReg, OV5670SensorCCT, sizeof(SENSOR_REG_STRUCT)*FACTORY_END_ADDR);  
  •             }  
  •             else  
  •                 return FALSE;  
  •             *pFeatureParaLen=sizeof(NVRAM_SENSOR_DATA_STRUCT);  
  •             break;  
  •         case SENSOR_FEATURE_GET_CONFIG_PARA:  
  •             memcpy(pSensorConfigData, &OV5670SensorConfigData, sizeof(MSDK_SENSOR_CONFIG_STRUCT));  
  •             *pFeatureParaLen=sizeof(MSDK_SENSOR_CONFIG_STRUCT);  
  •             break;  
  •         case SENSOR_FEATURE_CAMERA_PARA_TO_SENSOR:  
  •             OV5670_camera_para_to_sensor();  
  •             break;  
  •   
  •         case SENSOR_FEATURE_SENSOR_TO_CAMERA_PARA:  
  •             OV5670_sensor_to_camera_para();  
  •             break;  
  •         case SENSOR_FEATURE_GET_GROUP_COUNT:  
  •             *pFeatureReturnPara32++=OV5670_get_sensor_group_count();  
  •             *pFeatureParaLen=4;  
  •             break;  
  •         case SENSOR_FEATURE_GET_GROUP_INFO:  
  •             OV5670_get_sensor_group_info(pSensorGroupInfo->GroupIdx, pSensorGroupInfo->GroupNamePtr, &pSensorGroupInfo->ItemCount);  
  •             *pFeatureParaLen=sizeof(MSDK_SENSOR_GROUP_INFO_STRUCT);  
  •             break;  
  •         case SENSOR_FEATURE_GET_ITEM_INFO:  
  •             OV5670_get_sensor_item_info(pSensorItemInfo->GroupIdx,pSensorItemInfo->ItemIdx, pSensorItemInfo);  
  •             *pFeatureParaLen=sizeof(MSDK_SENSOR_ITEM_INFO_STRUCT);  
  •             break;  
  •   
  •         case SENSOR_FEATURE_SET_ITEM_INFO:  
  •             OV5670_set_sensor_item_info(pSensorItemInfo->GroupIdx, pSensorItemInfo->ItemIdx, pSensorItemInfo->ItemValue);  
  •             *pFeatureParaLen=sizeof(MSDK_SENSOR_ITEM_INFO_STRUCT);  
  •             break;  
  •   
  •         case SENSOR_FEATURE_GET_ENG_INFO:  
  •             pSensorEngInfo->SensorId = 129;  
  •             pSensorEngInfo->SensorType = CMOS_SENSOR;  
  •             pSensorEngInfo->SensorOutputDataFormat=SENSOR_OUTPUT_FORMAT_RAW_Gb;  
  •             *pFeatureParaLen=sizeof(MSDK_SENSOR_ENG_INFO_STRUCT);  
  •             break;  
  •         case SENSOR_FEATURE_GET_LENS_DRIVER_ID:  
  •             // get the lens driver ID from EEPROM or just return LENS_DRIVER_ID_DO_NOT_CARE  
  •             // if EEPROM does not exist in camera module.  
  •             *pFeatureReturnPara32=LENS_DRIVER_ID_DO_NOT_CARE;  
  •             *pFeatureParaLen=4;  
  •             break;  
  •   
  •         case SENSOR_FEATURE_INITIALIZE_AF:  
  •             break;  
  •         case SENSOR_FEATURE_CONSTANT_AF:  
  •             break;  
  •         case SENSOR_FEATURE_MOVE_FOCUS_LENS:  
  •             break;  
  •         case SENSOR_FEATURE_SET_VIDEO_MODE:  
  •             OV5670SetVideoMode(*pFeatureData16);  
  •             break;  
  •         case SENSOR_FEATURE_CHECK_SENSOR_ID://-------------调用此处读取ID  
  •             OV5670GetSensorID(pFeatureReturnPara32);  
  •             break;  
  •         case SENSOR_FEATURE_SET_AUTO_FLICKER_MODE:  
  •             OV5670SetAutoFlickerMode((BOOL)*pFeatureData16, *(pFeatureData16+1));  
  •                 break;  
  •                 case SENSOR_FEATURE_SET_MAX_FRAME_RATE_BY_SCENARIO:  
  •                         OV5670MIPISetMaxFramerateByScenario((MSDK_SCENARIO_ID_ENUM)*pFeatureData32, *(pFeatureData32+1));  
  •                         break;  
  •                 case SENSOR_FEATURE_GET_DEFAULT_FRAME_RATE_BY_SCENARIO:  
  •                         OV5670MIPIGetDefaultFramerateByScenario((MSDK_SCENARIO_ID_ENUM)*pFeatureData32, (MUINT32 *)(*(pFeatureData32+1)));  
  •                         break;  
  •                 case SENSOR_FEATURE_SET_TEST_PATTERN:  
  •                         OV5670SetTestPatternMode((BOOL)*pFeatureData16);  
  •                         break;  
  •                 case SENSOR_FEATURE_GET_TEST_PATTERN_CHECKSUM_VALUE://for factory mode auto testing  
  •                         *pFeatureReturnPara32=OV5670_TEST_PATTERN_CHECKSUM;  
  •                         *pFeatureParaLen=4;  
  •                      break;  
  •         default:  
  •             break;  
  •     }  
  •     return ERROR_NONE;  
  • }  4 A; |! R$ C5 B/ c0 d. n$ `; M+ s; r
9 i+ W. f: [# p9 B

0 \/ n7 K6 i; ?& {# n0 k5 C5 W' E$ S! d5 R
  • UINT32 OV5670GetSensorID(UINT32 *sensorID)  
  • {  
  •     int  retry = 2;  
  •   
  •         OV5670DB("OV5670GetSensorID enter :\n ");  
  •     mdelay(5);  
  •   
  •     do {  
  •         *sensorID = (OV5670_read_cmos_sensor(0x300B)<<8)|OV5670_read_cmos_sensor(0x300C);  
  •         if (*sensorID == OV5670_SENSOR_ID)  
  •                 {  
  •                         OV5670DB("Sensor ID = 0x%04x\n", *sensorID);  
  •                 break;  
  •                 }  
  •         OV5670DB("Read Sensor ID Fail = 0x%04x\n", *sensorID);  
  •         retry--;  
  •     } while (retry > 0);  
  •   
  •     if (*sensorID != OV5670_SENSOR_ID) {  
  •                 OV5670DB("Read Sensor ID Fail = 0x%04x\n", *sensorID);  
  •   
  •                 /*
  •         *sensorID = OV5670_SENSOR_ID;
  •         return ERROR_SENSOR_CONNECT_FAIL;
  •         */  
  •          *sensorID = 0xFFFFFFFF;  
  •      return ERROR_SENSOR_CONNECT_FAIL;  
  •     }  
  •     return ERROR_NONE;  
  • }  
    1 U6 ^0 \; }; b2 O; t. u' i2 [9 f

! T0 h" k: K& w7 l

# x$ t, t+ ?2 r2 H$ ~8 }

以上是ov5670获取ID的函数。
  I$ [  _4 n! z% W


/ c. b9 Z$ J6 R, O0 N3 U  p( k" G! I' B8 u3 X) J( m

2 m# Z2 O) c6 h* D* F三、开机打开sensor总结           
) T* e" h+ P$ g6 L. p
  • HAL层运行Search sensor这个线程
  • HAL层遍历sensorlist列表并挂载HAL层性能3A等一些参数获取的接口
  • HAL层下达setDriver的cmd,并下传正在遍历的sensorlist列表中的ID
  • Driver层根据这个ID,挂载Driver层sensorlist中对应的Sensorlist中对应的Sensor和具体Sensor底层操作接口
  • HAL层对正确遍历的sensor下达check ID的指令
  • Driver层为对应sensor上电,通过I2C读取预存在寄存器中的sensor id
  • 比较读取结果,不匹配,return error,继续遍历
  • 匹配,HAL层下达其他指令收集sensor信息
  • sensor下电
    9 R9 j. m( M- v. b8 r6 K) x$ \

    : v" k4 z1 I0 B9 }* n! X
1 k8 k1 j' H9 X/ T( e' [( M) q. s

% Y: J, h9 b: W) \' r! i1 r* \2 g+ l9 c* I
发表于 2015-8-22 08:12:22 | 显示全部楼层
好东西 给力很多 启发性的好东西!!!
高级模式
B Color Image Link Quote Code Smilies @朋友 |上传

本版积分规则

在线客服

客服电话

欢迎来电咨询

188-9985 8350

微信关注

手机APP程序:
扫码下载访问

微信公众平台:
摄像头之家公众号

微信小程序:
摄像头小程序

返回顶部

QQ|站点统计|小黑屋|手机版|Archiver|摄像头模组论坛网 ( 粤ICP备18155214号 )

Powered by Discuz! X3.4 Licensed© 2001-2013 Comsenz Inc.