/* * RkAiqHandle.h * * Copyright (c) 2019 Rockchip Corporation * * 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 "RkAiqHandle.h" #include "RkAiqCore.h" namespace RkCam { void RkAiqAeHandle::init() { ENTER_ANALYZER_FUNCTION(); deInit(); mConfig = (RkAiqAlgoCom*)(new RkAiqAlgoConfigAe()); mPreInParam = (RkAiqAlgoCom*)(new RkAiqAlgoPreAe()); mPreOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoPreResAe()); mProcInParam = (RkAiqAlgoCom*)(new RkAiqAlgoProcAe()); mProcOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoProcResAe()); mPostInParam = (RkAiqAlgoCom*)(new RkAiqAlgoPostAe()); mPostOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoPostResAe()); EXIT_ANALYZER_FUNCTION(); } XCamReturn RkAiqAeHandle::prepare() { ENTER_ANALYZER_FUNCTION(); XCamReturn ret = XCAM_RETURN_NO_ERROR; RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; ret = RkAiqHandle::prepare(); RKAIQCORE_CHECK_RET(ret, "ae handle prepare failed"); // TODO config ae common params: RkAiqAlgoConfigAe* ae_config = (RkAiqAlgoConfigAe*)mConfig; RkAiqCore::RkAiqAlgosComShared_t* sharedCom = &mAiqCore->mAlogsComSharedParams; /*****************AecConfig Sensor Exp related info*****************/ ae_config->LinePeriodsPerField = (float)sharedCom->snsDes.frame_length_lines; ae_config->PixelPeriodsPerLine = (float)sharedCom->snsDes.line_length_pck; ae_config->PixelClockFreqMHZ = (float)sharedCom->snsDes.pixel_clock_freq_mhz; // id != 0 means the thirdparty's algo if (mDes->id != 0) { ret = des->prepare(mConfig); RKAIQCORE_CHECK_RET(ret, "ae algo prepare failed"); } EXIT_ANALYZER_FUNCTION(); return ret; } XCamReturn RkAiqAeHandle::preProcess() { ENTER_ANALYZER_FUNCTION(); XCamReturn ret = XCAM_RETURN_NO_ERROR; RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; RkAiqAlgoPreAe* ae_pre = (RkAiqAlgoPreAe*)mPreInParam; RkAiqCore::RkAiqAlgosComShared_t* sharedCom = &mAiqCore->mAlogsComSharedParams; int groupId = mAiqCore->mAlgoTypeToGrpMaskMap[RK_AIQ_ALGO_TYPE_AE]; RkAiqCore::RkAiqAlgosGroupShared_t* shared = mAiqCore->mAlogsGroupSharedParamsMap[groupId]; RkAiqIspStats* ispStats = shared->ispStats; ret = RkAiqHandle::preProcess(); RKAIQCORE_CHECK_RET(ret, "ae handle preProcess failed"); RkAiqAecStats* xAecStats = nullptr; if (shared->aecStatsBuf) { xAecStats = (RkAiqAecStats*)shared->aecStatsBuf->map(shared->aecStatsBuf); if (!xAecStats) LOGE_AEC("aec stats is null"); } else { LOGE_AEC("the xcamvideobuffer of aec stats is null"); } if ((!xAecStats || !xAecStats->aec_stats_valid) && !sharedCom->init) { LOGE("no aec stats, ignore!"); return XCAM_RETURN_BYPASS; } // TODO config common ae preprocess params // id != 0 means the thirdparty's algo if (mDes->id != 0) { ret = des->pre_process(mPreInParam, mPreOutParam); RKAIQCORE_CHECK_RET(ret, "ae handle pre_process failed"); } EXIT_ANALYZER_FUNCTION(); return ret; } XCamReturn RkAiqAeHandle::processing() { XCamReturn ret = XCAM_RETURN_NO_ERROR; RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; RkAiqAlgoProcAe* ae_proc = (RkAiqAlgoProcAe*)mProcInParam; RkAiqCore::RkAiqAlgosComShared_t* sharedCom = &mAiqCore->mAlogsComSharedParams; RkAiqCore::RkAiqAlgosGroupShared_t* shared = nullptr; int groupId = mAiqCore->getGroupId(RK_AIQ_ALGO_TYPE_AE); if (groupId >= 0) { if (mAiqCore->getGroupSharedParams(groupId, shared) != XCAM_RETURN_NO_ERROR) return XCAM_RETURN_BYPASS; } else return XCAM_RETURN_BYPASS; RkAiqIspStats* ispStats = shared->ispStats; ret = RkAiqHandle::processing(); RKAIQCORE_CHECK_RET(ret, "ae handle processing failed"); RkAiqAecStats* xAecStats = nullptr; if (shared->aecStatsBuf) { xAecStats = (RkAiqAecStats*)shared->aecStatsBuf->map(shared->aecStatsBuf); if (!xAecStats) LOGE_AEC("aec stats is null"); } else { LOGE_AEC("the xcamvideobuffer of aec stats is null"); } if ((!xAecStats || !xAecStats->aec_stats_valid) && !sharedCom->init) { LOGE("no aec stats, ignore!"); return XCAM_RETURN_BYPASS; } // TODO config common ae processing params ae_proc->aecStatsBuf = shared->aecStatsBuf; // id != 0 means the thirdparty's algo if (mDes->id != 0) { ret = des->processing(mProcInParam, mProcOutParam); RKAIQCORE_CHECK_RET(ret, "ae algo processing failed"); } EXIT_ANALYZER_FUNCTION(); return ret; } XCamReturn RkAiqAeHandle::postProcess() { ENTER_ANALYZER_FUNCTION(); XCamReturn ret = XCAM_RETURN_NO_ERROR; RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; RkAiqAlgoPostAe* ae_post = (RkAiqAlgoPostAe*)mPostInParam; RkAiqCore::RkAiqAlgosComShared_t* sharedCom = &mAiqCore->mAlogsComSharedParams; RkAiqCore::RkAiqAlgosGroupShared_t* shared = nullptr; int groupId = mAiqCore->getGroupId(RK_AIQ_ALGO_TYPE_AE); if (groupId >= 0) { if (mAiqCore->getGroupSharedParams(groupId, shared) != XCAM_RETURN_NO_ERROR) return XCAM_RETURN_BYPASS; } else return XCAM_RETURN_BYPASS; RkAiqIspStats* ispStats = shared->ispStats; ret = RkAiqHandle::postProcess(); RKAIQCORE_CHECK_RET(ret, "ae handle postProcess failed"); if (!shared->aecStatsBuf && !sharedCom->init) { LOGE("no aec stats, ignore!"); return XCAM_RETURN_BYPASS; } // TODO config common ae postProcess params // id != 0 means the thirdparty's algo if (mDes->id != 0) { ret = des->post_process(mPostInParam, mPostOutParam); RKAIQCORE_CHECK_RET(ret, "ae algo postProcess failed"); } EXIT_ANALYZER_FUNCTION(); return ret; } }; // namespace RkCam