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