FFmpeg: libavcodec/vaapi_encode.h Source File

FFmpeg
vaapi_encode.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_ENCODE_H
20 #define AVCODEC_VAAPI_ENCODE_H
21 
22 #include <stdint.h>
23 
24 #include <va/va.h>
25 
26 #if VA_CHECK_VERSION(1, 0, 0)
27 #include <va/va_str.h>
28 #endif
29 
30 #include "libavutil/hwcontext.h"
31 #include "libavutil/hwcontext_vaapi.h"
32 
33 #include "avcodec.h"
34 #include "hwconfig.h"
35 #include "hw_base_encode.h"
36 
37 struct VAAPIEncodeType;
38 struct VAAPIEncodePicture;
39 
40 // Codec output packet without timestamp delay, which means the
41 // output packet has same PTS and DTS.
42  #define FLAG_TIMESTAMP_NO_DELAY 1 << 6
43 
44 enum {
45   MAX_CONFIG_ATTRIBUTES = 4,
46   MAX_GLOBAL_PARAMS = 4,
47   MAX_PARAM_BUFFER_SIZE = 1024,
48  // A.4.1: table A.6 allows at most 22 tile rows for any level.
49   MAX_TILE_ROWS = 22,
50  // A.4.1: table A.6 allows at most 20 tile columns for any level.
51   MAX_TILE_COLS = 20,
52 };
53 
54 extern const AVCodecHWConfigInternal *const ff_vaapi_encode_hw_configs[];
55 
56  typedef struct VAAPIEncodeSlice {
57   int index;
58   int row_start;
59   int row_size;
60   int block_start;
61   int block_size;
62   void *codec_slice_params;
63 } VAAPIEncodeSlice;
64 
65  typedef struct VAAPIEncodePicture {
66 #if VA_CHECK_VERSION(1, 0, 0)
67  // ROI regions.
68  VAEncROI *roi;
69 #else
70   void *roi;
71 #endif
72 
73   VASurfaceID input_surface;
74   VASurfaceID recon_surface;
75 
76   int nb_param_buffers;
77   VABufferID *param_buffers;
78 
79  /* Refcounted via the refstruct-API */
80   VABufferID *output_buffer_ref;
81   VABufferID output_buffer;
82 
83   void *codec_picture_params;
84 
85   int nb_slices;
86   VAAPIEncodeSlice *slices;
87 
88  /**
89  * indicate if current frame is an independent frame that the coded data
90  * can be pushed to downstream directly. Coded of non-independent frame
91  * data will be concatenated into next independent frame.
92  */
93   int non_independent_frame;
94  /** Tail data of current pic, used only for repeat header of AV1. */
95   char tail_data[MAX_PARAM_BUFFER_SIZE];
96  /** Byte length of tail_data. */
97   size_t tail_size;
98 } VAAPIEncodePicture;
99 
100  typedef struct VAAPIEncodeProfile {
101  // lavc profile value (AV_PROFILE_*).
102   int av_profile;
103  // Supported bit depth.
104   int depth;
105  // Number of components.
106   int nb_components;
107  // Chroma subsampling in width dimension.
108   int log2_chroma_w;
109  // Chroma subsampling in height dimension.
110   int log2_chroma_h;
111  // VAAPI profile value.
112   VAProfile va_profile;
113 } VAAPIEncodeProfile;
114 
115 enum {
116   RC_MODE_AUTO,
117   RC_MODE_CQP,
118   RC_MODE_CBR,
119   RC_MODE_VBR,
120   RC_MODE_ICQ,
121   RC_MODE_QVBR,
122   RC_MODE_AVBR,
123   RC_MODE_MAX = RC_MODE_AVBR,
124 };
125 
126  typedef struct VAAPIEncodeRCMode {
127  // Mode from above enum (RC_MODE_*).
128   int mode;
129  // Name.
130   const char *name;
131  // Supported in the compile-time VAAPI version.
132   int supported;
133  // VA mode value (VA_RC_*).
134   uint32_t va_mode;
135  // Uses bitrate parameters.
136   int bitrate;
137  // Supports maxrate distinct from bitrate.
138   int maxrate;
139  // Uses quality value.
140   int quality;
141  // Supports HRD/VBV parameters.
142   int hrd;
143 } VAAPIEncodeRCMode;
144 
145  typedef struct VAAPIEncodeContext {
146  // Base context.
147   FFHWBaseEncodeContext base;
148 
149  // Codec-specific hooks.
150   const struct VAAPIEncodeType *codec;
151 
152  // Use low power encoding mode.
153   int low_power;
154 
155  // Max Frame Size
156   int max_frame_size;
157 
158  // Explicitly set RC mode (otherwise attempt to pick from
159  // available modes).
160   int explicit_rc_mode;
161 
162  // Block Level based bitrate control.
163   int blbrc;
164 
165  // Explicitly-set QP, for use with the "qp" options.
166  // (Forces CQP mode when set, overriding everything else.)
167   int explicit_qp;
168 
169  // Desired packed headers.
170   unsigned int desired_packed_headers;
171 
172  // Everything above this point must be set before calling
173  // ff_vaapi_encode_init().
174 
175  // Chosen encoding profile details.
176   const VAAPIEncodeProfile *profile;
177 
178  // Chosen rate control mode details.
179   const VAAPIEncodeRCMode *rc_mode;
180  // RC quality level - meaning depends on codec and RC mode.
181  // In CQP mode this sets the fixed quantiser value.
182   int rc_quality;
183 
184  // Encoding profile (VAProfile*).
185   VAProfile va_profile;
186  // Encoding entrypoint (VAEntryoint*).
187   VAEntrypoint va_entrypoint;
188  // Rate control mode.
189   unsigned int va_rc_mode;
190  // Bitrate for codec-specific encoder parameters.
191   unsigned int va_bit_rate;
192  // Packed headers which will actually be sent.
193   unsigned int va_packed_headers;
194 
195  // Configuration attributes to use when creating va_config.
196   VAConfigAttrib config_attributes[MAX_CONFIG_ATTRIBUTES];
197   int nb_config_attributes;
198 
199   VAConfigID va_config;
200   VAContextID va_context;
201 
202   AVVAAPIDeviceContext *hwctx;
203 
204  // Pool of (reusable) bitstream output buffers.
205   struct FFRefStructPool *output_buffer_pool;
206 
207  // Global parameters which will be applied at the start of the
208  // sequence (includes rate control parameters below).
209   int global_params_type[MAX_GLOBAL_PARAMS];
210   const void *global_params [MAX_GLOBAL_PARAMS];
211   size_t global_params_size[MAX_GLOBAL_PARAMS];
212   int nb_global_params;
213 
214  // Rate control parameters.
215   VAEncMiscParameterRateControl rc_params;
216   VAEncMiscParameterHRD hrd_params;
217   VAEncMiscParameterFrameRate fr_params;
218   VAEncMiscParameterBufferMaxFrameSize mfs_params;
219 #if VA_CHECK_VERSION(0, 36, 0)
220  VAEncMiscParameterBufferQualityLevel quality_params;
221 #endif
222 
223  // Per-sequence parameter structure (VAEncSequenceParameterBuffer*).
224   void *codec_sequence_params;
225 
226  // Per-sequence parameters found in the per-picture parameter
227  // structure (VAEncPictureParameterBuffer*).
228   void *codec_picture_params;
229 
230  // Slice structure.
231   int slice_block_rows;
232   int slice_block_cols;
233   int nb_slices;
234   int slice_size;
235 
236  // Tile encoding.
237   int tile_cols;
238   int tile_rows;
239  // Tile width of the i-th column.
240   int col_width[MAX_TILE_COLS];
241  // Tile height of i-th row.
242   int row_height[MAX_TILE_ROWS];
243  // Location of the i-th tile column boundary.
244   int col_bd[MAX_TILE_COLS + 1];
245  // Location of the i-th tile row boundary.
246   int row_bd[MAX_TILE_ROWS + 1];
247 
248  // Maximum number of regions supported by the driver.
249   int roi_max_regions;
250  // Quantisation range for offset calculations. Set by codec-specific
251  // code, as it may change based on parameters.
252   int roi_quant_range;
253 
254  /** Head data for current output pkt, used only for AV1. */
255  //void *header_data;
256  //size_t header_data_size;
257 
258  /**
259  * Buffered coded data of a pic if it is an non-independent frame.
260  * This is a RefStruct reference.
261  */
262   VABufferID *coded_buffer_ref;
263 } VAAPIEncodeContext;
264 
265  typedef struct VAAPIEncodeType {
266  // List of supported profiles and corresponding VAAPI profiles.
267  // (Must end with AV_PROFILE_UNKNOWN.)
268   const VAAPIEncodeProfile *profiles;
269 
270  // Codec feature flags.
271   int flags;
272 
273  // Default quality for this codec - used as quantiser or RC quality
274  // factor depending on RC mode.
275   int default_quality;
276 
277  // Determine encode parameters like block sizes for surface alignment
278  // and slices. This may need to query the profile and entrypoint,
279  // which will be available when this function is called. If not set,
280  // assume that all blocks are 16x16 and that surfaces should be
281  // aligned to match this.
282   int (*get_encoder_caps)(AVCodecContext *avctx);
283 
284  // Perform any extra codec-specific configuration after the
285  // codec context is initialised (set up the private data and
286  // add any necessary global parameters).
287   int (*configure)(AVCodecContext *avctx);
288 
289  // The size of any private data structure associated with each
290  // picture (can be zero if not required).
291   size_t picture_priv_data_size;
292 
293  // The size of the parameter structures:
294  // sizeof(VAEnc{type}ParameterBuffer{codec}).
295   size_t sequence_params_size;
296   size_t picture_params_size;
297   size_t slice_params_size;
298 
299  // Fill the parameter structures.
300   int (*init_sequence_params)(AVCodecContext *avctx);
301   int (*init_picture_params)(AVCodecContext *avctx,
302  FFHWBaseEncodePicture *pic);
303   int (*init_slice_params)(AVCodecContext *avctx,
304  FFHWBaseEncodePicture *pic,
305  VAAPIEncodeSlice *slice);
306 
307  // The type used by the packed header: this should look like
308  // VAEncPackedHeader{something}.
309   int sequence_header_type;
310   int picture_header_type;
311   int slice_header_type;
312 
313  // Write the packed header data to the provided buffer.
314  // The sequence header is also used to fill the codec extradata
315  // when the encoder is starting.
316   int (*write_sequence_header)(AVCodecContext *avctx,
317  char *data, size_t *data_len);
318   int (*write_picture_header)(AVCodecContext *avctx,
319  FFHWBaseEncodePicture *pic,
320  char *data, size_t *data_len);
321   int (*write_slice_header)(AVCodecContext *avctx,
322  VAAPIEncodePicture *pic,
323  VAAPIEncodeSlice *slice,
324  char *data, size_t *data_len);
325 
326  // Fill an extra parameter structure, which will then be
327  // passed to vaRenderPicture(). Will be called repeatedly
328  // with increasing index argument until AVERROR_EOF is
329  // returned.
330   int (*write_extra_buffer)(AVCodecContext *avctx,
331  FFHWBaseEncodePicture *pic,
332  int index, int *type,
333  char *data, size_t *data_len);
334 
335  // Write an extra packed header. Will be called repeatedly
336  // with increasing index argument until AVERROR_EOF is
337  // returned.
338   int (*write_extra_header)(AVCodecContext *avctx,
339  FFHWBaseEncodePicture *pic,
340  int index, int *type,
341  char *data, size_t *data_len);
342 } VAAPIEncodeType;
343 
344 int ff_vaapi_encode_receive_packet(AVCodecContext *avctx, AVPacket *pkt);
345 
346 int ff_vaapi_encode_init(AVCodecContext *avctx);
347 int ff_vaapi_encode_close(AVCodecContext *avctx);
348 
349 
350  #define VAAPI_ENCODE_COMMON_OPTIONS \
351  { "low_power", \
352  "Use low-power encoding mode (only available on some platforms; " \
353  "may not support all encoding features)", \
354  OFFSET(common.low_power), AV_OPT_TYPE_BOOL, \
355  { .i64 = 0 }, 0, 1, FLAGS }, \
356  { "max_frame_size", \
357  "Maximum frame size (in bytes)",\
358  OFFSET(common.max_frame_size), AV_OPT_TYPE_INT, \
359  { .i64 = 0 }, 0, INT_MAX, FLAGS }
360 
361  #define VAAPI_ENCODE_RC_MODE(name, desc) \
362  { #name, desc, 0, AV_OPT_TYPE_CONST, { .i64 = RC_MODE_ ## name }, \
363  0, 0, FLAGS, .unit = "rc_mode" }
364  #define VAAPI_ENCODE_RC_OPTIONS \
365  { "rc_mode",\
366  "Set rate control mode", \
367  OFFSET(common.explicit_rc_mode), AV_OPT_TYPE_INT, \
368  { .i64 = RC_MODE_AUTO }, RC_MODE_AUTO, RC_MODE_MAX, FLAGS, .unit = "rc_mode" }, \
369  { "auto", "Choose mode automatically based on other parameters", \
370  0, AV_OPT_TYPE_CONST, { .i64 = RC_MODE_AUTO }, 0, 0, FLAGS, .unit = "rc_mode" }, \
371  VAAPI_ENCODE_RC_MODE(CQP, "Constant-quality"), \
372  VAAPI_ENCODE_RC_MODE(CBR, "Constant-bitrate"), \
373  VAAPI_ENCODE_RC_MODE(VBR, "Variable-bitrate"), \
374  VAAPI_ENCODE_RC_MODE(ICQ, "Intelligent constant-quality"), \
375  VAAPI_ENCODE_RC_MODE(QVBR, "Quality-defined variable-bitrate"), \
376  VAAPI_ENCODE_RC_MODE(AVBR, "Average variable-bitrate"), \
377  { "blbrc", \
378  "Block level based bitrate control",\
379  OFFSET(common.blbrc), AV_OPT_TYPE_BOOL, \
380  { .i64 = 0 }, 0, 1, FLAGS }
381 
382 
383 #endif /* AVCODEC_VAAPI_ENCODE_H */
hwconfig.h
VAAPIEncodeType::default_quality
int default_quality
Definition: vaapi_encode.h:275
VAAPIEncodeSlice::codec_slice_params
void * codec_slice_params
Definition: vaapi_encode.h:62
VAAPIEncodeProfile::va_profile
VAProfile va_profile
Definition: vaapi_encode.h:112
VAAPIEncodeContext::va_packed_headers
unsigned int va_packed_headers
Definition: vaapi_encode.h:193
VAAPIEncodeContext::desired_packed_headers
unsigned int desired_packed_headers
Definition: vaapi_encode.h:170
VAAPIEncodeType::init_picture_params
int(* init_picture_params)(AVCodecContext *avctx, FFHWBaseEncodePicture *pic)
Definition: vaapi_encode.h:301
VAAPIEncodePicture::tail_size
size_t tail_size
Byte length of tail_data.
Definition: vaapi_encode.h:97
VAAPIEncodeContext::blbrc
int blbrc
Definition: vaapi_encode.h:163
VAAPIEncodeContext::tile_cols
int tile_cols
Definition: vaapi_encode.h:237
VAAPIEncodeContext::base
FFHWBaseEncodeContext base
Definition: vaapi_encode.h:147
VAAPIEncodeContext::slice_size
int slice_size
Definition: vaapi_encode.h:234
VAAPIEncodeContext::nb_global_params
int nb_global_params
Definition: vaapi_encode.h:212
VAAPIEncodeContext::global_params_size
size_t global_params_size[MAX_GLOBAL_PARAMS]
Definition: vaapi_encode.h:211
VAAPIEncodeContext::nb_slices
int nb_slices
Definition: vaapi_encode.h:233
VAAPIEncodeType::write_sequence_header
int(* write_sequence_header)(AVCodecContext *avctx, char *data, size_t *data_len)
Definition: vaapi_encode.h:316
VAAPIEncodeSlice
Definition: vaapi_encode.h:56
data
const char data[16]
Definition: mxf.c:148
VAAPIEncodeContext::roi_quant_range
int roi_quant_range
Definition: vaapi_encode.h:252
VAAPIEncodeSlice::block_start
int block_start
Definition: vaapi_encode.h:60
VAAPIEncodeType::flags
int flags
Definition: vaapi_encode.h:271
VAAPIEncodeContext::low_power
int low_power
Definition: vaapi_encode.h:153
VAAPIEncodeSlice::index
int index
Definition: vaapi_encode.h:57
VAAPIEncodeRCMode::va_mode
uint32_t va_mode
Definition: vaapi_encode.h:134
ff_vaapi_encode_init
int ff_vaapi_encode_init(AVCodecContext *avctx)
Definition: vaapi_encode.c:2091
VAAPIEncodeContext::rc_params
VAEncMiscParameterRateControl rc_params
Definition: vaapi_encode.h:215
VAAPIEncodeContext::va_rc_mode
unsigned int va_rc_mode
Definition: vaapi_encode.h:189
VAAPIEncodeContext::roi_max_regions
int roi_max_regions
Definition: vaapi_encode.h:249
VAAPIEncodeType::configure
int(* configure)(AVCodecContext *avctx)
Definition: vaapi_encode.h:287
FFHWBaseEncodeContext
Definition: hw_base_encode.h:122
VAAPIEncodeContext::row_height
int row_height[MAX_TILE_ROWS]
Definition: vaapi_encode.h:242
VAAPIEncodeType::picture_header_type
int picture_header_type
Definition: vaapi_encode.h:310
VAAPIEncodeSlice::row_start
int row_start
Definition: vaapi_encode.h:58
VAAPIEncodePicture
Definition: vaapi_encode.h:65
VAAPIEncodePicture::non_independent_frame
int non_independent_frame
indicate if current frame is an independent frame that the coded data can be pushed to downstream dir...
Definition: vaapi_encode.h:93
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
VAAPIEncodeContext::mfs_params
VAEncMiscParameterBufferMaxFrameSize mfs_params
Definition: vaapi_encode.h:218
VAAPIEncodeContext::profile
const VAAPIEncodeProfile * profile
Definition: vaapi_encode.h:176
VAAPIEncodeContext::nb_config_attributes
int nb_config_attributes
Definition: vaapi_encode.h:197
VAAPIEncodeContext::rc_mode
const VAAPIEncodeRCMode * rc_mode
Definition: vaapi_encode.h:179
MAX_GLOBAL_PARAMS
@ MAX_GLOBAL_PARAMS
Definition: vaapi_encode.h:46
pkt
AVPacket * pkt
Definition: movenc.c:60
VAAPIEncodeSlice::row_size
int row_size
Definition: vaapi_encode.h:59
VAAPIEncodePicture::codec_picture_params
void * codec_picture_params
Definition: vaapi_encode.h:83
RC_MODE_QVBR
@ RC_MODE_QVBR
Definition: vaapi_encode.h:121
VAAPIEncodeType::picture_params_size
size_t picture_params_size
Definition: vaapi_encode.h:296
VAAPIEncodeContext::tile_rows
int tile_rows
Definition: vaapi_encode.h:238
VAAPIEncodeContext::global_params_type
int global_params_type[MAX_GLOBAL_PARAMS]
Definition: vaapi_encode.h:209
VAAPIEncodeContext::global_params
const void * global_params[MAX_GLOBAL_PARAMS]
Definition: vaapi_encode.h:210
VAAPIEncodeContext::output_buffer_pool
struct FFRefStructPool * output_buffer_pool
Definition: vaapi_encode.h:205
VAAPIEncodeContext::va_entrypoint
VAEntrypoint va_entrypoint
Definition: vaapi_encode.h:187
hw_base_encode.h
FFRefStructPool
FFRefStructPool is an API for a thread-safe pool of objects managed via the RefStruct API.
Definition: refstruct.c:183
VAAPIEncodeType
Definition: vaapi_encode.h:265
RC_MODE_ICQ
@ RC_MODE_ICQ
Definition: vaapi_encode.h:120
VAAPIEncodeContext
Definition: vaapi_encode.h:145
VAAPIEncodeContext::rc_quality
int rc_quality
Definition: vaapi_encode.h:182
VAAPIEncodeContext::slice_block_rows
int slice_block_rows
Definition: vaapi_encode.h:231
VAAPIEncodeType::sequence_header_type
int sequence_header_type
Definition: vaapi_encode.h:309
VAAPIEncodeType::write_picture_header
int(* write_picture_header)(AVCodecContext *avctx, FFHWBaseEncodePicture *pic, char *data, size_t *data_len)
Definition: vaapi_encode.h:318
VAAPIEncodeProfile::av_profile
int av_profile
Definition: vaapi_encode.h:102
VAAPIEncodeType::profiles
const VAAPIEncodeProfile * profiles
Definition: vaapi_encode.h:268
ff_vaapi_encode_close
int ff_vaapi_encode_close(AVCodecContext *avctx)
Definition: vaapi_encode.c:2275
VAAPIEncodeType::init_sequence_params
int(* init_sequence_params)(AVCodecContext *avctx)
Definition: vaapi_encode.h:300
RC_MODE_AVBR
@ RC_MODE_AVBR
Definition: vaapi_encode.h:122
MAX_PARAM_BUFFER_SIZE
@ MAX_PARAM_BUFFER_SIZE
Definition: vaapi_encode.h:47
RC_MODE_CQP
@ RC_MODE_CQP
Definition: vaapi_encode.h:117
VAAPIEncodeRCMode::supported
int supported
Definition: vaapi_encode.h:132
VAAPIEncodeContext::codec_sequence_params
void * codec_sequence_params
Definition: vaapi_encode.h:224
VAAPIEncodeContext::va_bit_rate
unsigned int va_bit_rate
Definition: vaapi_encode.h:191
RC_MODE_VBR
@ RC_MODE_VBR
Definition: vaapi_encode.h:119
VAAPIEncodeType::slice_params_size
size_t slice_params_size
Definition: vaapi_encode.h:297
VAAPIEncodeContext::config_attributes
VAConfigAttrib config_attributes[MAX_CONFIG_ATTRIBUTES]
Definition: vaapi_encode.h:196
index
int index
Definition: gxfenc.c:90
VAAPIEncodeProfile::nb_components
int nb_components
Definition: vaapi_encode.h:106
VAAPIEncodePicture::slices
VAAPIEncodeSlice * slices
Definition: vaapi_encode.h:86
VAAPIEncodePicture::input_surface
VASurfaceID input_surface
Definition: vaapi_encode.h:73
VAAPIEncodeRCMode::mode
int mode
Definition: vaapi_encode.h:128
VAAPIEncodeProfile::depth
int depth
Definition: vaapi_encode.h:104
AVCodecHWConfigInternal
Definition: hwconfig.h:25
VAAPIEncodeContext::explicit_rc_mode
int explicit_rc_mode
Definition: vaapi_encode.h:160
VAAPIEncodePicture::recon_surface
VASurfaceID recon_surface
Definition: vaapi_encode.h:74
VAAPIEncodeType::slice_header_type
int slice_header_type
Definition: vaapi_encode.h:311
VAAPIEncodePicture::output_buffer
VABufferID output_buffer
Definition: vaapi_encode.h:81
RC_MODE_AUTO
@ RC_MODE_AUTO
Definition: vaapi_encode.h:116
VAAPIEncodeContext::va_context
VAContextID va_context
Definition: vaapi_encode.h:200
VAAPIEncodeContext::hrd_params
VAEncMiscParameterHRD hrd_params
Definition: vaapi_encode.h:216
VAAPIEncodeContext::col_width
int col_width[MAX_TILE_COLS]
Definition: vaapi_encode.h:240
VAAPIEncodeContext::codec
const struct VAAPIEncodeType * codec
Definition: vaapi_encode.h:150
MAX_CONFIG_ATTRIBUTES
@ MAX_CONFIG_ATTRIBUTES
Definition: vaapi_encode.h:45
VAAPIEncodeContext::row_bd
int row_bd[MAX_TILE_ROWS+1]
Definition: vaapi_encode.h:246
VAAPIEncodePicture::roi
void * roi
Definition: vaapi_encode.h:70
RC_MODE_CBR
@ RC_MODE_CBR
Definition: vaapi_encode.h:118
VAAPIEncodeContext::codec_picture_params
void * codec_picture_params
Definition: vaapi_encode.h:228
VAAPIEncodeContext::max_frame_size
int max_frame_size
Definition: vaapi_encode.h:156
avcodec.h
VAAPIEncodePicture::tail_data
char tail_data[MAX_PARAM_BUFFER_SIZE]
Tail data of current pic, used only for repeat header of AV1.
Definition: vaapi_encode.h:95
hwcontext_vaapi.h
VAAPIEncodeContext::hwctx
AVVAAPIDeviceContext * hwctx
Definition: vaapi_encode.h:202
FFHWBaseEncodePicture
Definition: hw_base_encode.h:61
VAAPIEncodeRCMode::bitrate
int bitrate
Definition: vaapi_encode.h:136
VAAPIEncodePicture::param_buffers
VABufferID * param_buffers
Definition: vaapi_encode.h:77
VAAPIEncodeType::write_extra_buffer
int(* write_extra_buffer)(AVCodecContext *avctx, FFHWBaseEncodePicture *pic, int index, int *type, char *data, size_t *data_len)
Definition: vaapi_encode.h:330
VAAPIEncodeContext::va_config
VAConfigID va_config
Definition: vaapi_encode.h:199
VAAPIEncodeContext::va_profile
VAProfile va_profile
Definition: vaapi_encode.h:185
AVCodecContext
main external API structure.
Definition: avcodec.h:451
RC_MODE_MAX
@ RC_MODE_MAX
Definition: vaapi_encode.h:123
VAAPIEncodeRCMode::hrd
int hrd
Definition: vaapi_encode.h:142
VAAPIEncodeProfile::log2_chroma_h
int log2_chroma_h
Definition: vaapi_encode.h:110
VAAPIEncodeContext::fr_params
VAEncMiscParameterFrameRate fr_params
Definition: vaapi_encode.h:217
VAAPIEncodeType::write_slice_header
int(* write_slice_header)(AVCodecContext *avctx, VAAPIEncodePicture *pic, VAAPIEncodeSlice *slice, char *data, size_t *data_len)
Definition: vaapi_encode.h:321
VAAPIEncodeRCMode::maxrate
int maxrate
Definition: vaapi_encode.h:138
VAAPIEncodeContext::coded_buffer_ref
VABufferID * coded_buffer_ref
Head data for current output pkt, used only for AV1.
Definition: vaapi_encode.h:262
MAX_TILE_ROWS
@ MAX_TILE_ROWS
Definition: vaapi_encode.h:49
VAAPIEncodePicture::output_buffer_ref
VABufferID * output_buffer_ref
Definition: vaapi_encode.h:80
VAAPIEncodeType::sequence_params_size
size_t sequence_params_size
Definition: vaapi_encode.h:295
VAAPIEncodeContext::explicit_qp
int explicit_qp
Definition: vaapi_encode.h:167
MAX_TILE_COLS
@ MAX_TILE_COLS
Definition: vaapi_encode.h:51
VAAPIEncodeSlice::block_size
int block_size
Definition: vaapi_encode.h:61
VAAPIEncodeRCMode
Definition: vaapi_encode.h:126
AVPacket
This structure stores compressed data.
Definition: packet.h:516
VAAPIEncodeType::init_slice_params
int(* init_slice_params)(AVCodecContext *avctx, FFHWBaseEncodePicture *pic, VAAPIEncodeSlice *slice)
Definition: vaapi_encode.h:303
VAAPIEncodeContext::col_bd
int col_bd[MAX_TILE_COLS+1]
Definition: vaapi_encode.h:244
VAAPIEncodeProfile::log2_chroma_w
int log2_chroma_w
Definition: vaapi_encode.h:108
hwcontext.h
VAAPIEncodeContext::slice_block_cols
int slice_block_cols
Definition: vaapi_encode.h:232
VAAPIEncodeType::write_extra_header
int(* write_extra_header)(AVCodecContext *avctx, FFHWBaseEncodePicture *pic, int index, int *type, char *data, size_t *data_len)
Definition: vaapi_encode.h:338
VAAPIEncodeType::picture_priv_data_size
size_t picture_priv_data_size
Definition: vaapi_encode.h:291
VAAPIEncodeType::get_encoder_caps
int(* get_encoder_caps)(AVCodecContext *avctx)
Definition: vaapi_encode.h:282
VAAPIEncodePicture::nb_param_buffers
int nb_param_buffers
Definition: vaapi_encode.h:76
AVVAAPIDeviceContext
VAAPI connection details.
Definition: hwcontext_vaapi.h:68
VAAPIEncodeRCMode::quality
int quality
Definition: vaapi_encode.h:140
VAAPIEncodeProfile
Definition: vaapi_encode.h:100
ff_vaapi_encode_receive_packet
int ff_vaapi_encode_receive_packet(AVCodecContext *avctx, AVPacket *pkt)
Definition: vaapi_encode.c:2086
VAAPIEncodeRCMode::name
const char * name
Definition: vaapi_encode.h:130
VAAPIEncodePicture::nb_slices
int nb_slices
Definition: vaapi_encode.h:85
ff_vaapi_encode_hw_configs
const AVCodecHWConfigInternal *const ff_vaapi_encode_hw_configs[]
Definition: vaapi_encode.c:36

Generated on Fri Aug 22 2025 13:58:54 for FFmpeg by   doxygen 1.8.17

AltStyle によって変換されたページ (->オリジナル) /