You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
178 lines
3.2 KiB
178 lines
3.2 KiB
#ifndef UAPI_MSMB_ISPIF_H
|
|
#define UAPI_MSMB_ISPIF_H
|
|
|
|
#include <linux/types.h>
|
|
#include <linux/ioctl.h>
|
|
#include <linux/videodev2.h>
|
|
|
|
#define CSID_VERSION_V20 0x02000011
|
|
#define CSID_VERSION_V22 0x02001000
|
|
#define CSID_VERSION_V30 0x30000000
|
|
#define CSID_VERSION_V3 0x30000000
|
|
|
|
enum msm_ispif_vfe_intf {
|
|
VFE0,
|
|
VFE1,
|
|
VFE_MAX
|
|
};
|
|
#define VFE0_MASK (1 << VFE0)
|
|
#define VFE1_MASK (1 << VFE1)
|
|
|
|
enum msm_ispif_intftype {
|
|
PIX0,
|
|
RDI0,
|
|
PIX1,
|
|
RDI1,
|
|
RDI2,
|
|
INTF_MAX
|
|
};
|
|
#define MAX_PARAM_ENTRIES (INTF_MAX * 2)
|
|
#define MAX_CID_CH 8
|
|
#define MAX_CID_CH_PARAM_ENTRY 3
|
|
|
|
#define PIX0_MASK (1 << PIX0)
|
|
#define PIX1_MASK (1 << PIX1)
|
|
#define RDI0_MASK (1 << RDI0)
|
|
#define RDI1_MASK (1 << RDI1)
|
|
#define RDI2_MASK (1 << RDI2)
|
|
|
|
enum msm_ispif_vc {
|
|
VC0,
|
|
VC1,
|
|
VC2,
|
|
VC3,
|
|
VC_MAX
|
|
};
|
|
|
|
enum msm_ispif_cid {
|
|
CID0,
|
|
CID1,
|
|
CID2,
|
|
CID3,
|
|
CID4,
|
|
CID5,
|
|
CID6,
|
|
CID7,
|
|
CID8,
|
|
CID9,
|
|
CID10,
|
|
CID11,
|
|
CID12,
|
|
CID13,
|
|
CID14,
|
|
CID15,
|
|
CID_MAX
|
|
};
|
|
|
|
enum msm_ispif_csid {
|
|
CSID0,
|
|
CSID1,
|
|
CSID2,
|
|
CSID3,
|
|
CSID_MAX
|
|
};
|
|
|
|
enum msm_ispif_pixel_odd_even {
|
|
PIX_EVEN,
|
|
PIX_ODD
|
|
};
|
|
|
|
enum msm_ispif_pixel_pack_mode {
|
|
PACK_BYTE,
|
|
PACK_PLAIN_PACK,
|
|
PACK_NV_P8,
|
|
PACK_NV_P16
|
|
};
|
|
|
|
struct msm_ispif_pack_cfg {
|
|
int pixel_swap_en;
|
|
enum msm_ispif_pixel_odd_even even_odd_sel;
|
|
enum msm_ispif_pixel_pack_mode pack_mode;
|
|
};
|
|
|
|
struct msm_ispif_params_entry {
|
|
enum msm_ispif_vfe_intf vfe_intf;
|
|
enum msm_ispif_intftype intftype;
|
|
int num_cids;
|
|
enum msm_ispif_cid cids[MAX_CID_CH_PARAM_ENTRY];
|
|
enum msm_ispif_csid csid;
|
|
int crop_enable;
|
|
uint16_t crop_start_pixel;
|
|
uint16_t crop_end_pixel;
|
|
};
|
|
|
|
struct msm_ispif_right_param_entry {
|
|
enum msm_ispif_cid cids[MAX_CID_CH_PARAM_ENTRY];
|
|
enum msm_ispif_csid csid;
|
|
};
|
|
|
|
struct msm_ispif_param_data_ext {
|
|
uint32_t num;
|
|
struct msm_ispif_params_entry entries[MAX_PARAM_ENTRIES];
|
|
struct msm_ispif_pack_cfg pack_cfg[CID_MAX];
|
|
struct msm_ispif_right_param_entry right_entries[MAX_PARAM_ENTRIES];
|
|
uint32_t stereo_enable;
|
|
uint16_t line_width[VFE_MAX];
|
|
};
|
|
|
|
struct msm_ispif_param_data {
|
|
uint32_t num;
|
|
struct msm_ispif_params_entry entries[MAX_PARAM_ENTRIES];
|
|
};
|
|
|
|
struct msm_isp_info {
|
|
uint32_t max_resolution;
|
|
uint32_t id;
|
|
uint32_t ver;
|
|
};
|
|
|
|
struct msm_ispif_vfe_info {
|
|
int num_vfe;
|
|
struct msm_isp_info info[VFE_MAX];
|
|
};
|
|
|
|
enum ispif_cfg_type_t {
|
|
ISPIF_CLK_ENABLE,
|
|
ISPIF_CLK_DISABLE,
|
|
ISPIF_INIT,
|
|
ISPIF_CFG,
|
|
ISPIF_START_FRAME_BOUNDARY,
|
|
ISPIF_RESTART_FRAME_BOUNDARY,
|
|
ISPIF_STOP_FRAME_BOUNDARY,
|
|
ISPIF_STOP_IMMEDIATELY,
|
|
ISPIF_RELEASE,
|
|
ISPIF_ENABLE_REG_DUMP,
|
|
ISPIF_SET_VFE_INFO,
|
|
ISPIF_CFG2,
|
|
ISPIF_CFG_STEREO,
|
|
};
|
|
|
|
struct ispif_cfg_data {
|
|
enum ispif_cfg_type_t cfg_type;
|
|
union {
|
|
int reg_dump; /* ISPIF_ENABLE_REG_DUMP */
|
|
uint32_t csid_version; /* ISPIF_INIT */
|
|
struct msm_ispif_vfe_info vfe_info; /* ISPIF_SET_VFE_INFO */
|
|
struct msm_ispif_param_data params; /* CFG, START, STOP */
|
|
};
|
|
};
|
|
|
|
struct ispif_cfg_data_ext {
|
|
enum ispif_cfg_type_t cfg_type;
|
|
void __user *data;
|
|
uint32_t size;
|
|
};
|
|
|
|
#define ISPIF_RDI_PACK_MODE_SUPPORT 1
|
|
|
|
#define ISPIF_3D_SUPPORT 1
|
|
|
|
#define ISPIF_LINE_WIDTH_SUPPORT 1
|
|
|
|
#define VIDIOC_MSM_ISPIF_CFG \
|
|
_IOWR('V', BASE_VIDIOC_PRIVATE, struct ispif_cfg_data)
|
|
|
|
#define VIDIOC_MSM_ISPIF_CFG_EXT \
|
|
_IOWR('V', BASE_VIDIOC_PRIVATE+1, struct ispif_cfg_data_ext)
|
|
|
|
#endif
|
|
|