/*
|
* 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
|