• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2021 Rockchip Electronics Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #ifndef __VPU_API_H__
17 #define __VPU_API_H__
18 
19 #include "rk_type.h"
20 
21 /**
22  * @brief rockchip media process interface
23  */
24 
25 #define VPU_API_NOPTS_VALUE (0x8000000000000000LL)
26 
27 /*
28  * bit definition of ColorType in structure VPU_FRAME
29  */
30 #define VPU_OUTPUT_FORMAT_TYPE_MASK (0x0000ffff)
31 #define VPU_OUTPUT_FORMAT_ARGB8888 (0x00000000)
32 #define VPU_OUTPUT_FORMAT_ABGR8888 (0x00000001)
33 #define VPU_OUTPUT_FORMAT_RGB888 (0x00000002)
34 #define VPU_OUTPUT_FORMAT_RGB565 (0x00000003)
35 #define VPU_OUTPUT_FORMAT_RGB555 (0x00000004)
36 #define VPU_OUTPUT_FORMAT_YUV420_SEMIPLANAR (0x00000005)
37 #define VPU_OUTPUT_FORMAT_YUV420_PLANAR (0x00000006)
38 #define VPU_OUTPUT_FORMAT_YUV422 (0x00000007)
39 #define VPU_OUTPUT_FORMAT_YUV444 (0x00000008)
40 #define VPU_OUTPUT_FORMAT_YCH420 (0x00000009)
41 #define VPU_OUTPUT_FORMAT_BIT_MASK (0x000f0000)
42 #define VPU_OUTPUT_FORMAT_BIT_8 (0x00000000)
43 #define VPU_OUTPUT_FORMAT_BIT_10 (0x00010000)
44 #define VPU_OUTPUT_FORMAT_BIT_12 (0x00020000)
45 #define VPU_OUTPUT_FORMAT_BIT_14 (0x00030000)
46 #define VPU_OUTPUT_FORMAT_BIT_16 (0x00040000)
47 #define VPU_OUTPUT_FORMAT_COLORSPACE_MASK (0x00f00000)
48 #define VPU_OUTPUT_FORMAT_COLORSPACE_BT709 (0x00100000)
49 #define VPU_OUTPUT_FORMAT_COLORSPACE_BT2020 (0x00200000)
50 #define VPU_OUTPUT_FORMAT_DYNCRANGE_MASK (0x0f000000)
51 #define VPU_OUTPUT_FORMAT_DYNCRANGE_SDR (0x00000000)
52 #define VPU_OUTPUT_FORMAT_DYNCRANGE_HDR10 (0x01000000)
53 #define VPU_OUTPUT_FORMAT_DYNCRANGE_HDR_HLG (0x02000000)
54 #define VPU_OUTPUT_FORMAT_DYNCRANGE_HDR_DOLBY (0x03000000)
55 
56 /**
57  * @brief input picture type
58  */
59 typedef enum {
60     ENC_INPUT_YUV420_PLANAR = 0,           /**< YYYY... UUUU... VVVV */
61     ENC_INPUT_YUV420_SEMIPLANAR = 1,       /**< YYYY... UVUVUV...    */
62     ENC_INPUT_YUV422_INTERLEAVED_YUYV = 2, /**< YUYVYUYV...          */
63     ENC_INPUT_YUV422_INTERLEAVED_UYVY = 3, /**< UYVYUYVY...          */
64     ENC_INPUT_RGB565 = 4,                  /**< 16-bit RGB           */
65     ENC_INPUT_BGR565 = 5,                  /**< 16-bit RGB           */
66     ENC_INPUT_RGB555 = 6,                  /**< 15-bit RGB           */
67     ENC_INPUT_BGR555 = 7,                  /**< 15-bit RGB           */
68     ENC_INPUT_RGB444 = 8,                  /**< 12-bit RGB           */
69     ENC_INPUT_BGR444 = 9,                  /**< 12-bit RGB           */
70     ENC_INPUT_RGB888 = 10,                 /**< 24-bit RGB           */
71     ENC_INPUT_BGR888 = 11,                 /**< 24-bit RGB           */
72     ENC_INPUT_RGB101010 = 12,              /**< 30-bit RGB           */
73     ENC_INPUT_BGR101010 = 13               /**< 30-bit RGB           */
74 } EncInputPictureType;
75 
76 typedef enum VPU_API_CMD {
77     VPU_API_ENC_SETCFG,
78     VPU_API_ENC_GETCFG,
79     VPU_API_ENC_SETFORMAT,
80     VPU_API_ENC_SETIDRFRAME,
81 
82     VPU_API_ENABLE_DEINTERLACE,
83     VPU_API_SET_VPUMEM_CONTEXT,
84     VPU_API_USE_PRESENT_TIME_ORDER,
85     VPU_API_SET_DEFAULT_WIDTH_HEIGH,
86     VPU_API_SET_INFO_CHANGE,
87     VPU_API_USE_FAST_MODE,
88     VPU_API_DEC_GET_STREAM_COUNT,
89     VPU_API_GET_VPUMEM_USED_COUNT,
90     VPU_API_GET_FRAME_INFO,
91     VPU_API_SET_OUTPUT_BLOCK,
92     VPU_API_GET_EOS_STATUS,
93     VPU_API_SET_OUTPUT_MODE,
94 
95     VPU_API_DEC_GET_DPB_SIZE = 0X100, // add by zhanghanmeng
96 
97     /* get sps/pps header */
98     VPU_API_GET_EXTRA_INFO = 0x200,
99 
100     VPU_API_SET_IMMEDIATE_OUT = 0x1000,
101     VPU_API_SET_PARSER_SPLIT_MODE, /* NOTE: should control before init */
102 
103     VPU_API_ENC_VEPU22_START = 0x2000,
104     VPU_API_ENC_SET_VEPU22_CFG,
105     VPU_API_ENC_GET_VEPU22_CFG,
106     VPU_API_ENC_SET_VEPU22_CTU_QP,
107     VPU_API_ENC_SET_VEPU22_ROI,
108 
109     /* mlvec dynamic configure */
110     VPU_API_ENC_MLVEC_CFG = 0x4000,
111     VPU_API_ENC_SET_MAX_TID,
112     VPU_API_ENC_SET_MARK_LTR,
113     VPU_API_ENC_SET_USE_LTR,
114     VPU_API_ENC_SET_FRAME_QP,
115     VPU_API_ENC_SET_BASE_LAYER_PID,
116 } VPU_API_CMD;
117 
118 typedef struct {
119     unsigned int TimeLow;
120     unsigned int TimeHigh;
121 } TIME_STAMP;
122 
123 typedef struct {
124     unsigned int CodecType;
125     unsigned int ImgWidth;
126     unsigned int ImgHeight;
127     unsigned int ImgHorStride;
128     unsigned int ImgVerStride;
129     unsigned int BufSize;
130 } VPU_GENERIC;
131 
132 typedef struct VPUMem {
133     unsigned int phy_addr;
134     unsigned int *vir_addr;
135     unsigned int size;
136     unsigned int *offset;
137 } VPUMemLinear_t;
138 
139 typedef struct tVPU_FRAME {
140     unsigned int FrameBusAddr[2]; // 0: Y address; 1: UV address;
141     unsigned int FrameWidth;      // buffer horizontal stride
142     unsigned int FrameHeight;     // buffer vertical   stride
143     unsigned int OutputWidth;     // deprecated
144     unsigned int OutputHeight;    // deprecated
145     unsigned int DisplayWidth;    // valid width  for display
146     unsigned int DisplayHeight;   // valid height for display
147     unsigned int CodingType;
148     unsigned int FrameType; // frame; top_field_first; bot_field_first
149     unsigned int ColorType;
150     unsigned int DecodeFrmNum;
151     TIME_STAMP ShowTime;
152     unsigned int ErrorInfo; // error information
153     unsigned int employ_cnt;
154     VPUMemLinear_t vpumem;
155     struct tVPU_FRAME *next_frame;
156     union {
157         struct {
158             unsigned int Res0[2];
159             struct {
160                 unsigned int ColorPrimaries : 8;
161                 unsigned int ColorTransfer : 8;
162                 unsigned int ColorCoeffs : 8;
163                 unsigned int ColorRange : 1;
164                 unsigned int Res1 : 7;
165             };
166 
167             unsigned int Res2;
168         };
169 
170         unsigned int Res[4];
171     };
172 } VPU_FRAME;
173 
174 typedef struct VideoPacket {
175     RK_S64 pts; /* with unit of us */
176     RK_S64 dts; /* with unit of us */
177     unsigned char *data;
178     signed int size;
179     unsigned int capability;
180     unsigned int nFlags;
181 } VideoPacket_t;
182 
183 typedef struct DecoderOut {
184     unsigned char *data;
185     unsigned int size;
186     RK_S64 timeUs;
187     signed int nFlags;
188 } DecoderOut_t;
189 
190 typedef struct ParserOut {
191     unsigned char *data;
192     unsigned int size;
193     RK_S64 timeUs;
194     unsigned int nFlags;
195     unsigned int width;
196     unsigned int height;
197 } ParserOut_t;
198 
199 typedef struct EncInputStream {
200     unsigned char *buf;
201     signed int size;
202     unsigned int bufPhyAddr;
203     RK_S64 timeUs;
204     unsigned int nFlags;
205 } EncInputStream_t;
206 
207 typedef struct EncoderOut {
208     unsigned char *data;
209     signed int size;
210     RK_S64 timeUs;
211     signed int keyFrame;
212 } EncoderOut_t;
213 
214 /*
215  * @brief Enumeration used to define the possible video compression codings.
216  * @note  This essentially refers to file extensions. If the coding is
217  *        being used to specify the ENCODE type, then additional work
218  *        must be done to configure the exact flavor of the compression
219  *        to be used.  For decode cases where the user application can
220  *        not differentiate between MPEG-4 and H.264 bit streams, it is
221  *        up to the codec to handle this.
222  *
223  *        sync with the omx_video.h
224  */
225 typedef enum OMX_RK_VIDEO_CODINGTYPE {
226     OMX_RK_VIDEO_CodingUnused,           /**< Value when coding is N/A */
227     OMX_RK_VIDEO_CodingAutoDetect,       /**< Autodetection of coding type */
228     OMX_RK_VIDEO_CodingMPEG2,            /**< AKA: H.262 */
229     OMX_RK_VIDEO_CodingH263,             /**< H.263 */
230     OMX_RK_VIDEO_CodingMPEG4,            /**< MPEG-4 */
231     OMX_RK_VIDEO_CodingWMV,              /**< Windows Media Video (WMV1,WMV2,WMV3)*/
232     OMX_RK_VIDEO_CodingRV,               /**< all versions of Real Video */
233     OMX_RK_VIDEO_CodingAVC,              /**< H.264/AVC */
234     OMX_RK_VIDEO_CodingMJPEG,            /**< Motion JPEG */
235     OMX_RK_VIDEO_CodingVP8,              /**< VP8 */
236     OMX_RK_VIDEO_CodingVP9,              /**< VP9 */
237     OMX_RK_VIDEO_CodingVC1 = 0x01000000, /**< Windows Media Video (WMV1,WMV2,WMV3)*/
238     OMX_RK_VIDEO_CodingFLV1,             /**< Sorenson H.263 */
239     OMX_RK_VIDEO_CodingDIVX3,            /**< DIVX3 */
240     OMX_RK_VIDEO_CodingVP6,
241     OMX_RK_VIDEO_CodingHEVC, /**< H.265/HEVC */
242     OMX_RK_VIDEO_CodingAVS,  /**< AVS+ */
243     OMX_RK_VIDEO_CodingKhronosExtensions = 0x6F000000,
244     OMX_RK_VIDEO_CodingVendorStartUnused = 0x7F000000,
245     OMX_RK_VIDEO_CodingMax = 0x7FFFFFFF
246 } OMX_RK_VIDEO_CODINGTYPE;
247 
248 typedef enum CODEC_TYPE {
249     CODEC_NONE,
250     CODEC_DECODER,
251     CODEC_ENCODER,
252     CODEC_BUTT,
253 } CODEC_TYPE;
254 
255 typedef enum VPU_API_ERR {
256     VPU_API_OK = 0,
257     VPU_API_ERR_UNKNOW = -1,
258     VPU_API_ERR_BASE = -1000,
259     VPU_API_ERR_LIST_STREAM = VPU_API_ERR_BASE - 1,
260     VPU_API_ERR_INIT = VPU_API_ERR_BASE - 2,
261     VPU_API_ERR_VPU_CODEC_INIT = VPU_API_ERR_BASE - 3,
262     VPU_API_ERR_STREAM = VPU_API_ERR_BASE - 4,
263     VPU_API_ERR_FATAL_THREAD = VPU_API_ERR_BASE - 5,
264     VPU_API_EOS_STREAM_REACHED = VPU_API_ERR_BASE - 11,
265 
266     VPU_API_ERR_BUTT,
267 } VPU_API_ERR;
268 
269 typedef enum VPU_FRAME_ERR {
270     VPU_FRAME_ERR_UNKNOW = 0x0001,
271     VPU_FRAME_ERR_UNSUPPORT = 0x0002,
272 } VPU_FRAME_ERR;
273 
274 typedef struct EncParameter {
275     signed int width;
276     signed int height;
277     signed int rc_mode; /* 0 - CQP mode; 1 - CBR mode; 2 - FIXQP mode */
278     signed int bitRate; /* target bitrate */
279     signed int framerate;
280     signed int qp;
281     signed int enableCabac;
282     signed int cabacInitIdc;
283     signed int format;
284     signed int intraPicRate;
285     signed int framerateout;
286     signed int profileIdc;
287     signed int levelIdc;
288     signed int reserved[3];
289 } EncParameter_t;
290 
291 typedef struct EXtraCfg {
292     signed int vc1extra_size;
293     signed int vp6codeid;
294     signed int tsformat;
295     unsigned int ori_vpu; /* use origin vpu framework */
296     /* below used in decode */
297     unsigned int mpp_mode;   /* use mpp framework */
298     unsigned int bit_depth;  /* 8 or 10 bit */
299     unsigned int yuv_format; /* 0:420 1:422 2:444 */
300     unsigned int reserved[16];
301 } EXtraCfg_t;
302 
303 /**
304  * @brief vpu function interface
305  */
306 typedef struct VpuCodecContext {
307     void *vpuApiObj;
308 
309     CODEC_TYPE codecType;
310     OMX_RK_VIDEO_CODINGTYPE videoCoding;
311 
312     unsigned int width;
313     unsigned int height;
314     void *extradata;
315     signed int extradata_size;
316 
317     unsigned char enableparsing;
318 
319     signed int no_thread;
320     EXtraCfg_t extra_cfg;
321 
322     void *private_data;
323 
324     /*
325      ** 1: error state(not working)  0: working
326      */
327     signed int decoder_err;
328 
329     /**
330      * Allocate and initialize an VpuCodecContext.
331      *
332      * @param ctx The context of vpu api, allocated in this function.
333      * @param extraData The extra data of codec, some codecs need / can
334      *        use extradata like Huffman tables, also live VC1 codec can
335      *        use extradata to initialize itself.
336      * @param extra_size The size of extra data.
337      *
338      * @return 0 for init success, others for failure.
339      * @note check whether ctx has been allocated success after you do init.
340      */
341     signed int (*init)(struct VpuCodecContext *ctx, unsigned char *extraData, unsigned int extra_size);
342     /**
343      * @brief both send video stream packet to decoder and get video frame from
344      *        decoder at the same time
345      * @param ctx The context of vpu codec
346      * @param pkt[in] Stream to be decoded
347      * @param aDecOut[out] Decoding frame
348      * @return 0 for decode success, others for failure.
349      */
350     signed int (*decode)(struct VpuCodecContext *ctx, VideoPacket_t *pkt, DecoderOut_t *aDecOut);
351     /**
352      * @brief both send video frame to encoder and get encoded video stream from
353      *        encoder at the same time.
354      * @param ctx The context of vpu codec
355      * @param aEncInStrm[in] Frame to be encoded
356      * @param aEncOut[out] Encoding stream
357      * @return 0 for encode success, others for failure.
358      */
359     signed int (*encode)(struct VpuCodecContext *ctx, EncInputStream_t *aEncInStrm, EncoderOut_t *aEncOut);
360     /**
361      * @brief flush codec while do fast forward playing.
362      * @param ctx The context of vpu codec
363      * @return 0 for flush success, others for failure.
364      */
365     signed int (*flush)(struct VpuCodecContext *ctx);
366     signed int (*control)(struct VpuCodecContext *ctx, VPU_API_CMD cmdType, void *param);
367     /**
368      * @brief send video stream packet to decoder only, async interface
369      * @param ctx The context of vpu codec
370      * @param pkt Stream to be decoded
371      * @return 0 for success, others for failure.
372      */
373     signed int (*decode_sendstream)(struct VpuCodecContext *ctx, VideoPacket_t *pkt);
374     /**
375      * @brief get video frame from decoder only, async interface
376      * @param ctx The context of vpu codec
377      * @param aDecOut Decoding frame
378      * @return 0 for success, others for failure.
379      */
380     signed int (*decode_getframe)(struct VpuCodecContext *ctx, DecoderOut_t *aDecOut);
381     /**
382      * @brief send video frame to encoder only, async interface
383      * @param ctx The context of vpu codec
384      * @param aEncInStrm Frame to be encoded
385      * @return 0 for success, others for failure.
386      */
387     signed int (*encoder_sendframe)(struct VpuCodecContext *ctx, EncInputStream_t *aEncInStrm);
388     /**
389      * @brief get encoded video packet from encoder only, async interface
390      * @param ctx The context of vpu codec
391      * @param aEncOut Encoding stream
392      * @return 0 for success, others for failure.
393      */
394     signed int (*encoder_getstream)(struct VpuCodecContext *ctx, EncoderOut_t *aEncOut);
395 } VpuCodecContext_t;
396 
397 /* allocated vpu codec context */
398 #ifdef __cplusplus
399 extern "C" {
400 #endif
401 
402 /**
403  * @brief open context of vpu
404  * @param ctx pointer of vpu codec context
405  */
406 signed int vpu_open_context(struct VpuCodecContext **ctx);
407 /**
408  * @brief close context of vpu
409  * @param ctx pointer of vpu codec context
410  */
411 signed int vpu_close_context(struct VpuCodecContext **ctx);
412 
413 #ifdef __cplusplus
414 }
415 #endif
416 
417 /*
418  * vpu_mem api
419  */
420 #define vpu_display_mem_pool_FIELDS                                                                                    \
421     signed int (*commit_hdl)(vpu_display_mem_pool * p, signed int hdl, signed int size);                               \
422     void *(*get_free)(vpu_display_mem_pool * p);                                                                       \
423     signed int (*inc_used)(vpu_display_mem_pool * p, void *hdl);                                                       \
424     signed int (*put_used)(vpu_display_mem_pool * p, void *hdl);                                                       \
425     signed int (*reset)(vpu_display_mem_pool * p);                                                                     \
426     signed int (*get_unused_num)(vpu_display_mem_pool * p);                                                            \
427     signed int buff_size;                                                                                              \
428     float version;                                                                                                     \
429     signed int res[18]
430 
431 typedef struct vpu_display_mem_pool vpu_display_mem_pool;
432 
433 struct vpu_display_mem_pool {
434     vpu_display_mem_pool_FIELDS;
435 };
436 
437 #ifdef __cplusplus
438 extern "C" {
439 #endif
440 
441 /*
442  * vpu memory handle interface
443  */
444 signed int VPUMemJudgeIommu(void);
445 signed int VPUMallocLinear(VPUMemLinear_t *p, unsigned int size);
446 signed int VPUFreeLinear(VPUMemLinear_t *p);
447 signed int VPUMemDuplicate(VPUMemLinear_t *dst, VPUMemLinear_t *src);
448 signed int VPUMemLink(VPUMemLinear_t *p);
449 signed int VPUMemFlush(VPUMemLinear_t *p);
450 signed int VPUMemClean(VPUMemLinear_t *p);
451 signed int VPUMemInvalidate(VPUMemLinear_t *p);
452 signed int VPUMemGetFD(VPUMemLinear_t *p);
453 signed int VPUMallocLinearFromRender(VPUMemLinear_t *p, unsigned int size, void *ctx);
454 
455 /*
456  * vpu memory allocator and manager interface
457  */
458 vpu_display_mem_pool *open_vpu_memory_pool(void);
459 void close_vpu_memory_pool(vpu_display_mem_pool *p);
460 int create_vpu_memory_pool_allocator(vpu_display_mem_pool **ipool, int num, int size);
461 void release_vpu_memory_pool_allocator(vpu_display_mem_pool *ipool);
462 
463 #ifdef __cplusplus
464 }
465 #endif
466 
467 #endif
468