Go to the documentation of this file.
19 #ifndef AVCODEC_VAAPI_ENCODE_H
20 #define AVCODEC_VAAPI_ENCODE_H
26 #if VA_CHECK_VERSION(1, 0, 0)
27 #include <va/va_str.h>
85 #if VA_CHECK_VERSION(1, 0, 0)
292 #if VA_CHECK_VERSION(0, 36, 0)
293 VAEncMiscParameterBufferQualityLevel quality_params;
464 char *
data,
size_t *data_len);
467 char *
data,
size_t *data_len);
471 char *
data,
size_t *data_len);
480 char *
data,
size_t *data_len);
488 char *
data,
size_t *data_len);
498 #define VAAPI_ENCODE_COMMON_OPTIONS \
500 "Use low-power encoding mode (only available on some platforms; " \
501 "may not support all encoding features)", \
502 OFFSET(common.low_power), AV_OPT_TYPE_BOOL, \
503 { .i64 = 0 }, 0, 1, FLAGS }, \
505 "Distance (in I-frames) between IDR frames", \
506 OFFSET(common.idr_interval), AV_OPT_TYPE_INT, \
507 { .i64 = 0 }, 0, INT_MAX, FLAGS }, \
509 "Maximum B-frame reference depth", \
510 OFFSET(common.desired_b_depth), AV_OPT_TYPE_INT, \
511 { .i64 = 1 }, 1, INT_MAX, FLAGS }, \
512 { "async_depth", "Maximum processing parallelism. " \
513 "Increase this to improve single channel performance. This option " \
514 "doesn't work if driver doesn't implement vaSyncBuffer function.", \
515 OFFSET(common.async_depth), AV_OPT_TYPE_INT, \
516 { .i64 = 2 }, 1, MAX_ASYNC_DEPTH, FLAGS }, \
517 { "max_frame_size", \
518 "Maximum frame size (in bytes)",\
519 OFFSET(common.max_frame_size), AV_OPT_TYPE_INT, \
520 { .i64 = 0 }, 0, INT_MAX, FLAGS }
522 #define VAAPI_ENCODE_RC_MODE(name, desc) \
523 { #name, desc, 0, AV_OPT_TYPE_CONST, { .i64 = RC_MODE_ ## name }, \
524 0, 0, FLAGS, "rc_mode" }
525 #define VAAPI_ENCODE_RC_OPTIONS \
527 "Set rate control mode", \
528 OFFSET(common.explicit_rc_mode), AV_OPT_TYPE_INT, \
529 { .i64 = RC_MODE_AUTO }, RC_MODE_AUTO, RC_MODE_MAX, FLAGS, "rc_mode" }, \
530 { "auto", "Choose mode automatically based on other parameters", \
531 0, AV_OPT_TYPE_CONST, { .i64 = RC_MODE_AUTO }, 0, 0, FLAGS, "rc_mode" }, \
532 VAAPI_ENCODE_RC_MODE(CQP, "Constant-quality"), \
533 VAAPI_ENCODE_RC_MODE(CBR, "Constant-bitrate"), \
534 VAAPI_ENCODE_RC_MODE(VBR, "Variable-bitrate"), \
535 VAAPI_ENCODE_RC_MODE(ICQ, "Intelligent constant-quality"), \
536 VAAPI_ENCODE_RC_MODE(QVBR, "Quality-defined variable-bitrate"), \
537 VAAPI_ENCODE_RC_MODE(AVBR, "Average variable-bitrate")
void * codec_slice_params
@ FLAG_B_PICTURE_REFERENCES
unsigned int va_packed_headers
unsigned int desired_packed_headers
size_t tail_size
Byte length of tail_data.
This structure describes decoded (raw) audio or video data.
size_t global_params_size[MAX_GLOBAL_PARAMS]
int(* write_sequence_header)(AVCodecContext *avctx, char *data, size_t *data_len)
int ff_vaapi_encode_init(AVCodecContext *avctx)
VAEncMiscParameterRateControl rc_params
struct VAAPIEncodePicture * refs[MAX_REFERENCE_LIST_NUM][MAX_PICTURE_REFERENCES]
int(* configure)(AVCodecContext *avctx)
@ FLAG_NON_IDR_KEY_PICTURES
int nb_refs[MAX_REFERENCE_LIST_NUM]
int row_height[MAX_TILE_ROWS]
int(* init_picture_params)(AVCodecContext *avctx, VAAPIEncodePicture *pic)
AVPacket * tail_pkt
Tail data of a pic, now only used for av1 repeat frame header.
int non_independent_frame
indicate if current frame is an independent frame that the coded data can be pushed to downstream dir...
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
VAEncMiscParameterBufferMaxFrameSize mfs_params
const VAAPIEncodeProfile * profile
This struct aggregates all the (hardware/vendor-specific) "high-level" state, i.e.
const VAAPIEncodeRCMode * rc_mode
void * codec_picture_params
size_t picture_params_size
int global_params_type[MAX_GLOBAL_PARAMS]
const void * global_params[MAX_GLOBAL_PARAMS]
VAEntrypoint va_entrypoint
AVBufferRef * recon_frames_ref
AVHWDeviceContext * device
AVBufferPool * output_buffer_pool
struct VAAPIEncodePicture * prev
Describe the class of an AVClass context structure.
struct VAAPIEncodePicture * dpb[MAX_DPB_SIZE]
const VAAPIEncodeProfile * profiles
int ff_vaapi_encode_close(AVCodecContext *avctx)
int(* write_picture_header)(AVCodecContext *avctx, VAAPIEncodePicture *pic, char *data, size_t *data_len)
int(* init_sequence_params)(AVCodecContext *avctx)
void * codec_sequence_params
VAAPIEncodePicture * pic_start
int(* write_extra_buffer)(AVCodecContext *avctx, VAAPIEncodePicture *pic, int index, int *type, char *data, size_t *data_len)
VAConfigAttrib config_attributes[MAX_CONFIG_ATTRIBUTES]
VAAPIEncodePicture * pic_end
@ FLAG_CONSTANT_QUALITY_ONLY
VAAPIEncodeSlice * slices
VASurfaceID input_surface
AVHWFramesContext * recon_frames
VASurfaceID recon_surface
AVBufferRef * coded_buffer_ref
Head data for current output pkt, used only for AV1.
VAEncMiscParameterHRD hrd_params
int(* write_extra_header)(AVCodecContext *avctx, VAAPIEncodePicture *pic, int index, int *type, char *data, size_t *data_len)
int col_width[MAX_TILE_COLS]
const struct VAAPIEncodeType * codec
int(* init_slice_params)(AVCodecContext *avctx, VAAPIEncodePicture *pic, VAAPIEncodeSlice *slice)
int row_bd[MAX_TILE_ROWS+1]
AVHWFramesContext * input_frames
void * codec_picture_params
This struct describes a set or pool of "hardware" frames (i.e.
char tail_data[MAX_PARAM_BUFFER_SIZE]
Tail data of current pic, used only for repeat header of AV1.
AVBufferRef * output_buffer_ref
AVVAAPIDeviceContext * hwctx
int64_t ts_ring[MAX_REORDER_DELAY *3+MAX_ASYNC_DEPTH]
VABufferID * param_buffers
main external API structure.
AVBufferRef * input_frames_ref
VAEncMiscParameterFrameRate fr_params
int(* write_slice_header)(AVCodecContext *avctx, VAAPIEncodePicture *pic, VAAPIEncodeSlice *slice, char *data, size_t *data_len)
struct VAAPIEncodePicture * next
size_t sequence_params_size
A reference to a data buffer.
VAAPIEncodePicture * next_prev[MAX_PICTURE_REFERENCES]
This structure stores compressed data.
int col_bd[MAX_TILE_COLS+1]
size_t picture_priv_data_size
int(* get_encoder_caps)(AVCodecContext *avctx)
VAAPI connection details.
@ FLAG_TIMESTAMP_NO_DELAY
int ff_vaapi_encode_receive_packet(AVCodecContext *avctx, AVPacket *pkt)
const AVCodecHWConfigInternal *const ff_vaapi_encode_hw_configs[]