[FFmpeg-devel] [PATCH v3 1/2] avcodec/vvc: Fix output and unref a frame which isn't decoding yet
Nuo Mi
nuomi2021 at gmail.com
Mon Sep 16 06:42:05 EEST 2024
On Sun, Sep 15, 2024 at 4:54 PM Anton Khirnov <anton at khirnov.net> wrote:
> Quoting Nuo Mi (2024-09-15 10:49:31)
> > On Sun, Sep 15, 2024 at 1:04 PM Zhao Zhili <quinkblack at foxmail.com>
> wrote:
> >
> > > From: Zhao Zhili <zhilizhao at tencent.com>
> > >
> > > ff_vvc_output_frame is called before actually decoding. It's possible
> > > for ff_vvc_output_frame to select current frame to output. If current
> > > frame is nonref frame, it will be released by ff_vvc_unref_frame.
> > >
> > > Fix this by always marking the current frame with
> > > VVC_FRAME_FLAG_SHORT_REF, as is done by the HEVC decoder.
> > > ---
> > > libavcodec/vvc/refs.c | 2 +-
> > > 1 file changed, 1 insertion(+), 1 deletion(-)
> > >
> > > diff --git a/libavcodec/vvc/refs.c b/libavcodec/vvc/refs.c
> > > index bebcef7fd6..133ff9eaba 100644
> > > --- a/libavcodec/vvc/refs.c
> > > +++ b/libavcodec/vvc/refs.c
> > > @@ -193,7 +193,7 @@ int ff_vvc_set_new_ref(VVCContext *s,
> VVCFrameContext
> > > *fc, AVFrame **frame)
> > > if (s->no_output_before_recovery_flag && (IS_RASL(s) ||
> > > !GDR_IS_RECOVERED(s)))
> > > ref->flags = VVC_FRAME_FLAG_SHORT_REF;
> > > else if (ph->r->ph_pic_output_flag)
> > > - ref->flags = VVC_FRAME_FLAG_OUTPUT;
> > > + ref->flags = VVC_FRAME_FLAG_OUTPUT | VVC_FRAME_FLAG_SHORT_REF;
> > >
> > > if (!ph->r->ph_non_ref_pic_flag)
> > > ref->flags |= VVC_FRAME_FLAG_SHORT_REF;
> > > --
> > > 2.42.0
> > >
> > Thank you, Zhili.
> > Applied.
> >
> > Hi James,
> > Could you help merge
> >
> https://patchwork.ffmpeg.org/project/ffmpeg/patch/tencent_60CD804FDAD504277B38A716714D13202007@qq.com/
> > and add the clip to fate?
>
> Just FYI, the official way to request samples upload is add
> samples-request at ffmpeg.org to Cc. James is one of the people on that
> list, but not the only one.
sure, thank you for the reminder
>
> --
> Anton Khirnov
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request at ffmpeg.org with subject "unsubscribe".
>
More information about the ffmpeg-devel
mailing list