/* * RkAiqAcpHandle.h * * Copyright (c) 2019-2021 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 "RkAiqCore.h" #include "RkAiqHandle.h" namespace RkCam { void RkAiqAcpHandle::init() { ENTER_ANALYZER_FUNCTION(); deInit(); mConfig = (RkAiqAlgoCom*)(new RkAiqAlgoConfigAcp()); mPreInParam = (RkAiqAlgoCom*)(new RkAiqAlgoPreAcp()); mPreOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoPreResAcp()); mProcInParam = (RkAiqAlgoCom*)(new RkAiqAlgoProcAcp()); mProcOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoProcResAcp()); mPostInParam = (RkAiqAlgoCom*)(new RkAiqAlgoPostAcp()); mPostOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoPostResAcp()); EXIT_ANALYZER_FUNCTION(); } XCamReturn RkAiqAcpHandle::prepare() { ENTER_ANALYZER_FUNCTION(); XCamReturn ret = XCAM_RETURN_NO_ERROR; RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; ret = RkAiqHandle::prepare(); RKAIQCORE_CHECK_RET(ret, "acp handle prepare failed"); // TODO config acp common params RkAiqAlgoConfigAcp* acp_config = (RkAiqAlgoConfigAcp*)mConfig; // id != 0 means the thirdparty's algo if (mDes->id != 0) { ret = des->prepare(mConfig); RKAIQCORE_CHECK_RET(ret, "acp algo prepare failed"); } EXIT_ANALYZER_FUNCTION(); return ret; } XCamReturn RkAiqAcpHandle::preProcess() { ENTER_ANALYZER_FUNCTION(); XCamReturn ret = XCAM_RETURN_NO_ERROR; RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; RkAiqAlgoPreAcp* acp_pre = (RkAiqAlgoPreAcp*)mPreInParam; ret = RkAiqHandle::preProcess(); RKAIQCORE_CHECK_RET(ret, "acp handle preProcess failed"); // TODO config common acp preprocess params // id != 0 means the thirdparty's algo if (mDes->id != 0) { ret = des->pre_process(mPreInParam, mPreOutParam); RKAIQCORE_CHECK_RET(ret, "acp handle pre_process failed"); } EXIT_ANALYZER_FUNCTION(); return ret; } XCamReturn RkAiqAcpHandle::processing() { XCamReturn ret = XCAM_RETURN_NO_ERROR; RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; RkAiqAlgoProcAcp* acp_pre = (RkAiqAlgoProcAcp*)mProcInParam; ret = RkAiqHandle::processing(); RKAIQCORE_CHECK_RET(ret, "acp handle processing failed"); // TODO config common acp processing params // id != 0 means the thirdparty's algo if (mDes->id != 0) { ret = des->processing(mProcInParam, mProcOutParam); RKAIQCORE_CHECK_RET(ret, "acp algo processing failed"); } EXIT_ANALYZER_FUNCTION(); return ret; } XCamReturn RkAiqAcpHandle::postProcess() { ENTER_ANALYZER_FUNCTION(); XCamReturn ret = XCAM_RETURN_NO_ERROR; RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; RkAiqAlgoPostAcp* acp_pre = (RkAiqAlgoPostAcp*)mPostInParam; ret = RkAiqHandle::postProcess(); RKAIQCORE_CHECK_RET(ret, "acp handle postProcess failed"); // TODO config common acp postProcess params // id != 0 means the thirdparty's algo if (mDes->id != 0) { ret = des->post_process(mPostInParam, mPostOutParam); RKAIQCORE_CHECK_RET(ret, "acp algo postProcess failed"); } EXIT_ANALYZER_FUNCTION(); return ret; } }; // namespace RkCam