123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179 |
- #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
|