/* 
 | 
 * 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 "RkAiqCore.h" 
 | 
#include "RkAiqHandle.h" 
 | 
  
 | 
namespace RkCam { 
 | 
  
 | 
void RkAiqAfHandle::init() { 
 | 
    ENTER_ANALYZER_FUNCTION(); 
 | 
  
 | 
    deInit(); 
 | 
    mConfig       = (RkAiqAlgoCom*)(new RkAiqAlgoConfigAf()); 
 | 
    mPreInParam   = (RkAiqAlgoCom*)(new RkAiqAlgoPreAf()); 
 | 
    mPreOutParam  = (RkAiqAlgoResCom*)(new RkAiqAlgoPreResAf()); 
 | 
    mProcInParam  = (RkAiqAlgoCom*)(new RkAiqAlgoProcAf()); 
 | 
    mProcOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoProcResAf()); 
 | 
    mPostInParam  = (RkAiqAlgoCom*)(new RkAiqAlgoPostAf()); 
 | 
    mPostOutParam = (RkAiqAlgoResCom*)(new RkAiqAlgoPostResAf()); 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
} 
 | 
  
 | 
XCamReturn RkAiqAfHandle::prepare() { 
 | 
    ENTER_ANALYZER_FUNCTION(); 
 | 
    XCamReturn ret            = XCAM_RETURN_NO_ERROR; 
 | 
    RkAiqAlgoDescription* des = (RkAiqAlgoDescription*)mDes; 
 | 
  
 | 
    ret = RkAiqHandle::prepare(); 
 | 
    RKAIQCORE_CHECK_RET(ret, "af handle prepare failed"); 
 | 
  
 | 
    // TODO config af common params 
 | 
    RkAiqAlgoConfigAf* af_config = (RkAiqAlgoConfigAf*)mConfig; 
 | 
  
 | 
    // id != 0 means the thirdparty's algo 
 | 
    if (mDes->id != 0) { 
 | 
        ret = des->prepare(mConfig); 
 | 
        RKAIQCORE_CHECK_RET(ret, "af algo prepare failed"); 
 | 
    } 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
    return ret; 
 | 
} 
 | 
  
 | 
XCamReturn RkAiqAfHandle::preProcess() { 
 | 
    ENTER_ANALYZER_FUNCTION(); 
 | 
    XCamReturn ret                              = XCAM_RETURN_NO_ERROR; 
 | 
    RkAiqAlgoDescription* des                   = (RkAiqAlgoDescription*)mDes; 
 | 
    RkAiqAlgoPreAf* af_pre                      = (RkAiqAlgoPreAf*)mPreInParam; 
 | 
    RkAiqCore::RkAiqAlgosComShared_t* sharedCom = &mAiqCore->mAlogsComSharedParams; 
 | 
    RkAiqCore::RkAiqAlgosGroupShared_t* shared  = nullptr; 
 | 
    int groupId                                 = mAiqCore->getGroupId(RK_AIQ_ALGO_TYPE_AF); 
 | 
    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::preProcess(); 
 | 
    RKAIQCORE_CHECK_RET(ret, "af handle preProcess failed"); 
 | 
  
 | 
    RkAiqAfStats* xAfStats = nullptr; 
 | 
    if (shared->afStatsBuf) { 
 | 
        xAfStats = (RkAiqAfStats*)shared->afStatsBuf->map(shared->afStatsBuf); 
 | 
        if (!xAfStats) LOGE("af stats is null"); 
 | 
    } else { 
 | 
        LOGE("the xcamvideobuffer of af stats is null"); 
 | 
    } 
 | 
    if ((!xAfStats || !xAfStats->af_stats_valid) && !sharedCom->init) { 
 | 
        LOGE("no af stats, ignore!"); 
 | 
        return XCAM_RETURN_BYPASS; 
 | 
    } 
 | 
  
 | 
    // TODO config common af preprocess params 
 | 
  
 | 
    // id != 0 means the thirdparty's algo 
 | 
    if (mDes->id != 0) { 
 | 
        ret = des->pre_process(mPreInParam, mPreOutParam); 
 | 
        RKAIQCORE_CHECK_RET(ret, "af handle pre_process failed"); 
 | 
    } 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
    return ret; 
 | 
} 
 | 
  
 | 
XCamReturn RkAiqAfHandle::processing() { 
 | 
    XCamReturn ret                              = XCAM_RETURN_NO_ERROR; 
 | 
    RkAiqAlgoDescription* des                   = (RkAiqAlgoDescription*)mDes; 
 | 
    RkAiqAlgoProcAf* af_pre                     = (RkAiqAlgoProcAf*)mProcInParam; 
 | 
    RkAiqCore::RkAiqAlgosComShared_t* sharedCom = &mAiqCore->mAlogsComSharedParams; 
 | 
    RkAiqCore::RkAiqAlgosGroupShared_t* shared  = nullptr; 
 | 
    int groupId                                 = mAiqCore->getGroupId(RK_AIQ_ALGO_TYPE_AF); 
 | 
    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, "af handle processing failed"); 
 | 
  
 | 
    RkAiqAfStats* xAfStats = nullptr; 
 | 
    if (shared->afStatsBuf) { 
 | 
        xAfStats = (RkAiqAfStats*)shared->afStatsBuf->map(shared->afStatsBuf); 
 | 
        if (!xAfStats) LOGE("af stats is null"); 
 | 
    } else { 
 | 
        LOGE("the xcamvideobuffer of af stats is null"); 
 | 
    } 
 | 
    if ((!xAfStats || !xAfStats->af_stats_valid) && !sharedCom->init) { 
 | 
        LOGE("no af stats, ignore!"); 
 | 
        return XCAM_RETURN_BYPASS; 
 | 
    } 
 | 
  
 | 
    // TODO config common af processing params 
 | 
  
 | 
    // id != 0 means the thirdparty's algo 
 | 
    if (mDes->id != 0) { 
 | 
        ret = des->processing(mProcInParam, mProcOutParam); 
 | 
        RKAIQCORE_CHECK_RET(ret, "af algo processing failed"); 
 | 
    } 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
    return ret; 
 | 
} 
 | 
  
 | 
XCamReturn RkAiqAfHandle::postProcess() { 
 | 
    ENTER_ANALYZER_FUNCTION(); 
 | 
    XCamReturn ret                              = XCAM_RETURN_NO_ERROR; 
 | 
    RkAiqAlgoDescription* des                   = (RkAiqAlgoDescription*)mDes; 
 | 
    RkAiqAlgoPostAf* af_pre                     = (RkAiqAlgoPostAf*)mPostInParam; 
 | 
    RkAiqCore::RkAiqAlgosComShared_t* sharedCom = &mAiqCore->mAlogsComSharedParams; 
 | 
    RkAiqCore::RkAiqAlgosGroupShared_t* shared  = nullptr; 
 | 
    int groupId                                 = mAiqCore->getGroupId(RK_AIQ_ALGO_TYPE_AF); 
 | 
    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, "af handle postProcess failed"); 
 | 
  
 | 
    RkAiqAfStats* xAfStats = nullptr; 
 | 
    if (shared->afStatsBuf) { 
 | 
        xAfStats = (RkAiqAfStats*)shared->afStatsBuf->map(shared->afStatsBuf); 
 | 
        if (!xAfStats) LOGE("af stats is null"); 
 | 
    } else { 
 | 
        LOGE("the xcamvideobuffer of af stats is null"); 
 | 
    } 
 | 
    if ((!xAfStats || !xAfStats->af_stats_valid) && !sharedCom->init) { 
 | 
        LOGE("no af stats, ignore!"); 
 | 
        return XCAM_RETURN_BYPASS; 
 | 
    } 
 | 
  
 | 
    // TODO config common af postProcess params 
 | 
  
 | 
    // id != 0 means the thirdparty's algo 
 | 
    if (mDes->id != 0) { 
 | 
        ret = des->post_process(mPostInParam, mPostOutParam); 
 | 
        RKAIQCORE_CHECK_RET(ret, "af algo postProcess failed"); 
 | 
    } 
 | 
  
 | 
    EXIT_ANALYZER_FUNCTION(); 
 | 
    return ret; 
 | 
} 
 | 
  
 | 
};  // namespace RkCam 
 |