Home | History | Annotate | Download | only in linux
      1 #ifndef _MSM_VIDC_ENC_H_
      2 #define _MSM_VIDC_ENC_H_
      3 
      4 #include <linux/types.h>
      5 #include <linux/ioctl.h>
      6 
      7 /** STATUS CODES*/
      8 /* Base value for status codes */
      9 #define VEN_S_BASE	0x00000000
     10 #define VEN_S_SUCCESS	(VEN_S_BASE)/* Success */
     11 #define VEN_S_EFAIL	(VEN_S_BASE+1)/* General failure */
     12 #define VEN_S_EFATAL	(VEN_S_BASE+2)/* Fatal irrecoverable failure*/
     13 #define VEN_S_EBADPARAM	(VEN_S_BASE+3)/* Error passed parameters*/
     14 /*Command called in invalid state*/
     15 #define VEN_S_EINVALSTATE	(VEN_S_BASE+4)
     16 #define VEN_S_ENOSWRES	(VEN_S_BASE+5)/* Insufficient OS resources*/
     17 #define VEN_S_ENOHWRES	(VEN_S_BASE+6)/*Insufficient HW resources */
     18 #define VEN_S_EBUFFREQ	(VEN_S_BASE+7)/* Buffer requirements were not met*/
     19 #define VEN_S_EINVALCMD	(VEN_S_BASE+8)/* Invalid command called */
     20 #define VEN_S_ETIMEOUT	(VEN_S_BASE+9)/* Command timeout. */
     21 /*Re-attempt was made when multiple invocation not supported for API.*/
     22 #define VEN_S_ENOREATMPT	(VEN_S_BASE+10)
     23 #define VEN_S_ENOPREREQ	(VEN_S_BASE+11)/*Pre-requirement is not met for API*/
     24 #define VEN_S_ECMDQFULL	(VEN_S_BASE+12)/*Command queue is full*/
     25 #define VEN_S_ENOTSUPP	(VEN_S_BASE+13)/*Command not supported*/
     26 #define VEN_S_ENOTIMPL	(VEN_S_BASE+14)/*Command not implemented.*/
     27 #define VEN_S_ENOTPMEM	(VEN_S_BASE+15)/*Buffer is not from PMEM*/
     28 #define VEN_S_EFLUSHED	(VEN_S_BASE+16)/*returned buffer was flushed*/
     29 #define VEN_S_EINSUFBUF	(VEN_S_BASE+17)/*provided buffer size insufficient*/
     30 #define VEN_S_ESAMESTATE	(VEN_S_BASE+18)
     31 #define VEN_S_EINVALTRANS	(VEN_S_BASE+19)
     32 
     33 #define VEN_INTF_VER			 1
     34 
     35 /*Asynchronous messages from driver*/
     36 #define VEN_MSG_INDICATION	0
     37 #define VEN_MSG_INPUT_BUFFER_DONE	1
     38 #define VEN_MSG_OUTPUT_BUFFER_DONE	2
     39 #define VEN_MSG_NEED_OUTPUT_BUFFER	3
     40 #define VEN_MSG_FLUSH_INPUT_DONE	4
     41 #define VEN_MSG_FLUSH_OUPUT_DONE	5
     42 #define VEN_MSG_START	6
     43 #define VEN_MSG_STOP	7
     44 #define VEN_MSG_PAUSE	8
     45 #define VEN_MSG_RESUME	9
     46 #define VEN_MSG_STOP_READING_MSG	10
     47 #define VEN_MSG_LTRUSE_FAILED	    11
     48 
     49 
     50 /*Buffer flags bits masks*/
     51 #define VEN_BUFFLAG_EOS	0x00000001
     52 #define VEN_BUFFLAG_ENDOFFRAME	0x00000010
     53 #define VEN_BUFFLAG_SYNCFRAME	0x00000020
     54 #define VEN_BUFFLAG_EXTRADATA	0x00000040
     55 #define VEN_BUFFLAG_CODECCONFIG	0x00000080
     56 
     57 /*Post processing flags bit masks*/
     58 #define VEN_EXTRADATA_NONE          0x001
     59 #define VEN_EXTRADATA_QCOMFILLER    0x002
     60 #define VEN_EXTRADATA_SLICEINFO     0x100
     61 #define VEN_EXTRADATA_LTRINFO       0x200
     62 
     63 /*ENCODER CONFIGURATION CONSTANTS*/
     64 
     65 /*Encoded video frame types*/
     66 #define VEN_FRAME_TYPE_I	1/* I frame type */
     67 #define VEN_FRAME_TYPE_P	2/* P frame type */
     68 #define VEN_FRAME_TYPE_B	3/* B frame type */
     69 
     70 /*Video codec types*/
     71 #define VEN_CODEC_MPEG4	1/* MPEG4 Codec */
     72 #define VEN_CODEC_H264	2/* H.264 Codec */
     73 #define VEN_CODEC_H263	3/* H.263 Codec */
     74 
     75 /*Video codec profile types.*/
     76 #define VEN_PROFILE_MPEG4_SP      1/* 1 - MPEG4 SP profile      */
     77 #define VEN_PROFILE_MPEG4_ASP     2/* 2 - MPEG4 ASP profile     */
     78 #define VEN_PROFILE_H264_BASELINE 3/* 3 - H264 Baseline profile	*/
     79 #define VEN_PROFILE_H264_MAIN     4/* 4 - H264 Main profile     */
     80 #define VEN_PROFILE_H264_HIGH     5/* 5 - H264 High profile     */
     81 #define VEN_PROFILE_H263_BASELINE 6/* 6 - H263 Baseline profile */
     82 
     83 /*Video codec profile level types.*/
     84 #define VEN_LEVEL_MPEG4_0	 0x1/* MPEG4 Level 0  */
     85 #define VEN_LEVEL_MPEG4_1	 0x2/* MPEG4 Level 1  */
     86 #define VEN_LEVEL_MPEG4_2	 0x3/* MPEG4 Level 2  */
     87 #define VEN_LEVEL_MPEG4_3	 0x4/* MPEG4 Level 3  */
     88 #define VEN_LEVEL_MPEG4_4	 0x5/* MPEG4 Level 4  */
     89 #define VEN_LEVEL_MPEG4_5	 0x6/* MPEG4 Level 5  */
     90 #define VEN_LEVEL_MPEG4_3b	 0x7/* MPEG4 Level 3b */
     91 #define VEN_LEVEL_MPEG4_6	 0x8/* MPEG4 Level 6  */
     92 
     93 #define VEN_LEVEL_H264_1	 0x9/* H.264 Level 1   */
     94 #define VEN_LEVEL_H264_1b        0xA/* H.264 Level 1b  */
     95 #define VEN_LEVEL_H264_1p1	 0xB/* H.264 Level 1.1 */
     96 #define VEN_LEVEL_H264_1p2	 0xC/* H.264 Level 1.2 */
     97 #define VEN_LEVEL_H264_1p3	 0xD/* H.264 Level 1.3 */
     98 #define VEN_LEVEL_H264_2	 0xE/* H.264 Level 2   */
     99 #define VEN_LEVEL_H264_2p1	 0xF/* H.264 Level 2.1 */
    100 #define VEN_LEVEL_H264_2p2	0x10/* H.264 Level 2.2 */
    101 #define VEN_LEVEL_H264_3	0x11/* H.264 Level 3   */
    102 #define VEN_LEVEL_H264_3p1	0x12/* H.264 Level 3.1 */
    103 #define VEN_LEVEL_H264_3p2	0x13/* H.264 Level 3.2 */
    104 #define VEN_LEVEL_H264_4	0x14/* H.264 Level 4   */
    105 
    106 #define VEN_LEVEL_H263_10	0x15/* H.263 Level 10  */
    107 #define VEN_LEVEL_H263_20	0x16/* H.263 Level 20  */
    108 #define VEN_LEVEL_H263_30	0x17/* H.263 Level 30  */
    109 #define VEN_LEVEL_H263_40	0x18/* H.263 Level 40  */
    110 #define VEN_LEVEL_H263_45	0x19/* H.263 Level 45  */
    111 #define VEN_LEVEL_H263_50	0x1A/* H.263 Level 50  */
    112 #define VEN_LEVEL_H263_60	0x1B/* H.263 Level 60  */
    113 #define VEN_LEVEL_H263_70	0x1C/* H.263 Level 70  */
    114 
    115 /*Entropy coding model selection for H.264 encoder.*/
    116 #define VEN_ENTROPY_MODEL_CAVLC	1
    117 #define VEN_ENTROPY_MODEL_CABAC	2
    118 /*Cabac model number (0,1,2) for encoder.*/
    119 #define VEN_CABAC_MODEL_0	1/* CABAC Model 0. */
    120 #define VEN_CABAC_MODEL_1	2/* CABAC Model 1. */
    121 #define VEN_CABAC_MODEL_2	3/* CABAC Model 2. */
    122 
    123 /*Deblocking filter control type for encoder.*/
    124 #define VEN_DB_DISABLE	1/* 1 - Disable deblocking filter*/
    125 #define VEN_DB_ALL_BLKG_BNDRY	2/* 2 - All blocking boundary filtering*/
    126 #define VEN_DB_SKIP_SLICE_BNDRY	3/* 3 - Filtering except sliceboundary*/
    127 
    128 /*Different methods of Multi slice selection.*/
    129 #define VEN_MSLICE_OFF	1
    130 #define VEN_MSLICE_CNT_MB	2 /*number of MBscount per slice*/
    131 #define VEN_MSLICE_CNT_BYTE	3 /*number of bytes count per slice.*/
    132 #define VEN_MSLICE_GOB	4 /*Multi slice by GOB for H.263 only.*/
    133 
    134 /*Different modes for Rate Control.*/
    135 #define VEN_RC_OFF	1
    136 #define VEN_RC_VBR_VFR	2
    137 #define VEN_RC_VBR_CFR	3
    138 #define VEN_RC_CBR_VFR	4
    139 #define VEN_RC_CBR_CFR	5
    140 
    141 /*Different modes for flushing buffers*/
    142 #define VEN_FLUSH_INPUT	1
    143 #define VEN_FLUSH_OUTPUT	2
    144 #define VEN_FLUSH_ALL	3
    145 
    146 /*Different input formats for YUV data.*/
    147 #define VEN_INPUTFMT_NV12	1/* NV12 Linear */
    148 #define VEN_INPUTFMT_NV21	2/* NV21 Linear */
    149 #define VEN_INPUTFMT_NV12_16M2KA	3/* NV12 Linear */
    150 
    151 /*Different allowed rotation modes.*/
    152 #define VEN_ROTATION_0	1/* 0 degrees */
    153 #define VEN_ROTATION_90	2/* 90 degrees */
    154 #define VEN_ROTATION_180	3/* 180 degrees */
    155 #define VEN_ROTATION_270	4/* 270 degrees */
    156 
    157 /*IOCTL timeout values*/
    158 #define VEN_TIMEOUT_INFINITE	0xffffffff
    159 
    160 /*Different allowed intra refresh modes.*/
    161 #define VEN_IR_OFF	1
    162 #define VEN_IR_CYCLIC	2
    163 #define VEN_IR_RANDOM	3
    164 
    165 /*IOCTL BASE CODES Not to be used directly by the client.*/
    166 /* Base value for ioctls that are not related to encoder configuration.*/
    167 #define VEN_IOCTLBASE_NENC	0x800
    168 /* Base value for encoder configuration ioctls*/
    169 #define VEN_IOCTLBASE_ENC	0x850
    170 
    171 struct venc_ioctl_msg{
    172 	void __user *in;
    173 	void __user *out;
    174 };
    175 
    176 /*NON ENCODER CONFIGURATION IOCTLs*/
    177 
    178 /*IOCTL params:SET: InputData - unsigned long, OutputData - NULL*/
    179 #define VEN_IOCTL_SET_INTF_VERSION \
    180 	_IOW(VEN_IOCTLBASE_NENC, 0, struct venc_ioctl_msg)
    181 
    182 /*IOCTL params:CMD: InputData - venc_timeout, OutputData - venc_msg*/
    183 #define VEN_IOCTL_CMD_READ_NEXT_MSG \
    184 	_IOWR(VEN_IOCTLBASE_NENC, 1, struct venc_ioctl_msg)
    185 
    186 /*IOCTL params:CMD: InputData - NULL, OutputData - NULL*/
    187 #define VEN_IOCTL_CMD_STOP_READ_MSG	_IO(VEN_IOCTLBASE_NENC, 2)
    188 
    189 /*IOCTL params:SET: InputData - venc_allocatorproperty, OutputData - NULL
    190  GET: InputData - NULL, OutputData - venc_allocatorproperty*/
    191 #define VEN_IOCTL_SET_INPUT_BUFFER_REQ \
    192 	_IOW(VEN_IOCTLBASE_NENC, 3, struct venc_ioctl_msg)
    193 #define VEN_IOCTL_GET_INPUT_BUFFER_REQ \
    194 	_IOR(VEN_IOCTLBASE_NENC, 4, struct venc_ioctl_msg)
    195 
    196 /*IOCTL params:CMD: InputData - venc_bufferpayload, OutputData - NULL*/
    197 #define VEN_IOCTL_CMD_ALLOC_INPUT_BUFFER \
    198 	_IOW(VEN_IOCTLBASE_NENC, 5, struct venc_ioctl_msg)
    199 
    200 /*IOCTL params:CMD: InputData - venc_bufferpayload, OutputData - NULL*/
    201 #define VEN_IOCTL_SET_INPUT_BUFFER \
    202 	_IOW(VEN_IOCTLBASE_NENC, 6, struct venc_ioctl_msg)
    203 
    204 /*IOCTL params: CMD: InputData - venc_bufferpayload, OutputData - NULL*/
    205 #define VEN_IOCTL_CMD_FREE_INPUT_BUFFER \
    206 	_IOW(VEN_IOCTLBASE_NENC, 7, struct venc_ioctl_msg)
    207 
    208 /*IOCTL params:SET: InputData - venc_allocatorproperty, OutputData - NULL
    209  GET: InputData - NULL, OutputData - venc_allocatorproperty*/
    210 #define VEN_IOCTL_SET_OUTPUT_BUFFER_REQ \
    211 	_IOW(VEN_IOCTLBASE_NENC, 8, struct venc_ioctl_msg)
    212 #define VEN_IOCTL_GET_OUTPUT_BUFFER_REQ \
    213 	_IOR(VEN_IOCTLBASE_NENC, 9, struct venc_ioctl_msg)
    214 
    215 /*IOCTL params:CMD: InputData - venc_bufferpayload, OutputData - NULL*/
    216 #define VEN_IOCTL_CMD_ALLOC_OUTPUT_BUFFER \
    217 	_IOW(VEN_IOCTLBASE_NENC, 10, struct venc_ioctl_msg)
    218 
    219 
    220 /*IOCTL params:CMD: InputData - venc_bufferpayload, OutputData - NULL*/
    221 #define VEN_IOCTL_SET_OUTPUT_BUFFER \
    222 	_IOW(VEN_IOCTLBASE_NENC, 11, struct venc_ioctl_msg)
    223 
    224 /*IOCTL params:CMD: InputData - venc_bufferpayload, OutputData - NULL.*/
    225 #define VEN_IOCTL_CMD_FREE_OUTPUT_BUFFER \
    226 	_IOW(VEN_IOCTLBASE_NENC, 12, struct venc_ioctl_msg)
    227 
    228 
    229 /* Asynchronous respone message code:* VEN_MSG_START*/
    230 #define VEN_IOCTL_CMD_START	_IO(VEN_IOCTLBASE_NENC, 13)
    231 
    232 
    233 /*IOCTL params:CMD: InputData - venc_buffer, OutputData - NULL
    234  Asynchronous respone message code:VEN_MSG_INPUT_BUFFER_DONE*/
    235 #define VEN_IOCTL_CMD_ENCODE_FRAME \
    236 	_IOW(VEN_IOCTLBASE_NENC, 14, struct venc_ioctl_msg)
    237 
    238 
    239 /*IOCTL params:CMD: InputData - venc_buffer, OutputData - NULL
    240  Asynchronous response message code:VEN_MSG_OUTPUT_BUFFER_DONE*/
    241 #define VEN_IOCTL_CMD_FILL_OUTPUT_BUFFER \
    242 	_IOW(VEN_IOCTLBASE_NENC, 15, struct venc_ioctl_msg)
    243 
    244 /*IOCTL params:CMD: InputData - venc_bufferflush, OutputData - NULL
    245  * Asynchronous response message code:VEN_MSG_INPUT_BUFFER_DONE*/
    246 #define VEN_IOCTL_CMD_FLUSH \
    247 	_IOW(VEN_IOCTLBASE_NENC, 16, struct venc_ioctl_msg)
    248 
    249 
    250 /*Asynchronous respone message code:VEN_MSG_PAUSE*/
    251 #define VEN_IOCTL_CMD_PAUSE	_IO(VEN_IOCTLBASE_NENC, 17)
    252 
    253 /*Asynchronous respone message code:VEN_MSG_RESUME*/
    254 #define VEN_IOCTL_CMD_RESUME _IO(VEN_IOCTLBASE_NENC, 18)
    255 
    256 /* Asynchronous respone message code:VEN_MSG_STOP*/
    257 #define VEN_IOCTL_CMD_STOP _IO(VEN_IOCTLBASE_NENC, 19)
    258 
    259 #define VEN_IOCTL_SET_RECON_BUFFER \
    260 	_IOW(VEN_IOCTLBASE_NENC, 20, struct venc_ioctl_msg)
    261 
    262 #define VEN_IOCTL_FREE_RECON_BUFFER \
    263 	_IOW(VEN_IOCTLBASE_NENC, 21, struct venc_ioctl_msg)
    264 
    265 #define VEN_IOCTL_GET_RECON_BUFFER_SIZE \
    266 	_IOW(VEN_IOCTLBASE_NENC, 22, struct venc_ioctl_msg)
    267 
    268 
    269 
    270 /*ENCODER PROPERTY CONFIGURATION & CAPABILITY IOCTLs*/
    271 
    272 /*IOCTL params:SET: InputData - venc_basecfg, OutputData - NULL
    273  GET: InputData - NULL, OutputData - venc_basecfg*/
    274 #define VEN_IOCTL_SET_BASE_CFG \
    275 	_IOW(VEN_IOCTLBASE_ENC, 1, struct venc_ioctl_msg)
    276 #define VEN_IOCTL_GET_BASE_CFG \
    277 	_IOR(VEN_IOCTLBASE_ENC, 2, struct venc_ioctl_msg)
    278 
    279 /*IOCTL params:SET: InputData - venc_switch, OutputData - NULL
    280   GET: InputData - NULL, OutputData - venc_switch*/
    281 #define VEN_IOCTL_SET_LIVE_MODE \
    282 	_IOW(VEN_IOCTLBASE_ENC, 3, struct venc_ioctl_msg)
    283 #define VEN_IOCTL_GET_LIVE_MODE \
    284 	_IOR(VEN_IOCTLBASE_ENC, 4, struct venc_ioctl_msg)
    285 
    286 
    287 /*IOCTL params:SET: InputData - venc_profile, OutputData - NULL
    288   GET: InputData - NULL, OutputData - venc_profile*/
    289 #define VEN_IOCTL_SET_CODEC_PROFILE \
    290 	_IOW(VEN_IOCTLBASE_ENC, 5, struct venc_ioctl_msg)
    291 #define VEN_IOCTL_GET_CODEC_PROFILE \
    292 	_IOR(VEN_IOCTLBASE_ENC, 6, struct venc_ioctl_msg)
    293 
    294 
    295 /*IOCTL params:SET: InputData - ven_profilelevel, OutputData - NULL
    296   GET: InputData - NULL, OutputData - ven_profilelevel*/
    297 #define VEN_IOCTL_SET_PROFILE_LEVEL \
    298 	_IOW(VEN_IOCTLBASE_ENC, 7, struct venc_ioctl_msg)
    299 
    300 #define VEN_IOCTL_GET_PROFILE_LEVEL \
    301 	_IOR(VEN_IOCTLBASE_ENC, 8, struct venc_ioctl_msg)
    302 
    303 /*IOCTL params:SET: InputData - venc_switch, OutputData - NULL
    304  GET: InputData - NULL, OutputData - venc_switch*/
    305 #define VEN_IOCTL_SET_SHORT_HDR \
    306 	_IOW(VEN_IOCTLBASE_ENC, 9, struct venc_ioctl_msg)
    307 #define VEN_IOCTL_GET_SHORT_HDR \
    308 	_IOR(VEN_IOCTLBASE_ENC, 10, struct venc_ioctl_msg)
    309 
    310 
    311 /*IOCTL params: SET: InputData - venc_sessionqp, OutputData - NULL
    312   GET: InputData - NULL, OutputData - venc_sessionqp*/
    313 #define VEN_IOCTL_SET_SESSION_QP \
    314 	_IOW(VEN_IOCTLBASE_ENC, 11, struct venc_ioctl_msg)
    315 #define VEN_IOCTL_GET_SESSION_QP \
    316 	_IOR(VEN_IOCTLBASE_ENC, 12, struct venc_ioctl_msg)
    317 
    318 
    319 /*IOCTL params:SET: InputData - venc_intraperiod, OutputData - NULL
    320   GET: InputData - NULL, OutputData - venc_intraperiod*/
    321 #define VEN_IOCTL_SET_INTRA_PERIOD \
    322 	_IOW(VEN_IOCTLBASE_ENC, 13, struct venc_ioctl_msg)
    323 #define VEN_IOCTL_GET_INTRA_PERIOD \
    324 	_IOR(VEN_IOCTLBASE_ENC, 14, struct venc_ioctl_msg)
    325 
    326 
    327 /* Request an Iframe*/
    328 #define VEN_IOCTL_CMD_REQUEST_IFRAME _IO(VEN_IOCTLBASE_ENC, 15)
    329 
    330 /*IOCTL params:GET: InputData - NULL, OutputData - venc_capability*/
    331 #define VEN_IOCTL_GET_CAPABILITY \
    332 	_IOR(VEN_IOCTLBASE_ENC, 16, struct venc_ioctl_msg)
    333 
    334 
    335 /*IOCTL params:GET: InputData - NULL, OutputData - venc_seqheader*/
    336 #define VEN_IOCTL_GET_SEQUENCE_HDR \
    337 	_IOR(VEN_IOCTLBASE_ENC, 17, struct venc_ioctl_msg)
    338 
    339 /*IOCTL params:SET: InputData - venc_entropycfg, OutputData - NULL
    340  GET: InputData - NULL, OutputData - venc_entropycfg*/
    341 #define VEN_IOCTL_SET_ENTROPY_CFG \
    342 	_IOW(VEN_IOCTLBASE_ENC, 18, struct venc_ioctl_msg)
    343 #define VEN_IOCTL_GET_ENTROPY_CFG \
    344 	_IOR(VEN_IOCTLBASE_ENC, 19, struct venc_ioctl_msg)
    345 
    346 /*IOCTL params:SET: InputData - venc_dbcfg, OutputData - NULL
    347  GET: InputData - NULL, OutputData - venc_dbcfg*/
    348 #define VEN_IOCTL_SET_DEBLOCKING_CFG \
    349 	_IOW(VEN_IOCTLBASE_ENC, 20, struct venc_ioctl_msg)
    350 #define VEN_IOCTL_GET_DEBLOCKING_CFG \
    351 	_IOR(VEN_IOCTLBASE_ENC, 21, struct venc_ioctl_msg)
    352 
    353 
    354 /*IOCTL params:SET: InputData - venc_intrarefresh, OutputData - NULL
    355   GET: InputData - NULL, OutputData - venc_intrarefresh*/
    356 #define VEN_IOCTL_SET_INTRA_REFRESH \
    357 	_IOW(VEN_IOCTLBASE_ENC, 22, struct venc_ioctl_msg)
    358 #define VEN_IOCTL_GET_INTRA_REFRESH \
    359 	_IOR(VEN_IOCTLBASE_ENC, 23, struct venc_ioctl_msg)
    360 
    361 
    362 /*IOCTL params:SET: InputData - venc_multiclicecfg, OutputData - NULL
    363   GET: InputData - NULL, OutputData - venc_multiclicecfg*/
    364 #define VEN_IOCTL_SET_MULTI_SLICE_CFG \
    365 	_IOW(VEN_IOCTLBASE_ENC, 24, struct venc_ioctl_msg)
    366 #define VEN_IOCTL_GET_MULTI_SLICE_CFG \
    367 	_IOR(VEN_IOCTLBASE_ENC, 25, struct venc_ioctl_msg)
    368 
    369 /*IOCTL params:SET: InputData - venc_ratectrlcfg, OutputData - NULL
    370  GET: InputData - NULL, OutputData - venc_ratectrlcfg*/
    371 #define VEN_IOCTL_SET_RATE_CTRL_CFG \
    372 	_IOW(VEN_IOCTLBASE_ENC, 26, struct venc_ioctl_msg)
    373 #define VEN_IOCTL_GET_RATE_CTRL_CFG \
    374 	_IOR(VEN_IOCTLBASE_ENC, 27, struct venc_ioctl_msg)
    375 
    376 
    377 /*IOCTL params:SET: InputData - venc_voptimingcfg, OutputData - NULL
    378   GET: InputData - NULL, OutputData - venc_voptimingcfg*/
    379 #define VEN_IOCTL_SET_VOP_TIMING_CFG \
    380 	_IOW(VEN_IOCTLBASE_ENC, 28, struct venc_ioctl_msg)
    381 #define VEN_IOCTL_GET_VOP_TIMING_CFG \
    382 	_IOR(VEN_IOCTLBASE_ENC, 29, struct venc_ioctl_msg)
    383 
    384 
    385 /*IOCTL params:SET: InputData - venc_framerate, OutputData - NULL
    386  GET: InputData - NULL, OutputData - venc_framerate*/
    387 #define VEN_IOCTL_SET_FRAME_RATE \
    388 	_IOW(VEN_IOCTLBASE_ENC, 30, struct venc_ioctl_msg)
    389 #define VEN_IOCTL_GET_FRAME_RATE \
    390 	_IOR(VEN_IOCTLBASE_ENC, 31, struct venc_ioctl_msg)
    391 
    392 
    393 /*IOCTL params:SET: InputData - venc_targetbitrate, OutputData - NULL
    394  GET: InputData - NULL, OutputData - venc_targetbitrate*/
    395 #define VEN_IOCTL_SET_TARGET_BITRATE \
    396 	_IOW(VEN_IOCTLBASE_ENC, 32, struct venc_ioctl_msg)
    397 #define VEN_IOCTL_GET_TARGET_BITRATE \
    398 	_IOR(VEN_IOCTLBASE_ENC, 33, struct venc_ioctl_msg)
    399 
    400 
    401 /*IOCTL params:SET: InputData - venc_rotation, OutputData - NULL
    402   GET: InputData - NULL, OutputData - venc_rotation*/
    403 #define VEN_IOCTL_SET_ROTATION \
    404 	_IOW(VEN_IOCTLBASE_ENC, 34, struct venc_ioctl_msg)
    405 #define VEN_IOCTL_GET_ROTATION \
    406 	_IOR(VEN_IOCTLBASE_ENC, 35, struct venc_ioctl_msg)
    407 
    408 
    409 /*IOCTL params:SET: InputData - venc_headerextension, OutputData - NULL
    410  GET: InputData - NULL, OutputData - venc_headerextension*/
    411 #define VEN_IOCTL_SET_HEC \
    412 	_IOW(VEN_IOCTLBASE_ENC, 36, struct venc_ioctl_msg)
    413 #define VEN_IOCTL_GET_HEC \
    414 	_IOR(VEN_IOCTLBASE_ENC, 37, struct venc_ioctl_msg)
    415 
    416 /*IOCTL params:SET: InputData - venc_switch, OutputData - NULL
    417  GET: InputData - NULL, OutputData - venc_switch*/
    418 #define VEN_IOCTL_SET_DATA_PARTITION \
    419 	_IOW(VEN_IOCTLBASE_ENC, 38, struct venc_ioctl_msg)
    420 #define VEN_IOCTL_GET_DATA_PARTITION \
    421 	_IOR(VEN_IOCTLBASE_ENC, 39, struct venc_ioctl_msg)
    422 
    423 /*IOCTL params:SET: InputData - venc_switch, OutputData - NULL
    424  GET: InputData - NULL, OutputData - venc_switch*/
    425 #define VEN_IOCTL_SET_RVLC \
    426 	_IOW(VEN_IOCTLBASE_ENC, 40, struct venc_ioctl_msg)
    427 #define VEN_IOCTL_GET_RVLC \
    428 	_IOR(VEN_IOCTLBASE_ENC, 41, struct venc_ioctl_msg)
    429 
    430 
    431 /*IOCTL params:SET: InputData - venc_switch, OutputData - NULL
    432  GET: InputData - NULL, OutputData - venc_switch*/
    433 #define VEN_IOCTL_SET_AC_PREDICTION \
    434 	_IOW(VEN_IOCTLBASE_ENC, 42, struct venc_ioctl_msg)
    435 #define VEN_IOCTL_GET_AC_PREDICTION \
    436 	_IOR(VEN_IOCTLBASE_ENC, 43, struct venc_ioctl_msg)
    437 
    438 
    439 /*IOCTL params:SET: InputData - venc_qprange, OutputData - NULL
    440  GET: InputData - NULL, OutputData - venc_qprange*/
    441 #define VEN_IOCTL_SET_QP_RANGE \
    442 	_IOW(VEN_IOCTLBASE_ENC, 44, struct venc_ioctl_msg)
    443 #define VEN_IOCTL_GET_QP_RANGE \
    444 	_IOR(VEN_IOCTLBASE_ENC, 45, struct venc_ioctl_msg)
    445 
    446 #define VEN_IOCTL_GET_NUMBER_INSTANCES \
    447 	_IOR(VEN_IOCTLBASE_ENC, 46, struct venc_ioctl_msg)
    448 
    449 #define VEN_IOCTL_SET_METABUFFER_MODE \
    450 	_IOW(VEN_IOCTLBASE_ENC, 47, struct venc_ioctl_msg)
    451 
    452 
    453 /*IOCTL params:SET: InputData - unsigned int, OutputData - NULL.*/
    454 #define VEN_IOCTL_SET_EXTRADATA \
    455 	_IOW(VEN_IOCTLBASE_ENC, 48, struct venc_ioctl_msg)
    456 /*IOCTL params:GET: InputData - NULL, OutputData - unsigned int.*/
    457 #define VEN_IOCTL_GET_EXTRADATA \
    458 	_IOR(VEN_IOCTLBASE_ENC, 49, struct venc_ioctl_msg)
    459 
    460 /*IOCTL params:SET: InputData - NULL, OutputData - NULL.*/
    461 #define VEN_IOCTL_SET_SLICE_DELIVERY_MODE \
    462 	_IO(VEN_IOCTLBASE_ENC, 50)
    463 
    464 #define VEN_IOCTL_SET_H263_PLUSPTYPE \
    465 	_IOW(VEN_IOCTLBASE_ENC, 51, struct venc_ioctl_msg)
    466 
    467 /*IOCTL params:SET: InputData - venc_range, OutputData - NULL.*/
    468 #define VEN_IOCTL_SET_CAPABILITY_LTRCOUNT \
    469 	_IOW(VEN_IOCTLBASE_ENC, 52, struct venc_ioctl_msg)
    470 /*IOCTL params:GET: InputData - NULL, OutputData - venc_range.*/
    471 #define VEN_IOCTL_GET_CAPABILITY_LTRCOUNT \
    472 	_IOR(VEN_IOCTLBASE_ENC, 53, struct venc_ioctl_msg)
    473 
    474 /*IOCTL params:SET: InputData - venc_ltrmode, OutputData - NULL.*/
    475 #define VEN_IOCTL_SET_LTRMODE \
    476 	_IOW(VEN_IOCTLBASE_ENC, 54, struct venc_ioctl_msg)
    477 /*IOCTL params:GET: InputData - NULL, OutputData - venc_ltrmode.*/
    478 #define VEN_IOCTL_GET_LTRMODE \
    479 	_IOR(VEN_IOCTLBASE_ENC, 55, struct venc_ioctl_msg)
    480 
    481 /*IOCTL params:SET: InputData - venc_ltrcount, OutputData - NULL.*/
    482 #define VEN_IOCTL_SET_LTRCOUNT \
    483 	_IOW(VEN_IOCTLBASE_ENC, 56, struct venc_ioctl_msg)
    484 /*IOCTL params:GET: InputData - NULL, OutputData - venc_ltrcount.*/
    485 #define VEN_IOCTL_GET_LTRCOUNT \
    486 	_IOR(VEN_IOCTLBASE_ENC, 57, struct venc_ioctl_msg)
    487 
    488 /*IOCTL params:SET: InputData - venc_ltrperiod, OutputData - NULL.*/
    489 #define VEN_IOCTL_SET_LTRPERIOD \
    490 	_IOW(VEN_IOCTLBASE_ENC, 58, struct venc_ioctl_msg)
    491 /*IOCTL params:GET: InputData - NULL, OutputData - venc_ltrperiod.*/
    492 #define VEN_IOCTL_GET_LTRPERIOD \
    493 	_IOR(VEN_IOCTLBASE_ENC, 59, struct venc_ioctl_msg)
    494 
    495 /*IOCTL params:SET: InputData - venc_ltruse, OutputData - NULL.*/
    496 #define VEN_IOCTL_SET_LTRUSE \
    497 	_IOW(VEN_IOCTLBASE_ENC, 60, struct venc_ioctl_msg)
    498 /*IOCTL params:GET: InputData - NULL, OutputData - venc_ltruse.*/
    499 #define VEN_IOCTL_GET_LTRUSE \
    500 	_IOR(VEN_IOCTLBASE_ENC, 61, struct venc_ioctl_msg)
    501 
    502 /*IOCTL params:SET: InputData - venc_ltrmark, OutputData - NULL.*/
    503 #define VEN_IOCTL_SET_LTRMARK \
    504 	_IOW(VEN_IOCTLBASE_ENC, 62, struct venc_ioctl_msg)
    505 /*IOCTL params:GET: InputData - NULL, OutputData - venc_ltrmark.*/
    506 #define VEN_IOCTL_GET_LTRMARK \
    507 	_IOR(VEN_IOCTLBASE_ENC, 63, struct venc_ioctl_msg)
    508 
    509 /*IOCTL params:SET: InputData - unsigned int, OutputData - NULL*/
    510 #define VEN_IOCTL_SET_SPS_PPS_FOR_IDR \
    511 	_IOW(VEN_IOCTLBASE_ENC, 64, struct venc_ioctl_msg)
    512 
    513 struct venc_range {
    514 	unsigned long	max;
    515 	unsigned long	min;
    516 	unsigned long	step_size;
    517 };
    518 
    519 struct venc_switch{
    520 	unsigned char	status;
    521 };
    522 
    523 struct venc_allocatorproperty{
    524 	unsigned long	 mincount;
    525 	unsigned long	 maxcount;
    526 	unsigned long	 actualcount;
    527 	unsigned long	 datasize;
    528 	unsigned long	 suffixsize;
    529 	unsigned long	 alignment;
    530 	unsigned long	 bufpoolid;
    531 };
    532 
    533 struct venc_bufferpayload{
    534 	unsigned char *pbuffer;
    535 	size_t	sz;
    536 	int	fd;
    537 	unsigned int	offset;
    538 	unsigned int	maped_size;
    539 	unsigned long	filled_len;
    540 };
    541 
    542 struct venc_buffer{
    543  unsigned char *ptrbuffer;
    544  unsigned long	sz;
    545  unsigned long	len;
    546  unsigned long	offset;
    547  long long	timestamp;
    548  unsigned long	flags;
    549  void	*clientdata;
    550 };
    551 
    552 struct venc_basecfg{
    553 	unsigned long	input_width;
    554 	unsigned long	input_height;
    555 	unsigned long	dvs_width;
    556 	unsigned long	dvs_height;
    557 	unsigned long	codectype;
    558 	unsigned long	fps_num;
    559 	unsigned long	fps_den;
    560 	unsigned long	targetbitrate;
    561 	unsigned long	inputformat;
    562 };
    563 
    564 struct venc_profile{
    565 	unsigned long	profile;
    566 };
    567 struct ven_profilelevel{
    568 	unsigned long	level;
    569 };
    570 
    571 struct venc_sessionqp{
    572 	unsigned long	iframeqp;
    573 	unsigned long	pframqp;
    574 };
    575 
    576 struct venc_qprange{
    577 	unsigned long	maxqp;
    578 	unsigned long	minqp;
    579 };
    580 
    581 struct venc_plusptype {
    582 	unsigned long	plusptype_enable;
    583 };
    584 
    585 struct venc_intraperiod{
    586 	unsigned long	num_pframes;
    587 	unsigned long	num_bframes;
    588 };
    589 struct venc_seqheader{
    590 	unsigned char *hdrbufptr;
    591 	unsigned long	bufsize;
    592 	unsigned long	hdrlen;
    593 };
    594 
    595 struct venc_capability{
    596 	unsigned long	codec_types;
    597 	unsigned long	maxframe_width;
    598 	unsigned long	maxframe_height;
    599 	unsigned long	maxtarget_bitrate;
    600 	unsigned long	maxframe_rate;
    601 	unsigned long	input_formats;
    602 	unsigned char	dvs;
    603 };
    604 
    605 struct venc_entropycfg{
    606 	unsigned longentropysel;
    607 	unsigned long	cabacmodel;
    608 };
    609 
    610 struct venc_dbcfg{
    611 	unsigned long	db_mode;
    612 	unsigned long	slicealpha_offset;
    613 	unsigned long	slicebeta_offset;
    614 };
    615 
    616 struct venc_intrarefresh{
    617 	unsigned long	irmode;
    618 	unsigned long	mbcount;
    619 };
    620 
    621 struct venc_multiclicecfg{
    622 	unsigned long	mslice_mode;
    623 	unsigned long	mslice_size;
    624 };
    625 
    626 struct venc_bufferflush{
    627 	unsigned long	flush_mode;
    628 };
    629 
    630 struct venc_ratectrlcfg{
    631 	unsigned long	rcmode;
    632 };
    633 
    634 struct	venc_voptimingcfg{
    635 	unsigned long	voptime_resolution;
    636 };
    637 struct venc_framerate{
    638 	unsigned long	fps_denominator;
    639 	unsigned long	fps_numerator;
    640 };
    641 
    642 struct venc_targetbitrate{
    643 	unsigned long	target_bitrate;
    644 };
    645 
    646 
    647 struct venc_rotation{
    648 	unsigned long	rotation;
    649 };
    650 
    651 struct venc_timeout{
    652 	 unsigned long	millisec;
    653 };
    654 
    655 struct venc_headerextension{
    656 	 unsigned long	header_extension;
    657 };
    658 
    659 struct venc_msg{
    660 	unsigned long	statuscode;
    661 	unsigned long	msgcode;
    662 	struct venc_buffer	buf;
    663 	unsigned long	msgdata_size;
    664 };
    665 
    666 struct venc_recon_addr{
    667 	unsigned char *pbuffer;
    668 	unsigned long buffer_size;
    669 	unsigned long pmem_fd;
    670 	unsigned long offset;
    671 };
    672 
    673 struct venc_recon_buff_size{
    674 	int width;
    675 	int height;
    676 	int size;
    677 	int alignment;
    678 };
    679 
    680 struct venc_ltrmode {
    681 	unsigned long   ltr_mode;
    682 };
    683 
    684 struct venc_ltrcount {
    685 	unsigned long   ltr_count;
    686 };
    687 
    688 struct venc_ltrperiod {
    689 	unsigned long   ltr_period;
    690 };
    691 
    692 struct venc_ltruse {
    693 	unsigned long   ltr_id;
    694 	unsigned long   ltr_frames;
    695 };
    696 
    697 #endif /* _MSM_VIDC_ENC_H_ */
    698