FFmpeg
vaapi_decode.h
Go to the documentation of this file.
1 /*
2  * This file is part of FFmpeg.
3  *
4  * FFmpeg is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * FFmpeg is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with FFmpeg; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17  */
18 
19 #ifndef AVCODEC_VAAPI_DECODE_H
20 #define AVCODEC_VAAPI_DECODE_H
21 
22 #include <va/va.h>
23 
24 #include "libavutil/frame.h"
25 #include "libavutil/hwcontext.h"
27 
28 #include "avcodec.h"
29 
30 static inline VASurfaceID ff_vaapi_get_surface_id(AVFrame *pic)
31 {
32  return (uintptr_t)pic->data[3];
33 }
34 
35 typedef struct VAAPIDecodePicture {
36  VASurfaceID output_surface;
37 
39  VABufferID *param_buffers;
41 
42  int nb_slices;
43  VABufferID *slice_buffers;
46 
47 typedef struct VAAPIDecodeContext {
48  VAConfigID va_config;
49  VAContextID va_context;
50 
53 
56 
59 
60  VASurfaceAttrib pixel_format_attribute;
62 
63 
65  VAAPIDecodePicture *pic,
66  int type,
67  const void *data,
68  size_t size);
69 
71  VAAPIDecodePicture *pic,
72  const void *params_data,
73  int nb_params,
74  size_t params_size,
75  const void *slice_data,
76  size_t slice_size);
77 
79  VAAPIDecodePicture *pic);
81  VAAPIDecodePicture *pic);
82 
85 
87  AVBufferRef *hw_frames_ctx);
88 
89 #endif /* AVCODEC_VAAPI_DECODE_H */
VAAPIDecodePicture::nb_slice_buffers_allocated
int nb_slice_buffers_allocated
Definition: vaapi_decode.h:44
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:71
ff_vaapi_get_surface_id
static VASurfaceID ff_vaapi_get_surface_id(AVFrame *pic)
Definition: vaapi_decode.h:30
VAAPIDecodePicture::nb_param_buffers_allocated
int nb_param_buffers_allocated
Definition: vaapi_decode.h:40
VAAPIDecodePicture::slice_buffers
VABufferID * slice_buffers
Definition: vaapi_decode.h:43
VAAPIDecodeContext
Definition: vaapi_decode.h:47
VAAPIDecodeContext::device
AVHWDeviceContext * device
Definition: vaapi_decode.h:51
VAAPIDecodePicture
Definition: vaapi_decode.h:35
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:403
data
const char data[16]
Definition: mxf.c:149
AVFrame::data
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
Definition: frame.h:424
VAAPIDecodePicture::nb_param_buffers
int nb_param_buffers
Definition: vaapi_decode.h:38
type
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf type
Definition: writing_filters.txt:86
VAAPIDecodePicture::output_surface
VASurfaceID output_surface
Definition: vaapi_decode.h:36
AVHWDeviceContext
This struct aggregates all the (hardware/vendor-specific) "high-level" state, i.e.
Definition: hwcontext.h:60
ff_vaapi_decode_cancel
int ff_vaapi_decode_cancel(AVCodecContext *avctx, VAAPIDecodePicture *pic)
Definition: vaapi_decode.c:247
ff_vaapi_decode_make_slice_buffer
int ff_vaapi_decode_make_slice_buffer(AVCodecContext *avctx, VAAPIDecodePicture *pic, const void *params_data, int nb_params, size_t params_size, const void *slice_data, size_t slice_size)
Definition: vaapi_decode.c:75
ff_vaapi_decode_uninit
int ff_vaapi_decode_uninit(AVCodecContext *avctx)
Definition: vaapi_decode.c:738
VAAPIDecodeContext::surface_format
enum AVPixelFormat surface_format
Definition: vaapi_decode.h:57
ff_vaapi_decode_issue
int ff_vaapi_decode_issue(AVCodecContext *avctx, VAAPIDecodePicture *pic)
Definition: vaapi_decode.c:166
VAAPIDecodeContext::surface_count
int surface_count
Definition: vaapi_decode.h:58
VAAPIDecodePicture::param_buffers
VABufferID * param_buffers
Definition: vaapi_decode.h:39
VAAPIDecodeContext::va_config
VAConfigID va_config
Definition: vaapi_decode.h:48
VAAPIDecodePicture::nb_slices
int nb_slices
Definition: vaapi_decode.h:42
ff_vaapi_decode_init
int ff_vaapi_decode_init(AVCodecContext *avctx)
Definition: vaapi_decode.c:692
size
int size
Definition: twinvq_data.h:10344
VAAPIDecodeContext::pixel_format_attribute
VASurfaceAttrib pixel_format_attribute
Definition: vaapi_decode.h:60
frame.h
avcodec.h
AVHWFramesContext
This struct describes a set or pool of "hardware" frames (i.e.
Definition: hwcontext.h:115
hwcontext_vaapi.h
VAAPIDecodeContext::hwctx
AVVAAPIDeviceContext * hwctx
Definition: vaapi_decode.h:52
AVCodecContext
main external API structure.
Definition: avcodec.h:451
ff_vaapi_decode_make_param_buffer
int ff_vaapi_decode_make_param_buffer(AVCodecContext *avctx, VAAPIDecodePicture *pic, int type, const void *data, size_t size)
Definition: vaapi_decode.c:34
AVBufferRef
A reference to a data buffer.
Definition: buffer.h:82
AVVAAPIFramesContext
VAAPI-specific data associated with a frame pool.
Definition: hwcontext_vaapi.h:88
VAAPIDecodeContext::va_context
VAContextID va_context
Definition: vaapi_decode.h:49
VAAPIDecodeContext::hwfc
AVVAAPIFramesContext * hwfc
Definition: vaapi_decode.h:55
hwcontext.h
AVVAAPIDeviceContext
VAAPI connection details.
Definition: hwcontext_vaapi.h:68
ff_vaapi_common_frame_params
int ff_vaapi_common_frame_params(AVCodecContext *avctx, AVBufferRef *hw_frames_ctx)
Definition: vaapi_decode.c:668
VAAPIDecodeContext::frames
AVHWFramesContext * frames
Definition: vaapi_decode.h:54