25 #include <sys/types.h>
27 #include <mfx/mfxvideo.h>
55 res =
ff_alloc_a53_sei(frame,
sizeof(mfxPayload) + 2, (
void**)&payload, &sei_size);
56 if (res < 0 || !payload)
59 sei_data = (mfxU8*)(payload + 1);
62 sei_data[1] = (mfxU8)sei_size;
65 payload->BufSize = sei_size + 2;
66 payload->NumBit = payload->BufSize * 8;
68 payload->Data = sei_data;
70 enc_ctrl->NumExtParam = 0;
71 enc_ctrl->NumPayload = 1;
72 enc_ctrl->Payload[0] = payload;
100 #define OFFSET(x) offsetof(QSVH264EncContext, x)
101 #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
106 {
"idr_interval",
"Distance (in I-frames) between IDR frames",
OFFSET(qsv.idr_interval),
AV_OPT_TYPE_INT, { .i64 = 0 }, 0, INT_MAX,
VE },
107 {
"pic_timing_sei",
"Insert picture timing SEI with pic_struct_syntax element",
OFFSET(qsv.pic_timing_sei),
AV_OPT_TYPE_INT, { .i64 = 1 }, 0, 1,
VE },
108 {
"single_sei_nal_unit",
"Put all the SEI messages into one NALU",
OFFSET(qsv.single_sei_nal_unit),
AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 1,
VE },
109 {
"max_dec_frame_buffering",
"Maximum number of frames buffered in the DPB",
OFFSET(qsv.max_dec_frame_buffering),
AV_OPT_TYPE_INT, { .i64 = 0 }, 0, UINT16_MAX,
VE },
112 {
"look_ahead",
"Use VBR algorithm with look ahead",
OFFSET(qsv.look_ahead),
AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 1,
VE },
113 {
"look_ahead_depth",
"Depth of look ahead in number frames",
OFFSET(qsv.look_ahead_depth),
AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 100,
VE },
116 {
"look_ahead_downsampling",
"Downscaling factor for the frames saved for the lookahead analysis",
OFFSET(qsv.look_ahead_downsampling),
125 {
"int_ref_type",
"Intra refresh type",
OFFSET(qsv.int_ref_type),
AV_OPT_TYPE_INT, { .i64 = -1 }, -1, UINT16_MAX,
VE,
"int_ref_type" },
128 {
"int_ref_cycle_size",
"Number of frames in the intra refresh cycle",
OFFSET(qsv.int_ref_cycle_size),
AV_OPT_TYPE_INT, { .i64 = -1 }, -1, UINT16_MAX,
VE },
129 {
"int_ref_qp_delta",
"QP difference for the refresh MBs",
OFFSET(qsv.int_ref_qp_delta),
AV_OPT_TYPE_INT, { .i64 = INT16_MIN }, INT16_MIN, INT16_MAX,
VE },
130 {
"recovery_point_sei",
"Insert recovery point SEI messages",
OFFSET(qsv.recovery_point_sei),
AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 1,
VE },
140 {
"baseline",
NULL, 0,
AV_OPT_TYPE_CONST, { .i64 = MFX_PROFILE_AVC_BASELINE }, INT_MIN, INT_MAX,
VE,
"profile" },
144 {
"a53cc" ,
"Use A53 Closed Captions (if available)",
OFFSET(qsv.a53_cc),
AV_OPT_TYPE_INT, {.i64 = 1}, 0, 1,
VE},
168 #if FF_API_CODER_TYPE
172 {
"flags",
"+cgop" },
173 #if FF_API_PRIVATE_OPT
174 {
"b_strategy",
"-1" },
181 .long_name =
NULL_IF_CONFIG_SMALL(
"H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10 (Intel Quick Sync Video acceleration)"),
193 .priv_class = &
class,
196 .wrapper_name =
"qsv",
#define FF_CODEC_CAP_INIT_CLEANUP
The codec allows calling the close function for deallocation even if the init function returned a fai...
This structure describes decoded (raw) audio or video data.
#define LIBAVUTIL_VERSION_INT
static av_cold int init(AVCodecContext *avctx)
const char * av_default_item_name(void *ptr)
Return the context name.
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
#define AV_CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
int ff_qsv_encode(AVCodecContext *avctx, QSVEncContext *q, AVPacket *pkt, const AVFrame *frame, int *got_packet)
static const AVCodecDefault qsv_enc_defaults[]
int ff_qsv_enc_close(AVCodecContext *avctx, QSVEncContext *q)
static const AVOption options[]
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
planar YUV 4:2:0, 12bpp, 1 plane for Y and 1 plane for the UV components, which are interleaved (firs...
const char * name
Name of the codec implementation.
#define MFX_LOOKAHEAD_DS_UNKNOWN
AVCodec ff_h264_qsv_encoder
#define MFX_LOOKAHEAD_DS_OFF
#define MFX_LOOKAHEAD_DS_2x
Libavcodec external API header.
static int qsv_h264_set_encode_ctrl(AVCodecContext *avctx, const AVFrame *frame, mfxEncodeCtrl *enc_ctrl)
main external API structure.
#define AV_CODEC_CAP_HYBRID
Codec is potentially backed by a hardware implementation, but not necessarily.
Describe the class of an AVClass context structure.
int ff_qsv_enc_init(AVCodecContext *avctx, QSVEncContext *q)
HW acceleration through QSV, data[3] contains a pointer to the mfxFrameSurface1 structure.
static int qsv_enc_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *frame, int *got_packet)
static enum AVPixelFormat pix_fmts[]
static av_cold int qsv_enc_init(AVCodecContext *avctx)
common internal api header.
common internal and external API header
#define MFX_LOOKAHEAD_DS_4x
int ff_alloc_a53_sei(const AVFrame *frame, size_t prefix_len, void **data, size_t *sei_size)
Check AVFrame for A53 side data and allocate and fill SEI message with A53 info.
static av_cold int qsv_enc_close(AVCodecContext *avctx)
AVPixelFormat
Pixel format.
This structure stores compressed data.
SetEncodeCtrlCB * set_encode_ctrl_cb