/* * Copyright (c) 2019-2022 Rockchip Eletronics Co., Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ #include "uAPI2/rk_aiq_user_api2_af.h" #include "algo_handlers/RkAiqAfHandle.h" #include "base/xcam_common.h" RKAIQ_BEGIN_DECLARE #ifdef RK_SIMULATOR_HW #define CHECK_USER_API_ENABLE #endif XCamReturn rk_aiq_user_api2_af_SetAttrib(const rk_aiq_sys_ctx_t* sys_ctx, rk_aiq_af_attrib_t *attr) { CHECK_USER_API_ENABLE2(sys_ctx); CHECK_USER_API_ENABLE(RK_AIQ_ALGO_TYPE_AF); RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->setAttrib(attr); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_GetAttrib(const rk_aiq_sys_ctx_t* sys_ctx, rk_aiq_af_attrib_t *attr) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->getAttrib(attr); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_Lock(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->lock(); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_Unlock(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->unlock(); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_Oneshot(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->Oneshot(); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_ManualTriger(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->ManualTriger(); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_Tracking(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->Tracking(); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_SetZoomIndex(const rk_aiq_sys_ctx_t* sys_ctx, int index) { RKAIQ_API_SMART_LOCK(sys_ctx); CamCalibDbV2Context_t calibdbv2_ctx = RkAiqCalibDbV2::toDefaultCalibDb(sys_ctx->_calibDbProj); CalibDbV2_Af_ZoomFocusTbl_t *zoomfocus_tbl; int focal_length_len; RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (CHECK_ISP_HW_V30()) { CalibDbV2_AFV30_t *af_v30 = (CalibDbV2_AFV30_t*)(CALIBDBV2_GET_MODULE_PTR((&calibdbv2_ctx), af_v30)); zoomfocus_tbl = (CalibDbV2_Af_ZoomFocusTbl_t*)(&af_v30->TuningPara.zoomfocus_tbl); } else { CalibDbV2_AF_t *af = (CalibDbV2_AF_t*)CALIBDBV2_GET_MODULE_PTR((&calibdbv2_ctx), af); zoomfocus_tbl = (CalibDbV2_Af_ZoomFocusTbl_t*)(&af->TuningPara.zoomfocus_tbl); } focal_length_len = zoomfocus_tbl->focal_length_len; if (index < 0) index = 0; else if (index >= focal_length_len) index = focal_length_len - 1; if (algo_handle) { return algo_handle->setZoomIndex(index); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_EndZoomChg(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->endZoomChg(); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_GetZoomIndex(const rk_aiq_sys_ctx_t* sys_ctx, int *index) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->getZoomIndex(index); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_StartZoomCalib(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->startZoomCalib(); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_resetZoom(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->resetZoom(); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_SetVcmCfg(const rk_aiq_sys_ctx_t* sys_ctx, rk_aiq_lens_vcmcfg* cfg) { RKAIQ_API_SMART_LOCK(sys_ctx); XCamReturn ret = XCAM_RETURN_NO_ERROR; ret = sys_ctx->_camHw->setLensVcmCfg(*cfg); return ret; } XCamReturn rk_aiq_user_api2_af_GetVcmCfg(const rk_aiq_sys_ctx_t* sys_ctx, rk_aiq_lens_vcmcfg* cfg) { RKAIQ_API_SMART_LOCK(sys_ctx); XCamReturn ret = XCAM_RETURN_NO_ERROR; ret = sys_ctx->_camHw->getLensVcmCfg(*cfg); return ret; } XCamReturn rk_aiq_user_api2_af_GetSearchPath(const rk_aiq_sys_ctx_t* sys_ctx, rk_aiq_af_sec_path_t* path) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->GetSearchPath(path); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_GetSearchResult(const rk_aiq_sys_ctx_t* sys_ctx, rk_aiq_af_result_t* result) { RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->GetSearchResult(result); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_GetZoomRange(const rk_aiq_sys_ctx_t* sys_ctx, rk_aiq_af_zoomrange* range) { RKAIQ_API_SMART_LOCK(sys_ctx); XCamReturn ret = XCAM_RETURN_NO_ERROR; CamCalibDbV2Context_t calibdbv2_ctx = RkAiqCalibDbV2::toDefaultCalibDb(sys_ctx->_calibDbProj); CalibDbV2_Af_ZoomFocusTbl_t *zoomfocus_tbl; int focal_length_len; if (CHECK_ISP_HW_V30()) { CalibDbV2_AFV30_t *af_v30 = (CalibDbV2_AFV30_t*)(CALIBDBV2_GET_MODULE_PTR((&calibdbv2_ctx), af_v30)); zoomfocus_tbl = (CalibDbV2_Af_ZoomFocusTbl_t*)(&af_v30->TuningPara.zoomfocus_tbl); } else { CalibDbV2_AF_t *af = (CalibDbV2_AF_t*)CALIBDBV2_GET_MODULE_PTR((&calibdbv2_ctx), af); zoomfocus_tbl = (CalibDbV2_Af_ZoomFocusTbl_t*)(&af->TuningPara.zoomfocus_tbl); } focal_length_len = zoomfocus_tbl->focal_length_len; if (focal_length_len > 1) { range->min_fl = zoomfocus_tbl->focal_length[0]; range->max_fl = zoomfocus_tbl->focal_length[focal_length_len - 1]; range->min_pos = 0; range->max_pos = focal_length_len - 1; } else { ret = XCAM_RETURN_ERROR_FAILED; } return ret; } XCamReturn rk_aiq_user_api2_af_GetFocusRange(const rk_aiq_sys_ctx_t* sys_ctx, rk_aiq_af_focusrange* range) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->GetFocusRange(range); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_FocusCorrection(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); XCamReturn ret = XCAM_RETURN_NO_ERROR; ret = sys_ctx->_camHw->FocusCorrection(); return ret; } XCamReturn rk_aiq_user_api2_af_ZoomCorrection(const rk_aiq_sys_ctx_t* sys_ctx) { RKAIQ_API_SMART_LOCK(sys_ctx); XCamReturn ret = XCAM_RETURN_NO_ERROR; ret = sys_ctx->_camHw->ZoomCorrection(); return ret; } XCamReturn rk_aiq_user_api2_af_setAngleZ(const rk_aiq_sys_ctx_t* sys_ctx, float angleZ) { RKAIQ_API_SMART_LOCK(sys_ctx); XCamReturn ret = XCAM_RETURN_NO_ERROR; ret = sys_ctx->_camHw->setAngleZ(angleZ); return ret; } XCamReturn rk_aiq_user_api2_af_getCustomAfRes(const rk_aiq_sys_ctx_t* sys_ctx, rk_tool_customAf_res_t *attr) { RKAIQ_API_SMART_LOCK(sys_ctx); RkAiqAfHandleInt* algo_handle = algoHandle(sys_ctx, RK_AIQ_ALGO_TYPE_AF); if (algo_handle) { return algo_handle->GetCustomAfRes(attr); } return XCAM_RETURN_NO_ERROR; } XCamReturn rk_aiq_user_api2_af_setCustomAfRes(const rk_aiq_sys_ctx_t* sys_ctx, rk_tool_customAf_res_t *attr) { rk_aiq_af_attrib_t af_attr; if (CHECK_ISP_HW_V30()) { rk_aiq_user_api2_af_GetAttrib(sys_ctx, &af_attr); memset(&af_attr.manual_meascfg_v30, 0, sizeof(af_attr.manual_meascfg_v30)); af_attr.manual_meascfg_v30.af_en = attr->af_en; af_attr.manual_meascfg_v30.rawaf_sel = attr->rawaf_sel; af_attr.manual_meascfg_v30.accu_8bit_mode = attr->accu_8bit_mode; af_attr.manual_meascfg_v30.ae_mode = attr->ae_mode; af_attr.manual_meascfg_v30.window_num = attr->window_num; af_attr.manual_meascfg_v30.wina_h_offs = attr->wina_h_offs; af_attr.manual_meascfg_v30.wina_v_offs = attr->wina_v_offs; af_attr.manual_meascfg_v30.wina_h_size = attr->wina_h_size; af_attr.manual_meascfg_v30.wina_v_size = attr->wina_v_size; af_attr.manual_meascfg_v30.winb_h_offs = attr->winb_h_offs; af_attr.manual_meascfg_v30.winb_v_offs = attr->winb_v_offs; af_attr.manual_meascfg_v30.winb_h_size = attr->winb_h_size; af_attr.manual_meascfg_v30.winb_v_size = attr->winb_v_size; af_attr.manual_meascfg_v30.gamma_en = attr->gamma_en; memcpy(af_attr.manual_meascfg_v30.gamma_y, attr->gamma_y, RKAIQ_RAWAF_GAMMA_NUM * sizeof(uint16_t)); // param for winb af_attr.manual_meascfg_v30.thres = attr->af_en; af_attr.manual_meascfg_v30.shift_sum_a = attr->af_en; af_attr.manual_meascfg_v30.shift_y_a = attr->af_en; af_attr.manual_meascfg_v30.shift_sum_b = attr->af_en; af_attr.manual_meascfg_v30.shift_y_b = attr->af_en; af_attr.manual_meascfg_v30.gaus_en = attr->gaus_en; af_attr.manual_meascfg_v30.v1_fir_sel = attr->v1_fir_sel; af_attr.manual_meascfg_v30.viir_en = attr->viir_en; af_attr.manual_meascfg_v30.v1_fv_outmode = attr->v1_fv_outmode; af_attr.manual_meascfg_v30.v2_fv_outmode = attr->v2_fv_outmode; af_attr.manual_meascfg_v30.v1_fv_shift = attr->v1_fv_shift; af_attr.manual_meascfg_v30.v2_fv_shift = attr->v2_fv_shift; af_attr.manual_meascfg_v30.v_fv_thresh = attr->v_fv_thresh; for (int i = 0; i < 9; i++) { af_attr.manual_meascfg_v30.v1_iir_coe[i] = attr->v1_iir_coe[i]; } for (int i = 0; i < 3; i++) { af_attr.manual_meascfg_v30.v1_fir_coe[i] = attr->v1_fir_coe[i]; af_attr.manual_meascfg_v30.v2_iir_coe[i] = attr->v2_iir_coe[i]; af_attr.manual_meascfg_v30.v2_fir_coe[i] = attr->v2_fir_coe[i]; } af_attr.manual_meascfg_v30.hiir_en = attr->hiir_en; af_attr.manual_meascfg_v30.h1_fv_outmode = attr->h1_fv_outmode; af_attr.manual_meascfg_v30.h2_fv_outmode = attr->h2_fv_outmode; af_attr.manual_meascfg_v30.h1_fv_shift = attr->h1_fv_shift; af_attr.manual_meascfg_v30.h2_fv_shift = attr->h2_fv_shift; af_attr.manual_meascfg_v30.h_fv_thresh = attr->h_fv_thresh; for (int i = 0; i < 6; i++) { af_attr.manual_meascfg_v30.h1_iir1_coe[i] = attr->h1_iir1_coe[i]; af_attr.manual_meascfg_v30.h1_iir2_coe[i] = attr->h1_iir2_coe[i]; af_attr.manual_meascfg_v30.h2_iir1_coe[i] = attr->h2_iir1_coe[i]; af_attr.manual_meascfg_v30.h2_iir2_coe[i] = attr->h2_iir2_coe[i]; } // level depended gain af_attr.manual_meascfg_v30.ldg_en = attr->af_en; af_attr.manual_meascfg_v30.h_ldg_lumth[0] = attr->h_ldg_lumth[0]; af_attr.manual_meascfg_v30.h_ldg_gain[0] = attr->h_ldg_gain[0]; af_attr.manual_meascfg_v30.h_ldg_gslp[0] = attr->h_ldg_gslp[0]; af_attr.manual_meascfg_v30.h_ldg_lumth[1] = attr->h_ldg_lumth[1]; af_attr.manual_meascfg_v30.h_ldg_gain[1] = attr->h_ldg_gain[1]; af_attr.manual_meascfg_v30.h_ldg_gslp[1] = attr->h_ldg_gslp[1]; af_attr.manual_meascfg_v30.v_ldg_lumth[0] = attr->v_ldg_lumth[0]; af_attr.manual_meascfg_v30.v_ldg_gain[0] = attr->v_ldg_gain[0]; af_attr.manual_meascfg_v30.v_ldg_gslp[0] = attr->v_ldg_gslp[0]; af_attr.manual_meascfg_v30.v_ldg_lumth[1] = attr->v_ldg_lumth[1]; af_attr.manual_meascfg_v30.v_ldg_gain[1] = attr->v_ldg_gain[1]; af_attr.manual_meascfg_v30.v_ldg_gslp[1] = attr->v_ldg_gslp[1]; // High light af_attr.manual_meascfg_v30.highlit_thresh = attr->highlit_thresh; af_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; rk_aiq_user_api2_af_SetAttrib(sys_ctx, &af_attr); return XCAM_RETURN_NO_ERROR; } else { return XCAM_RETURN_ERROR_FAILED; } } RKAIQ_END_DECLARE