/*
* aiq_wrapper.cpp - aiq wrapper:
*
* Copyright (c) 2015 Intel 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.
*
* Author: Jia Meng <jia.meng@intel.com>
*/
#include <base/xcam_3a_description.h>
#include <xcam_std.h>
using namespace XCam;
#define CONTEXT_CAST(context) ((XCam3AHybridContext*)(context))
class XCam3AHybridContext
{
public:
XCam3AHybridContext ();
~XCam3AHybridContext ();
private:
XCAM_DEAD_COPY (XCam3AHybridContext);
};
XCam3AHybridContext::XCam3AHybridContext ()
{
}
XCam3AHybridContext::~XCam3AHybridContext ()
{
}
static XCamReturn
xcam_create_context (XCam3AContext **context)
{
XCAM_ASSERT (context);
XCam3AHybridContext *ctx = new XCam3AHybridContext ();
*context = ((XCam3AContext*)(ctx));
return XCAM_RETURN_NO_ERROR;
}
static XCamReturn
xcam_destroy_context (XCam3AContext *context)
{
XCam3AHybridContext *ctx = CONTEXT_CAST (context);
delete ctx;
return XCAM_RETURN_NO_ERROR;
}
// configure customized 3a analyzer with width/height/framerate
static XCamReturn
xcam_configure_3a (XCam3AContext *context, uint32_t width, uint32_t height, double framerate)
{
XCAM_UNUSED (context);
XCAM_UNUSED (width);
XCAM_UNUSED (height);
XCAM_UNUSED (framerate);
return XCAM_RETURN_NO_ERROR;
}
// set 3a stats to customized 3a analyzer for subsequent usage
static XCamReturn
xcam_set_3a_stats (XCam3AContext *context, XCam3AStats *stats, int64_t timestamp)
{
XCAM_UNUSED (context);
XCAM_UNUSED (timestamp);
XCam3AStatsInfo info = stats->info;
for (uint32_t i = 0; i < info.height; ++i)
for (uint32_t j = 0; j < info.width; ++j) {
XCAM_LOG_DEBUG ("%d %d %d %d %d %d %d %d",
stats->stats[i * info.aligned_width + j].avg_y,
stats->stats[i * info.aligned_width + j].avg_gr,
stats->stats[i * info.aligned_width + j].avg_r,
stats->stats[i * info.aligned_width + j].avg_b,
stats->stats[i * info.aligned_width + j].avg_gb,
stats->stats[i * info.aligned_width + j].valid_wb_count,
stats->stats[i * info.aligned_width + j].f_value1,
stats->stats[i * info.aligned_width + j].f_value2);
}
return XCAM_RETURN_NO_ERROR;
}
// refer to xcam_params.h for common parameters
static XCamReturn
xcam_update_common_params (XCam3AContext *context, XCamCommonParam *params)
{
XCAM_UNUSED (context);
XCAM_UNUSED (params);
return XCAM_RETURN_NO_ERROR;
}
// customized awb algorithm should be added here
static XCamReturn
xcam_analyze_awb (XCam3AContext *context, XCamAwbParam *params)
{
XCAM_UNUSED (context);
XCAM_UNUSED (params);
return XCAM_RETURN_NO_ERROR;
}
// customized ae algorithm should be added here
static XCamReturn
xcam_analyze_ae (XCam3AContext *context, XCamAeParam *params)
{
XCAM_UNUSED (context);
XCAM_UNUSED (params);
return XCAM_RETURN_NO_ERROR;
}
// customized af is unsupported now
static XCamReturn
xcam_analyze_af (XCam3AContext *context, XCamAfParam *params)
{
XCAM_UNUSED (context);
XCAM_UNUSED (params);
return XCAM_RETURN_NO_ERROR;
}
// combine ae/awb analyze results and set to framework
// only support XCam3aResultExposure and XCam3aResultWhiteBalance now
static XCamReturn
xcam_combine_analyze_results (XCam3AContext *context, XCam3aResultHead *results[], uint32_t *res_count)
{
XCAM_UNUSED (context);
uint32_t result_count = 2;
static XCam3aResultHead *res_array[XCAM_3A_MAX_RESULT_COUNT];
xcam_mem_clear (res_array);
for (uint32_t i = 0; i < result_count; ++i) {
results[i] = res_array[i];
}
*res_count = result_count;
XCam3aResultExposure *exposure = xcam_malloc0_type (XCam3aResultExposure);
XCAM_ASSERT (exposure);
exposure->head.type = XCAM_3A_RESULT_EXPOSURE;
exposure->head.process_type = XCAM_IMAGE_PROCESS_ALWAYS;
exposure->head.version = XCAM_VERSION;
exposure->exposure_time = 9986; // 9.986ms
exposure->analog_gain = 10;
results[0] = (XCam3aResultHead *)exposure;
XCam3aResultWhiteBalance *wb = xcam_malloc0_type (XCam3aResultWhiteBalance);
XCAM_ASSERT (wb);
wb->head.type = XCAM_3A_RESULT_WHITE_BALANCE;
wb->head.process_type = XCAM_IMAGE_PROCESS_ALWAYS;
wb->head.version = XCAM_VERSION;
wb->gr_gain = 1.0;
wb->r_gain = 1.6453;
wb->b_gain = 2.0645;
wb->gb_gain = 1.0;
results[1] = (XCam3aResultHead *)wb;
return XCAM_RETURN_NO_ERROR;
}
static void
xcam_free_results (XCam3aResultHead *results[], uint32_t res_count)
{
for (uint32_t i = 0; i < res_count; ++i) {
if (results[i])
xcam_free (results[i]);
}
}
XCAM_BEGIN_DECLARE
XCam3ADescription xcam_3a_desciption = {
XCAM_VERSION,
sizeof (XCam3ADescription),
xcam_create_context,
xcam_destroy_context,
xcam_configure_3a,
xcam_set_3a_stats,
xcam_update_common_params,
xcam_analyze_awb,
xcam_analyze_ae,
xcam_analyze_af,
xcam_combine_analyze_results,
xcam_free_results
};
XCAM_END_DECLARE