mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-08 13:22:53 +02:00
hevc: properly handle no_rasl_output_flag when removing pictures from the DPB
Fixes ticket #4185.
Reviewed-By: Mickael Raulet <Mickael.Raulet@insa-rennes.fr>
Signed-off-by: Hendrik Leppkes <h.leppkes@gmail.com>
(cherry picked from commit 0118158efa
)
This commit is contained in:
parent
f7cb979766
commit
98fdd0baf3
@ -795,6 +795,8 @@ static int hls_slice_header(HEVCContext *s)
|
|||||||
s->HEVClc->tu.cu_qp_offset_cb = 0;
|
s->HEVClc->tu.cu_qp_offset_cb = 0;
|
||||||
s->HEVClc->tu.cu_qp_offset_cr = 0;
|
s->HEVClc->tu.cu_qp_offset_cr = 0;
|
||||||
|
|
||||||
|
s->no_rasl_output_flag = IS_IDR(s) || IS_BLA(s) || (s->nal_unit_type == NAL_CRA_NUT && s->last_eos);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3355,6 +3357,7 @@ static int hevc_update_thread_context(AVCodecContext *dst,
|
|||||||
s->pocTid0 = s0->pocTid0;
|
s->pocTid0 = s0->pocTid0;
|
||||||
s->max_ra = s0->max_ra;
|
s->max_ra = s0->max_ra;
|
||||||
s->eos = s0->eos;
|
s->eos = s0->eos;
|
||||||
|
s->no_rasl_output_flag = s0->no_rasl_output_flag;
|
||||||
|
|
||||||
s->is_nalff = s0->is_nalff;
|
s->is_nalff = s0->is_nalff;
|
||||||
s->nal_length_size = s0->nal_length_size;
|
s->nal_length_size = s0->nal_length_size;
|
||||||
@ -3459,6 +3462,7 @@ static av_cold int hevc_decode_init(AVCodecContext *avctx)
|
|||||||
|
|
||||||
s->enable_parallel_tiles = 0;
|
s->enable_parallel_tiles = 0;
|
||||||
s->picture_struct = 0;
|
s->picture_struct = 0;
|
||||||
|
s->eos = 1;
|
||||||
|
|
||||||
if(avctx->active_thread_type & FF_THREAD_SLICE)
|
if(avctx->active_thread_type & FF_THREAD_SLICE)
|
||||||
s->threads_number = avctx->thread_count;
|
s->threads_number = avctx->thread_count;
|
||||||
@ -3500,6 +3504,7 @@ static void hevc_decode_flush(AVCodecContext *avctx)
|
|||||||
HEVCContext *s = avctx->priv_data;
|
HEVCContext *s = avctx->priv_data;
|
||||||
ff_hevc_flush_dpb(s);
|
ff_hevc_flush_dpb(s);
|
||||||
s->max_ra = INT_MAX;
|
s->max_ra = INT_MAX;
|
||||||
|
s->eos = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define OFFSET(x) offsetof(HEVCContext, x)
|
#define OFFSET(x) offsetof(HEVCContext, x)
|
||||||
|
@ -842,6 +842,7 @@ typedef struct HEVCContext {
|
|||||||
int bs_height;
|
int bs_height;
|
||||||
|
|
||||||
int is_decoded;
|
int is_decoded;
|
||||||
|
int no_rasl_output_flag;
|
||||||
|
|
||||||
HEVCPredContext hpc;
|
HEVCPredContext hpc;
|
||||||
HEVCDSPContext hevcdsp;
|
HEVCDSPContext hevcdsp;
|
||||||
|
@ -174,7 +174,7 @@ int ff_hevc_output_frame(HEVCContext *s, AVFrame *out, int flush)
|
|||||||
int min_poc = INT_MAX;
|
int min_poc = INT_MAX;
|
||||||
int i, min_idx, ret;
|
int i, min_idx, ret;
|
||||||
|
|
||||||
if (s->sh.no_output_of_prior_pics_flag == 1) {
|
if (s->sh.no_output_of_prior_pics_flag == 1 && s->no_rasl_output_flag == 1) {
|
||||||
for (i = 0; i < FF_ARRAY_ELEMS(s->DPB); i++) {
|
for (i = 0; i < FF_ARRAY_ELEMS(s->DPB); i++) {
|
||||||
HEVCFrame *frame = &s->DPB[i];
|
HEVCFrame *frame = &s->DPB[i];
|
||||||
if (!(frame->flags & HEVC_FRAME_FLAG_BUMPING) && frame->poc != s->poc &&
|
if (!(frame->flags & HEVC_FRAME_FLAG_BUMPING) && frame->poc != s->poc &&
|
||||||
|
Loading…
Reference in New Issue
Block a user