mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
hevc: Track long and short term RPS size for VDPAU
Today, we track the short term RPS size for DXVA, but only if the SliceHeader RPS is being used. Otherwise it's left uninitialized. NVIDIA's VDPAU implementation requires that the size be accurately tracked even if an SPS RPS is being used. In this case, it's really counting the size of the RPS idx information, but you end up with mangled output if the value is not accurate. VDPAU also needs the size of the long term RPS. Signed-off-by: Philip Langdale <philipl@overt.org> Signed-off-by: Rémi Denis-Courmont <remi@remlab.net> Signed-off-by: Luca Barbato <lu_zero@gentoo.org>
This commit is contained in:
parent
8c399bd5ce
commit
8958c5c64d
@ -533,7 +533,7 @@ static int hls_slice_header(HEVCContext *s)
|
|||||||
sh->colour_plane_id = get_bits(gb, 2);
|
sh->colour_plane_id = get_bits(gb, 2);
|
||||||
|
|
||||||
if (!IS_IDR(s)) {
|
if (!IS_IDR(s)) {
|
||||||
int poc;
|
int poc, pos;
|
||||||
|
|
||||||
sh->pic_order_cnt_lsb = get_bits(gb, s->ps.sps->log2_max_poc_lsb);
|
sh->pic_order_cnt_lsb = get_bits(gb, s->ps.sps->log2_max_poc_lsb);
|
||||||
poc = ff_hevc_compute_poc(s, sh->pic_order_cnt_lsb);
|
poc = ff_hevc_compute_poc(s, sh->pic_order_cnt_lsb);
|
||||||
@ -547,13 +547,12 @@ static int hls_slice_header(HEVCContext *s)
|
|||||||
s->poc = poc;
|
s->poc = poc;
|
||||||
|
|
||||||
sh->short_term_ref_pic_set_sps_flag = get_bits1(gb);
|
sh->short_term_ref_pic_set_sps_flag = get_bits1(gb);
|
||||||
|
pos = get_bits_left(gb);
|
||||||
if (!sh->short_term_ref_pic_set_sps_flag) {
|
if (!sh->short_term_ref_pic_set_sps_flag) {
|
||||||
int pos = get_bits_left(gb);
|
|
||||||
ret = ff_hevc_decode_short_term_rps(gb, s->avctx, &sh->slice_rps, s->ps.sps, 1);
|
ret = ff_hevc_decode_short_term_rps(gb, s->avctx, &sh->slice_rps, s->ps.sps, 1);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
sh->short_term_ref_pic_set_size = pos - get_bits_left(gb);
|
|
||||||
sh->short_term_rps = &sh->slice_rps;
|
sh->short_term_rps = &sh->slice_rps;
|
||||||
} else {
|
} else {
|
||||||
int numbits, rps_idx;
|
int numbits, rps_idx;
|
||||||
@ -567,13 +566,16 @@ static int hls_slice_header(HEVCContext *s)
|
|||||||
rps_idx = numbits > 0 ? get_bits(gb, numbits) : 0;
|
rps_idx = numbits > 0 ? get_bits(gb, numbits) : 0;
|
||||||
sh->short_term_rps = &s->ps.sps->st_rps[rps_idx];
|
sh->short_term_rps = &s->ps.sps->st_rps[rps_idx];
|
||||||
}
|
}
|
||||||
|
sh->short_term_ref_pic_set_size = pos - get_bits_left(gb);
|
||||||
|
|
||||||
|
pos = get_bits_left(gb);
|
||||||
ret = decode_lt_rps(s, &sh->long_term_rps, gb);
|
ret = decode_lt_rps(s, &sh->long_term_rps, gb);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
av_log(s->avctx, AV_LOG_WARNING, "Invalid long term RPS.\n");
|
av_log(s->avctx, AV_LOG_WARNING, "Invalid long term RPS.\n");
|
||||||
if (s->avctx->err_recognition & AV_EF_EXPLODE)
|
if (s->avctx->err_recognition & AV_EF_EXPLODE)
|
||||||
return AVERROR_INVALIDDATA;
|
return AVERROR_INVALIDDATA;
|
||||||
}
|
}
|
||||||
|
sh->long_term_ref_pic_set_size = pos - get_bits_left(gb);
|
||||||
|
|
||||||
if (s->ps.sps->sps_temporal_mvp_enabled_flag)
|
if (s->ps.sps->sps_temporal_mvp_enabled_flag)
|
||||||
sh->slice_temporal_mvp_enabled_flag = get_bits1(gb);
|
sh->slice_temporal_mvp_enabled_flag = get_bits1(gb);
|
||||||
|
@ -559,6 +559,7 @@ typedef struct SliceHeader {
|
|||||||
int short_term_ref_pic_set_size;
|
int short_term_ref_pic_set_size;
|
||||||
ShortTermRPS slice_rps;
|
ShortTermRPS slice_rps;
|
||||||
const ShortTermRPS *short_term_rps;
|
const ShortTermRPS *short_term_rps;
|
||||||
|
int long_term_ref_pic_set_size;
|
||||||
LongTermRPS long_term_rps;
|
LongTermRPS long_term_rps;
|
||||||
unsigned int list_entry_lx[2][32];
|
unsigned int list_entry_lx[2][32];
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user