mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-11-21 10:55:51 +02:00
vaapi_encode_h264: Support more complex reference structures
This commit is contained in:
parent
494bd8df78
commit
25c0ede93b
@ -47,6 +47,20 @@ static const uint8_t vaapi_encode_h264_sei_identifier_uuid[16] = {
|
||||
0x96, 0x75, 0x19, 0xd4, 0x1f, 0xea, 0xa9, 0x4d,
|
||||
};
|
||||
|
||||
typedef struct VAAPIEncodeH264Picture {
|
||||
int frame_num;
|
||||
int pic_order_cnt;
|
||||
|
||||
int64_t last_idr_frame;
|
||||
uint16_t idr_pic_id;
|
||||
|
||||
int primary_pic_type;
|
||||
int slice_type;
|
||||
|
||||
int cpb_delay;
|
||||
int dpb_delay;
|
||||
} VAAPIEncodeH264Picture;
|
||||
|
||||
typedef struct VAAPIEncodeH264Context {
|
||||
VAAPIEncodeContext common;
|
||||
|
||||
@ -67,18 +81,7 @@ typedef struct VAAPIEncodeH264Context {
|
||||
int fixed_qp_p;
|
||||
int fixed_qp_b;
|
||||
|
||||
// Stream state.
|
||||
int frame_num;
|
||||
int pic_order_cnt;
|
||||
int next_frame_num;
|
||||
int64_t last_idr_frame;
|
||||
int64_t idr_pic_count;
|
||||
|
||||
int primary_pic_type;
|
||||
int slice_type;
|
||||
|
||||
int cpb_delay;
|
||||
int dpb_delay;
|
||||
int dpb_frames;
|
||||
|
||||
// Writer structures.
|
||||
CodedBitstreamContext *cbc;
|
||||
@ -295,7 +298,6 @@ static int vaapi_encode_h264_init_sequence_params(AVCodecContext *avctx)
|
||||
H264RawPPS *pps = &priv->raw_pps;
|
||||
VAEncSequenceParameterBufferH264 *vseq = ctx->codec_sequence_params;
|
||||
VAEncPictureParameterBufferH264 *vpic = ctx->codec_picture_params;
|
||||
int dpb_frames;
|
||||
|
||||
memset(&priv->current_access_unit, 0,
|
||||
sizeof(priv->current_access_unit));
|
||||
@ -322,9 +324,9 @@ static int vaapi_encode_h264_init_sequence_params(AVCodecContext *avctx)
|
||||
}
|
||||
|
||||
if (ctx->gop_size == 1)
|
||||
dpb_frames = 0;
|
||||
priv->dpb_frames = 0;
|
||||
else
|
||||
dpb_frames = 1 + (ctx->b_per_p > 0);
|
||||
priv->dpb_frames = 1 + ctx->max_b_depth;
|
||||
|
||||
if (avctx->level != FF_LEVEL_UNKNOWN) {
|
||||
sps->level_idc = avctx->level;
|
||||
@ -335,7 +337,7 @@ static int vaapi_encode_h264_init_sequence_params(AVCodecContext *avctx)
|
||||
avctx->bit_rate,
|
||||
priv->mb_width * 16,
|
||||
priv->mb_height * 16,
|
||||
dpb_frames);
|
||||
priv->dpb_frames);
|
||||
if (level) {
|
||||
av_log(avctx, AV_LOG_VERBOSE, "Using level %s.\n", level->name);
|
||||
if (level->constraint_set3_flag)
|
||||
@ -353,10 +355,9 @@ static int vaapi_encode_h264_init_sequence_params(AVCodecContext *avctx)
|
||||
|
||||
sps->log2_max_frame_num_minus4 = 4;
|
||||
sps->pic_order_cnt_type = 0;
|
||||
sps->log2_max_pic_order_cnt_lsb_minus4 =
|
||||
av_clip(av_log2(ctx->b_per_p + 1) - 2, 0, 12);
|
||||
sps->log2_max_pic_order_cnt_lsb_minus4 = 4;
|
||||
|
||||
sps->max_num_ref_frames = dpb_frames;
|
||||
sps->max_num_ref_frames = priv->dpb_frames;
|
||||
|
||||
sps->pic_width_in_mbs_minus1 = priv->mb_width - 1;
|
||||
sps->pic_height_in_map_units_minus1 = priv->mb_height - 1;
|
||||
@ -495,8 +496,8 @@ static int vaapi_encode_h264_init_sequence_params(AVCodecContext *avctx)
|
||||
sps->vui.motion_vectors_over_pic_boundaries_flag = 1;
|
||||
sps->vui.log2_max_mv_length_horizontal = 15;
|
||||
sps->vui.log2_max_mv_length_vertical = 15;
|
||||
sps->vui.max_num_reorder_frames = (ctx->b_per_p > 0);
|
||||
sps->vui.max_dec_frame_buffering = sps->max_num_ref_frames;
|
||||
sps->vui.max_num_reorder_frames = ctx->max_b_depth;
|
||||
sps->vui.max_dec_frame_buffering = ctx->max_b_depth + 1;
|
||||
|
||||
pps->nal_unit_header.nal_ref_idc = 3;
|
||||
pps->nal_unit_header.nal_unit_type = H264_NAL_PPS;
|
||||
@ -617,7 +618,9 @@ static int vaapi_encode_h264_init_picture_params(AVCodecContext *avctx,
|
||||
{
|
||||
VAAPIEncodeContext *ctx = avctx->priv_data;
|
||||
VAAPIEncodeH264Context *priv = avctx->priv_data;
|
||||
H264RawSPS *sps = &priv->raw_sps;
|
||||
VAAPIEncodeH264Picture *hpic = pic->priv_data;
|
||||
VAAPIEncodePicture *prev = pic->prev;
|
||||
VAAPIEncodeH264Picture *hprev = prev ? prev->priv_data : NULL;
|
||||
VAEncPictureParameterBufferH264 *vpic = pic->codec_picture_params;
|
||||
int i;
|
||||
|
||||
@ -626,37 +629,35 @@ static int vaapi_encode_h264_init_picture_params(AVCodecContext *avctx,
|
||||
|
||||
if (pic->type == PICTURE_TYPE_IDR) {
|
||||
av_assert0(pic->display_order == pic->encode_order);
|
||||
priv->frame_num = 0;
|
||||
priv->next_frame_num = 1;
|
||||
priv->cpb_delay = 0;
|
||||
priv->last_idr_frame = pic->display_order;
|
||||
++priv->idr_pic_count;
|
||||
|
||||
priv->slice_type = 7;
|
||||
priv->primary_pic_type = 0;
|
||||
hpic->frame_num = 0;
|
||||
hpic->last_idr_frame = pic->display_order;
|
||||
hpic->idr_pic_id = hprev ? hprev->idr_pic_id + 1 : 0;
|
||||
|
||||
hpic->primary_pic_type = 0;
|
||||
hpic->slice_type = 7;
|
||||
} else {
|
||||
priv->frame_num = priv->next_frame_num;
|
||||
av_assert0(prev);
|
||||
|
||||
if (pic->type != PICTURE_TYPE_B) {
|
||||
// Reference picture, so frame_num advances.
|
||||
priv->next_frame_num = (priv->frame_num + 1) &
|
||||
((1 << (4 + sps->log2_max_frame_num_minus4)) - 1);
|
||||
}
|
||||
++priv->cpb_delay;
|
||||
hpic->frame_num = hprev->frame_num + prev->is_reference;
|
||||
|
||||
hpic->last_idr_frame = hprev->last_idr_frame;
|
||||
hpic->idr_pic_id = hprev->idr_pic_id;
|
||||
|
||||
if (pic->type == PICTURE_TYPE_I) {
|
||||
priv->slice_type = 7;
|
||||
priv->primary_pic_type = 0;
|
||||
hpic->slice_type = 7;
|
||||
hpic->primary_pic_type = 0;
|
||||
} else if (pic->type == PICTURE_TYPE_P) {
|
||||
priv->slice_type = 5;
|
||||
priv->primary_pic_type = 1;
|
||||
hpic->slice_type = 5;
|
||||
hpic->primary_pic_type = 1;
|
||||
} else {
|
||||
priv->slice_type = 6;
|
||||
priv->primary_pic_type = 2;
|
||||
hpic->slice_type = 6;
|
||||
hpic->primary_pic_type = 2;
|
||||
}
|
||||
}
|
||||
priv->pic_order_cnt = pic->display_order - priv->last_idr_frame;
|
||||
priv->dpb_delay = pic->display_order - pic->encode_order + 1;
|
||||
hpic->pic_order_cnt = pic->display_order - hpic->last_idr_frame;
|
||||
hpic->dpb_delay = pic->display_order - pic->encode_order + ctx->max_b_depth;
|
||||
hpic->cpb_delay = pic->encode_order - hpic->last_idr_frame;
|
||||
|
||||
if (priv->aud) {
|
||||
priv->aud_needed = 1;
|
||||
@ -664,7 +665,7 @@ static int vaapi_encode_h264_init_picture_params(AVCodecContext *avctx,
|
||||
.nal_unit_header = {
|
||||
.nal_unit_type = H264_NAL_AUD,
|
||||
},
|
||||
.primary_pic_type = priv->primary_pic_type,
|
||||
.primary_pic_type = hpic->primary_pic_type,
|
||||
};
|
||||
} else {
|
||||
priv->aud_needed = 0;
|
||||
@ -681,8 +682,8 @@ static int vaapi_encode_h264_init_picture_params(AVCodecContext *avctx,
|
||||
|
||||
if (priv->sei & SEI_TIMING) {
|
||||
priv->sei_pic_timing = (H264RawSEIPicTiming) {
|
||||
.cpb_removal_delay = 2 * priv->cpb_delay,
|
||||
.dpb_output_delay = 2 * priv->dpb_delay,
|
||||
.cpb_removal_delay = 2 * hpic->cpb_delay,
|
||||
.dpb_output_delay = 2 * hpic->dpb_delay,
|
||||
};
|
||||
|
||||
priv->sei_needed |= SEI_TIMING;
|
||||
@ -700,25 +701,25 @@ static int vaapi_encode_h264_init_picture_params(AVCodecContext *avctx,
|
||||
|
||||
vpic->CurrPic = (VAPictureH264) {
|
||||
.picture_id = pic->recon_surface,
|
||||
.frame_idx = priv->frame_num,
|
||||
.frame_idx = hpic->frame_num,
|
||||
.flags = 0,
|
||||
.TopFieldOrderCnt = priv->pic_order_cnt,
|
||||
.BottomFieldOrderCnt = priv->pic_order_cnt,
|
||||
.TopFieldOrderCnt = hpic->pic_order_cnt,
|
||||
.BottomFieldOrderCnt = hpic->pic_order_cnt,
|
||||
};
|
||||
|
||||
for (i = 0; i < pic->nb_refs; i++) {
|
||||
VAAPIEncodePicture *ref = pic->refs[i];
|
||||
unsigned int frame_num = (ref->encode_order - priv->last_idr_frame) &
|
||||
((1 << (4 + sps->log2_max_frame_num_minus4)) - 1);
|
||||
unsigned int pic_order_cnt = ref->display_order - priv->last_idr_frame;
|
||||
VAAPIEncodePicture *ref = pic->refs[i];
|
||||
VAAPIEncodeH264Picture *href;
|
||||
|
||||
av_assert0(ref && ref->encode_order < pic->encode_order);
|
||||
href = ref->priv_data;
|
||||
|
||||
vpic->ReferenceFrames[i] = (VAPictureH264) {
|
||||
.picture_id = ref->recon_surface,
|
||||
.frame_idx = frame_num,
|
||||
.frame_idx = href->frame_num,
|
||||
.flags = VA_PICTURE_H264_SHORT_TERM_REFERENCE,
|
||||
.TopFieldOrderCnt = pic_order_cnt,
|
||||
.BottomFieldOrderCnt = pic_order_cnt,
|
||||
.TopFieldOrderCnt = href->pic_order_cnt,
|
||||
.BottomFieldOrderCnt = href->pic_order_cnt,
|
||||
};
|
||||
}
|
||||
for (; i < FF_ARRAY_ELEMS(vpic->ReferenceFrames); i++) {
|
||||
@ -730,7 +731,7 @@ static int vaapi_encode_h264_init_picture_params(AVCodecContext *avctx,
|
||||
|
||||
vpic->coded_buf = pic->output_buffer;
|
||||
|
||||
vpic->frame_num = priv->frame_num;
|
||||
vpic->frame_num = hpic->frame_num;
|
||||
|
||||
vpic->pic_fields.bits.idr_pic_flag = (pic->type == PICTURE_TYPE_IDR);
|
||||
vpic->pic_fields.bits.reference_pic_flag = (pic->type != PICTURE_TYPE_B);
|
||||
@ -738,35 +739,134 @@ static int vaapi_encode_h264_init_picture_params(AVCodecContext *avctx,
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void vaapi_encode_h264_default_ref_pic_list(AVCodecContext *avctx,
|
||||
VAAPIEncodePicture *pic,
|
||||
VAAPIEncodePicture **rpl0,
|
||||
VAAPIEncodePicture **rpl1,
|
||||
int *rpl_size)
|
||||
{
|
||||
VAAPIEncodePicture *prev;
|
||||
VAAPIEncodeH264Picture *hp, *hn, *hc;
|
||||
int i, j, n = 0;
|
||||
|
||||
prev = pic->prev;
|
||||
av_assert0(prev);
|
||||
hp = pic->priv_data;
|
||||
|
||||
for (i = 0; i < pic->prev->nb_dpb_pics; i++) {
|
||||
hn = prev->dpb[i]->priv_data;
|
||||
av_assert0(hn->frame_num < hp->frame_num);
|
||||
|
||||
if (pic->type == PICTURE_TYPE_P) {
|
||||
for (j = n; j > 0; j--) {
|
||||
hc = rpl0[j - 1]->priv_data;
|
||||
av_assert0(hc->frame_num != hn->frame_num);
|
||||
if (hc->frame_num > hn->frame_num)
|
||||
break;
|
||||
rpl0[j] = rpl0[j - 1];
|
||||
}
|
||||
rpl0[j] = prev->dpb[i];
|
||||
|
||||
} else if (pic->type == PICTURE_TYPE_B) {
|
||||
for (j = n; j > 0; j--) {
|
||||
hc = rpl0[j - 1]->priv_data;
|
||||
av_assert0(hc->pic_order_cnt != hp->pic_order_cnt);
|
||||
if (hc->pic_order_cnt < hp->pic_order_cnt) {
|
||||
if (hn->pic_order_cnt > hp->pic_order_cnt ||
|
||||
hn->pic_order_cnt < hc->pic_order_cnt)
|
||||
break;
|
||||
} else {
|
||||
if (hn->pic_order_cnt > hc->pic_order_cnt)
|
||||
break;
|
||||
}
|
||||
rpl0[j] = rpl0[j - 1];
|
||||
}
|
||||
rpl0[j] = prev->dpb[i];
|
||||
|
||||
for (j = n; j > 0; j--) {
|
||||
hc = rpl1[j - 1]->priv_data;
|
||||
av_assert0(hc->pic_order_cnt != hp->pic_order_cnt);
|
||||
if (hc->pic_order_cnt > hp->pic_order_cnt) {
|
||||
if (hn->pic_order_cnt < hp->pic_order_cnt ||
|
||||
hn->pic_order_cnt > hc->pic_order_cnt)
|
||||
break;
|
||||
} else {
|
||||
if (hn->pic_order_cnt < hc->pic_order_cnt)
|
||||
break;
|
||||
}
|
||||
rpl1[j] = rpl1[j - 1];
|
||||
}
|
||||
rpl1[j] = prev->dpb[i];
|
||||
}
|
||||
|
||||
++n;
|
||||
}
|
||||
|
||||
if (pic->type == PICTURE_TYPE_B) {
|
||||
for (i = 0; i < n; i++) {
|
||||
if (rpl0[i] != rpl1[i])
|
||||
break;
|
||||
}
|
||||
if (i == n)
|
||||
FFSWAP(VAAPIEncodePicture*, rpl1[0], rpl1[1]);
|
||||
}
|
||||
|
||||
if (pic->type == PICTURE_TYPE_P ||
|
||||
pic->type == PICTURE_TYPE_B) {
|
||||
av_log(avctx, AV_LOG_DEBUG, "Default RefPicList0 for fn=%d/poc=%d:",
|
||||
hp->frame_num, hp->pic_order_cnt);
|
||||
for (i = 0; i < n; i++) {
|
||||
hn = rpl0[i]->priv_data;
|
||||
av_log(avctx, AV_LOG_DEBUG, " fn=%d/poc=%d",
|
||||
hn->frame_num, hn->pic_order_cnt);
|
||||
}
|
||||
av_log(avctx, AV_LOG_DEBUG, "\n");
|
||||
}
|
||||
if (pic->type == PICTURE_TYPE_B) {
|
||||
av_log(avctx, AV_LOG_DEBUG, "Default RefPicList1 for fn=%d/poc=%d:",
|
||||
hp->frame_num, hp->pic_order_cnt);
|
||||
for (i = 0; i < n; i++) {
|
||||
hn = rpl1[i]->priv_data;
|
||||
av_log(avctx, AV_LOG_DEBUG, " fn=%d/poc=%d",
|
||||
hn->frame_num, hn->pic_order_cnt);
|
||||
}
|
||||
av_log(avctx, AV_LOG_DEBUG, "\n");
|
||||
}
|
||||
|
||||
*rpl_size = n;
|
||||
}
|
||||
|
||||
static int vaapi_encode_h264_init_slice_params(AVCodecContext *avctx,
|
||||
VAAPIEncodePicture *pic,
|
||||
VAAPIEncodeSlice *slice)
|
||||
{
|
||||
VAAPIEncodeH264Context *priv = avctx->priv_data;
|
||||
VAAPIEncodeH264Picture *hpic = pic->priv_data;
|
||||
VAAPIEncodePicture *prev = pic->prev;
|
||||
H264RawSPS *sps = &priv->raw_sps;
|
||||
H264RawPPS *pps = &priv->raw_pps;
|
||||
H264RawSliceHeader *sh = &priv->raw_slice.header;
|
||||
VAEncPictureParameterBufferH264 *vpic = pic->codec_picture_params;
|
||||
VAEncSliceParameterBufferH264 *vslice = slice->codec_slice_params;
|
||||
int i;
|
||||
int i, j;
|
||||
|
||||
if (pic->type == PICTURE_TYPE_IDR) {
|
||||
sh->nal_unit_header.nal_unit_type = H264_NAL_IDR_SLICE;
|
||||
sh->nal_unit_header.nal_ref_idc = 3;
|
||||
} else {
|
||||
sh->nal_unit_header.nal_unit_type = H264_NAL_SLICE;
|
||||
sh->nal_unit_header.nal_ref_idc = pic->type != PICTURE_TYPE_B;
|
||||
sh->nal_unit_header.nal_ref_idc = pic->is_reference;
|
||||
}
|
||||
|
||||
sh->first_mb_in_slice = slice->block_start;
|
||||
sh->slice_type = priv->slice_type;
|
||||
sh->slice_type = hpic->slice_type;
|
||||
|
||||
sh->pic_parameter_set_id = pps->pic_parameter_set_id;
|
||||
|
||||
sh->frame_num = priv->frame_num;
|
||||
sh->idr_pic_id = priv->idr_pic_count;
|
||||
|
||||
sh->pic_order_cnt_lsb = priv->pic_order_cnt &
|
||||
sh->frame_num = hpic->frame_num &
|
||||
((1 << (4 + sps->log2_max_frame_num_minus4)) - 1);
|
||||
sh->idr_pic_id = hpic->idr_pic_id;
|
||||
sh->pic_order_cnt_lsb = hpic->pic_order_cnt &
|
||||
((1 << (4 + sps->log2_max_pic_order_cnt_lsb_minus4)) - 1);
|
||||
|
||||
sh->direct_spatial_mv_pred_flag = 1;
|
||||
@ -778,6 +878,146 @@ static int vaapi_encode_h264_init_slice_params(AVCodecContext *avctx,
|
||||
else
|
||||
sh->slice_qp_delta = priv->fixed_qp_idr - (pps->pic_init_qp_minus26 + 26);
|
||||
|
||||
if (pic->is_reference && pic->type != PICTURE_TYPE_IDR) {
|
||||
VAAPIEncodePicture *discard_list[MAX_DPB_SIZE];
|
||||
int discard = 0, keep = 0;
|
||||
|
||||
// Discard everything which is in the DPB of the previous frame but
|
||||
// not in the DPB of this one.
|
||||
for (i = 0; i < prev->nb_dpb_pics; i++) {
|
||||
for (j = 0; j < pic->nb_dpb_pics; j++) {
|
||||
if (prev->dpb[i] == pic->dpb[j])
|
||||
break;
|
||||
}
|
||||
if (j == pic->nb_dpb_pics) {
|
||||
discard_list[discard] = prev->dpb[i];
|
||||
++discard;
|
||||
} else {
|
||||
++keep;
|
||||
}
|
||||
}
|
||||
av_assert0(keep <= priv->dpb_frames);
|
||||
|
||||
if (discard == 0) {
|
||||
sh->adaptive_ref_pic_marking_mode_flag = 0;
|
||||
} else {
|
||||
sh->adaptive_ref_pic_marking_mode_flag = 1;
|
||||
for (i = 0; i < discard; i++) {
|
||||
VAAPIEncodeH264Picture *old = discard_list[i]->priv_data;
|
||||
av_assert0(old->frame_num < hpic->frame_num);
|
||||
sh->mmco[i].memory_management_control_operation = 1;
|
||||
sh->mmco[i].difference_of_pic_nums_minus1 =
|
||||
hpic->frame_num - old->frame_num - 1;
|
||||
}
|
||||
sh->mmco[i].memory_management_control_operation = 0;
|
||||
}
|
||||
}
|
||||
|
||||
// If the intended references are not the first entries of RefPicListN
|
||||
// by default, use ref-pic-list-modification to move them there.
|
||||
if (pic->type == PICTURE_TYPE_P || pic->type == PICTURE_TYPE_B) {
|
||||
VAAPIEncodePicture *def_l0[MAX_DPB_SIZE], *def_l1[MAX_DPB_SIZE];
|
||||
VAAPIEncodeH264Picture *href;
|
||||
int n;
|
||||
|
||||
vaapi_encode_h264_default_ref_pic_list(avctx, pic,
|
||||
def_l0, def_l1, &n);
|
||||
|
||||
if (pic->type == PICTURE_TYPE_P) {
|
||||
int need_rplm = 0;
|
||||
for (i = 0; i < pic->nb_refs; i++) {
|
||||
av_assert0(pic->refs[i]);
|
||||
if (pic->refs[i] != def_l0[i])
|
||||
need_rplm = 1;
|
||||
}
|
||||
|
||||
sh->ref_pic_list_modification_flag_l0 = need_rplm;
|
||||
if (need_rplm) {
|
||||
int pic_num = hpic->frame_num;
|
||||
for (i = 0; i < pic->nb_refs; i++) {
|
||||
href = pic->refs[i]->priv_data;
|
||||
av_assert0(href->frame_num != pic_num);
|
||||
if (href->frame_num < pic_num) {
|
||||
sh->rplm_l0[i].modification_of_pic_nums_idc = 0;
|
||||
sh->rplm_l0[i].abs_diff_pic_num_minus1 =
|
||||
pic_num - href->frame_num - 1;
|
||||
} else {
|
||||
sh->rplm_l0[i].modification_of_pic_nums_idc = 1;
|
||||
sh->rplm_l0[i].abs_diff_pic_num_minus1 =
|
||||
href->frame_num - pic_num - 1;
|
||||
}
|
||||
pic_num = href->frame_num;
|
||||
}
|
||||
sh->rplm_l0[i].modification_of_pic_nums_idc = 3;
|
||||
}
|
||||
|
||||
} else {
|
||||
int need_rplm_l0 = 0, need_rplm_l1 = 0;
|
||||
int n0 = 0, n1 = 0;
|
||||
for (i = 0; i < pic->nb_refs; i++) {
|
||||
av_assert0(pic->refs[i]);
|
||||
href = pic->refs[i]->priv_data;
|
||||
av_assert0(href->pic_order_cnt != hpic->pic_order_cnt);
|
||||
if (href->pic_order_cnt < hpic->pic_order_cnt) {
|
||||
if (pic->refs[i] != def_l0[n0])
|
||||
need_rplm_l0 = 1;
|
||||
++n0;
|
||||
} else {
|
||||
if (pic->refs[i] != def_l1[n1])
|
||||
need_rplm_l1 = 1;
|
||||
++n1;
|
||||
}
|
||||
}
|
||||
|
||||
sh->ref_pic_list_modification_flag_l0 = need_rplm_l0;
|
||||
if (need_rplm_l0) {
|
||||
int pic_num = hpic->frame_num;
|
||||
for (i = j = 0; i < pic->nb_refs; i++) {
|
||||
href = pic->refs[i]->priv_data;
|
||||
if (href->pic_order_cnt > hpic->pic_order_cnt)
|
||||
continue;
|
||||
av_assert0(href->frame_num != pic_num);
|
||||
if (href->frame_num < pic_num) {
|
||||
sh->rplm_l0[j].modification_of_pic_nums_idc = 0;
|
||||
sh->rplm_l0[j].abs_diff_pic_num_minus1 =
|
||||
pic_num - href->frame_num - 1;
|
||||
} else {
|
||||
sh->rplm_l0[j].modification_of_pic_nums_idc = 1;
|
||||
sh->rplm_l0[j].abs_diff_pic_num_minus1 =
|
||||
href->frame_num - pic_num - 1;
|
||||
}
|
||||
pic_num = href->frame_num;
|
||||
++j;
|
||||
}
|
||||
av_assert0(j == n0);
|
||||
sh->rplm_l0[j].modification_of_pic_nums_idc = 3;
|
||||
}
|
||||
|
||||
sh->ref_pic_list_modification_flag_l1 = need_rplm_l1;
|
||||
if (need_rplm_l1) {
|
||||
int pic_num = hpic->frame_num;
|
||||
for (i = j = 0; i < pic->nb_refs; i++) {
|
||||
href = pic->refs[i]->priv_data;
|
||||
if (href->pic_order_cnt < hpic->pic_order_cnt)
|
||||
continue;
|
||||
av_assert0(href->frame_num != pic_num);
|
||||
if (href->frame_num < pic_num) {
|
||||
sh->rplm_l1[j].modification_of_pic_nums_idc = 0;
|
||||
sh->rplm_l1[j].abs_diff_pic_num_minus1 =
|
||||
pic_num - href->frame_num - 1;
|
||||
} else {
|
||||
sh->rplm_l1[j].modification_of_pic_nums_idc = 1;
|
||||
sh->rplm_l1[j].abs_diff_pic_num_minus1 =
|
||||
href->frame_num - pic_num - 1;
|
||||
}
|
||||
pic_num = href->frame_num;
|
||||
++j;
|
||||
}
|
||||
av_assert0(j == n1);
|
||||
sh->rplm_l1[j].modification_of_pic_nums_idc = 3;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
vslice->macroblock_address = slice->block_start;
|
||||
vslice->num_macroblocks = slice->block_size;
|
||||
@ -904,10 +1144,13 @@ static const VAAPIEncodeType vaapi_encode_type_h264 = {
|
||||
|
||||
.flags = FLAG_SLICE_CONTROL |
|
||||
FLAG_B_PICTURES |
|
||||
FLAG_B_PICTURE_REFERENCES |
|
||||
FLAG_NON_IDR_KEY_PICTURES,
|
||||
|
||||
.configure = &vaapi_encode_h264_configure,
|
||||
|
||||
.picture_priv_data_size = sizeof(VAAPIEncodeH264Picture),
|
||||
|
||||
.sequence_params_size = sizeof(VAEncSequenceParameterBufferH264),
|
||||
.init_sequence_params = &vaapi_encode_h264_init_sequence_params,
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user