#include "rk_aiq_uapi_agamma_int.h"
|
#include "agamma/rk_aiq_types_agamma_algo_prvt.h"
|
|
|
void
|
rk_aiq_uapi_agamma_SetTool
|
(
|
CalibDbV2_gamma_t* pStore,
|
CalibDbV2_gamma_t* pInput
|
)
|
{
|
LOG1_AGAMMA("ENTER: %s \n", __func__);
|
|
pStore->GammaTuningPara.Gamma_en = pInput->GammaTuningPara.Gamma_en;
|
pStore->GammaTuningPara.Gamma_out_offset = pInput->GammaTuningPara.Gamma_out_offset;
|
pStore->GammaTuningPara.Gamma_out_segnum = pInput->GammaTuningPara.Gamma_out_segnum;
|
for(int i = 0; i < 45; i++)
|
pStore->GammaTuningPara.Gamma_curve[i] = pInput->GammaTuningPara.Gamma_curve[i];
|
|
LOG1_AGAMMA("EXIT: %s \n", __func__);
|
|
}
|
|
XCamReturn
|
rk_aiq_uapi_agamma_SetAttrib(RkAiqAlgoContext *ctx,
|
rk_aiq_gamma_attrib_V2_t attr,
|
bool need_sync)
|
{
|
LOG1_AGAMMA("ENTER: %s \n", __func__);
|
AgammaHandle_t *gamma_handle = (AgammaHandle_t *)ctx;
|
XCamReturn ret = XCAM_RETURN_NO_ERROR;
|
|
gamma_handle->agammaAttr.mode = attr.mode;
|
if(attr.mode == RK_AIQ_GAMMA_MODE_MANUAL)
|
memcpy(&gamma_handle->agammaAttr.stManual, &attr.stManual, sizeof(Agamma_api_manual_t));
|
if(attr.mode == RK_AIQ_GAMMA_MODE_TOOL)
|
rk_aiq_uapi_agamma_SetTool(&gamma_handle->agammaAttr.stTool, &attr.stTool);
|
|
LOG1_AGAMMA("EXIT: %s \n", __func__);
|
return ret;
|
}
|
|
XCamReturn
|
rk_aiq_uapi_agamma_GetAttrib(const RkAiqAlgoContext *ctx,
|
rk_aiq_gamma_attrib_V2_t *attr)
|
{
|
LOG1_AGAMMA("ENTER: %s \n", __func__);
|
|
AgammaHandle_t* gamma_handle = (AgammaHandle_t*)ctx;
|
|
attr->mode = gamma_handle->agammaAttr.mode;
|
memcpy(&attr->stManual, &gamma_handle->agammaAttr.stManual, sizeof(Agamma_api_manual_t));
|
rk_aiq_uapi_agamma_SetTool(&attr->stTool, &gamma_handle->agammaAttr.stTool);
|
|
LOG1_AGAMMA("EXIT: %s \n", __func__);
|
return XCAM_RETURN_NO_ERROR;
|
}
|