firmware/br-ext-chip-xiongmai/package/xiongmai-osdrv2/files/include/isp/xm_comm_3a.h

344 lines
8.3 KiB
C

/******************************************************************************
Copyright (C), 2015-2020, XM. Co., Ltd.
******************************************************************************
File Name : xm_common_3a.h
Version : Initial Draft
Author : XM Isp software group
Created : 2015/6/27
Description : The common data type defination
Function List :
History :
1.Date : 2015/6/27
Author : Lycai
Modification : creat
******************************************************************************/
#ifndef __XM_COMM_3A_H__
#define __XM_COMM_3A_H__
#include "xm_common.h"
#include "xm_comm_isp.h"
#define MAX_REGISTER_ALG_LIB_NUM 2
typedef enum xm_ISP_ALG_MOD_E
{
ISP_ALG_AE = 0,
ISP_ALG_AF,
ISP_ALG_AWB,
ISP_ALG_ANTIFOG,
ISP_ALG_BLC,
ISP_ALG_DP,
ISP_ALG_DRC,
ISP_ALG_DEMOSAIC,
ISP_ALG_GAMMA,
ISP_ALG_GAMMAFE,
ISP_ALG_GE,
ISP_ALG_NEW_ANTIFOG,
ISP_ALG_NR,
ISP_ALG_SHARPEN,
ISP_ALG_SHADING,
ISP_ALG_BUTT,
} ISP_ALG_MOD_E;
typedef enum xm_ISP_CTRL_CMD_E
{
ISP_WDR_MODE_SET = 8000,
ISP_PROC_WRITE,
ISP_AE_FPS_BASE_SET,
ISP_AWB_ISO_SET, /* set iso, change saturation when iso change */
ISP_AE_INTTIME_GET,
ISP_AWB_INTTIME_SET,
ISP_CHANGE_IMAGE_MODE_SET,
ISP_CTRL_CMD_BUTT,
} ISP_CTRL_CMD_E;
typedef struct xm_ISP_CTRL_PROC_WRITE_S
{
XM_CHAR *pcProcBuff;
XM_U32 u32BuffLen;
XM_U32 u32WriteLen; /* The len count should contain '\0'. */
} ISP_CTRL_PROC_WRITE_S;
/******************************** AE *************************************/
/* the init param of ae alg */
typedef struct xm_ISP_AE_PARAM_S
{
SENSOR_ID SensorId;
XM_U32 u32MaxIspDgain;
XM_U32 u32MinIspDgain;
XM_U32 u32IspDgainShift;
XM_U8 u8FrameRate;
} ISP_AE_PARAM_S;
/* the statistics of ae alg */
typedef struct xm_ISP_AE_STAT_1_S
{
XM_U32 au32MeteringHist[16];
} ISP_AE_STAT_1_S;
typedef struct xm_ISP_AE_STAT_2_S
{
XM_U32 au32MeteringWin[AE_ZONE_ROW][AE_ZONE_COLUMN]; // Y_avg << 8
} ISP_AE_STAT_2_S;
typedef struct xm_ISP_AE_STAT_3_S
{
XM_U16 au16MeteringWinV2[ISP_V2_ZONE_ROW][ISP_V2_ZONE_COLUMN];
} ISP_AE_STAT_3_S;
typedef struct xm_ISP_AE_STAT_S
{
XM_U8 u8FrameRate;
XM_U32 u32FrameCnt;
XM_U32 au32MeteringWin[AE_ZONE_ROW][AE_ZONE_COLUMN]; // Y_avg << 8
} ISP_AE_STAT_S;
typedef struct xm_ISP_AE_INFO_S
{
XM_U32 u32FrameCnt; /* the counting of frame */
XM_U8 u8FrameRate;
ISP_AE_STAT_1_S stAeStat1;
ISP_AE_STAT_2_S stAeStat2;
ISP_AE_STAT_3_S stAeStat3;
} ISP_AE_INFO_S;
/* the final calculate of ae alg */
typedef struct xm_ISP_AE_RESULT_S
{
XM_U32 u32IspDgain;
XM_U32 u32IspDgainShift;
XM_U32 u32Iso;
XM_U32 u32Rsv;
/********************************
u32UpdateCfg:
bit[0~7] period
bit[8~15] shut
bit[16~23] snsGain
bit[24~31] ispGain
********************************/
XM_U32 u32UpdateCfg;
} ISP_AE_RESULT_S;
typedef struct xm_ISP_AE_EXP_FUNC_S
{
XM_S32 (*pfn_ae_init)(ISP_DEV IspDev, XM_S32 s32Handle, const ISP_AE_PARAM_S *pstAeParam);
XM_S32 (*pfn_ae_run)(ISP_DEV IspDev, XM_S32 s32Handle,
const ISP_AE_INFO_S *pstAeInfo,
ISP_AE_RESULT_S *pstAeResult,
XM_S32 s32Rsv
);
XM_S32 (*pfn_ae_ctrl)(ISP_DEV IspDev, XM_S32 s32Handle, XM_U32 u32Cmd, XM_VOID *pValue);
XM_S32 (*pfn_ae_exit)(ISP_DEV IspDev, XM_S32 s32Handle);
} ISP_AE_EXP_FUNC_S;
typedef struct xm_ISP_AE_REGISTER_S
{
ISP_AE_EXP_FUNC_S stAeExpFunc;
} ISP_AE_REGISTER_S;
/******************************** AWB *************************************/
/* the statistics of awb alg */
typedef struct xm_ISP_AWB_STAT_ZONE_S
{
XM_U32 u32Data1; // Wp
XM_U32 u32Data2; // Cb
XM_U32 u32Data3; // Cr
} ISP_AWB_STAT_ZONE_S;
typedef struct xm_ISP_AWB_STAT_1_S
{
ISP_AWB_STAT_ZONE_S stStat1[4][4]; // 4:Chn // 4:Zone
} ISP_AWB_STAT_1_S;
typedef struct xm_ISP_AWB_STAT_2_S
{
;
} ISP_AWB_STAT_2_S;
typedef struct xm_ISP_AWB_INFO_S
{
XM_U32 u32FrameCnt;
XM_U32 u32Rsv;
ISP_AWB_STAT_1_S *pstAwbStat1;
ISP_AWB_STAT_2_S *pstAwbStat2;
} ISP_AWB_INFO_S;
/* the statistics's attr of awb alg */
typedef struct xm_ISP_AWB_FT_L_ATTR_S
{
XM_BOOL bChange;
XM_U32 u32Lh;
XM_U32 u32Lv;
XM_U32 u32L45;
XM_U32 u32L135;
} ISP_AWB_FT_L_ATTR_S;
typedef struct xm_ISP_AWB_FT_K_ATTR_S
{
XM_BOOL bChange;
XM_U32 u32KCbCr1;
XM_U32 u32KCbCr2;
XM_U32 u32KCbCr3;
XM_U32 u32KCbCr4;
} ISP_AWB_FT_K_ATTR_S;
typedef struct xm_ISP_AWB_WDW_ATTR_S
{
XM_BOOL bChange;
XM_U8 u8Mode;
XM_U32 u32VBegin;
XM_U32 u32VEnd;
XM_U32 u32HBegin;
XM_U32 u32HEnd;
} ISP_AWB_WDW_ATTR_S;
typedef struct xm_ISP_AWB_BG_ATTR_S
{
XM_BOOL bChange;
XM_U32 u32R_Ch[4];
XM_U32 u32B_Ch[4];
} ISP_AWB_BG_ATTR_S;
typedef struct xm_ISP_AWB_RESULT_BK_S
{
ISP_AWB_FT_L_ATTR_S stFtL;
ISP_AWB_FT_K_ATTR_S stFtK;
ISP_AWB_WDW_ATTR_S stWin;
ISP_AWB_BG_ATTR_S stBg;
} ISP_AWB_RESULT_BK_S;
typedef struct xm_ISP_AWB_RESULT_GAIN_S
{
XM_BOOL bChange;
XM_U32 au32WhiteBalanceGain[3];
} ISP_AWB_RESULT_GAIN_S;
typedef struct xm_ISP_AWB_RESULT_CC_S
{
XM_BOOL bChange;
XM_U16 au16ColorMatrix[12];
} ISP_AWB_RESULT_CC_S;
/* the final calculate of awb alg */
typedef struct xm_ISP_AWB_RESULT_S
{
ISP_AWB_RESULT_GAIN_S *pstRlt_Gain;
ISP_AWB_RESULT_CC_S *pstRlt_Cc;
ISP_AWB_RESULT_BK_S *pstRlt_Bk;
XM_U16 *pstRlt_RGB;
} ISP_AWB_RESULT_S;
typedef struct xm_ISP_AWB_EXP_FUNC_S
{
XM_S32 (*pfn_awb_init)(XM_S32 s32Handle, ISP_AWB_RESULT_BK_S* const pstAwbParam,XM_U32 Width,XM_U32 Height);
XM_S32 (*pfn_awb_run)(XM_S32 s32Handle,
const ISP_AWB_INFO_S *pstAwbInfo,
ISP_AWB_RESULT_S *pstAwbResult,
XM_S32 s32Rsv
);
XM_S32 (*pfn_awb_ctrl)(XM_S32 s32Handle, XM_U32 u32Cmd, XM_VOID *pValue);
XM_S32 (*pfn_awb_exit)(XM_S32 s32Handle);
} ISP_AWB_EXP_FUNC_S;
typedef struct xm_ISP_AWB_REGISTER_S
{
ISP_AWB_EXP_FUNC_S stAwbExpFunc;
} ISP_AWB_REGISTER_S;
/******************************** AF *************************************/
/* the init param of af alg */
typedef struct xm_ISP_AF_PARAM_S
{
SENSOR_ID SensorId;
XM_S32 s32Rsv;
} ISP_AF_PARAM_S;
/* the statistics of af alg */
typedef struct xm_ISP_AF_STAT_S
{
XM_U16 u16FocusMetrics; /* The integrated and normalized measure of contrast*/
XM_U16 u16ThresholdRead; /* The ISP recommend value of AF threshold*/
XM_U16 u16ThresholdWrite; /* The user defined value of AF threshold (or 0 to use threshold from previous frame)*/
XM_U16 u16FocusIntensity; /* The average brightness*/
XM_U8 u8MetricsShift; /* Metrics scaling factor:the bigger value for this register means all zones metrics go higher,0x03 is the default, Range: [0x0, 0xF] */
XM_U8 u8NpOffset; /* The AF noise profile offset, Range: [0x0, 0xFF] */
XM_U16 au16ZoneMetrics[AE_ZONE_ROW][AE_ZONE_COLUMN]; /* The zoned measure of contrast*/
} ISP_AF_STAT_S;
typedef struct xm_ISP_AF_INFO_S
{
XM_U32 u32FrameCnt;
ISP_AF_STAT_S *pstStatistics;
} ISP_AF_INFO_S;
typedef struct xm_ISP_AF_STAT_ATTR_S
{
XM_BOOL bChange;
XM_U16 u16ThresholdWrite;
XM_U8 u8MetricsShift;
XM_U8 u8NpOffset;
} ISP_AF_STAT_ATTR_S;
/* the final calculate of af alg */
typedef struct xm_ISP_AF_RESULT_S
{
ISP_AF_STAT_ATTR_S stStatAttr;
XM_S32 s32Rsv;
} ISP_AF_RESULT_S;
typedef struct xm_ISP_AF_EXP_FUNC_S
{
XM_S32 (*pfn_af_init)(XM_S32 s32Handle, const ISP_AF_PARAM_S *pstAfParam);
XM_S32 (*pfn_af_run)(XM_S32 s32Handle,
const ISP_AF_INFO_S *pstAfInfo,
ISP_AF_RESULT_S *pstAfResult,
XM_S32 s32Rsv
);
XM_S32 (*pfn_af_ctrl)(XM_S32 s32Handle, XM_U32 u32Cmd, XM_VOID *pValue);
XM_S32 (*pfn_af_exit)(XM_S32 s32Handle);
} ISP_AF_EXP_FUNC_S;
typedef struct xm_ISP_AF_REGISTER_S
{
ISP_AF_EXP_FUNC_S stAfExpFunc;
} ISP_AF_REGISTER_S;
typedef struct xm_ALG_LIB_S
{
XM_S32 s32Id;
XM_CHAR acLibName[20];
} ALG_LIB_S;
typedef struct xm_ISP_BIND_ATTR_S
{
SENSOR_ID SensorId;
ALG_LIB_S stAeLib;
ALG_LIB_S stAfLib;
ALG_LIB_S stAwbLib;
} ISP_BIND_ATTR_S;
#endif /*__XM_COMM_SNS_H__ */