[FFmpeg-devel] [PATCH] avcodec/vvc: Fix output and unref a frame which isn't decoding yet
Zhao Zhili
quinkblack at foxmail.com
Fri Sep 13 08:19:48 EEST 2024
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.
---
fate sample:
https://drive.google.com/file/d/1U5WGWeSsMFiEkhsl_vL4NiMma-LLh02t/view?usp=drive_link
md5sum:
8054b4b8e62c0171476b40206d044590 Hierarchical.bit
libavcodec/vvc/refs.c | 11 +++----
tests/fate/vvc.mak | 1 +
tests/ref/fate/vvc-conformance-Hierarchical | 35 +++++++++++++++++++++
3 files changed, 40 insertions(+), 7 deletions(-)
create mode 100644 tests/ref/fate/vvc-conformance-Hierarchical
diff --git a/libavcodec/vvc/refs.c b/libavcodec/vvc/refs.c
index bebcef7fd6..d3663c7c69 100644
--- a/libavcodec/vvc/refs.c
+++ b/libavcodec/vvc/refs.c
@@ -190,13 +190,10 @@ int ff_vvc_set_new_ref(VVCContext *s, VVCFrameContext *fc, AVFrame **frame)
*frame = ref->frame;
fc->ref = ref;
- 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;
-
- if (!ph->r->ph_non_ref_pic_flag)
- ref->flags |= VVC_FRAME_FLAG_SHORT_REF;
+ ref->flags = VVC_FRAME_FLAG_SHORT_REF;
+ if (ph->r->ph_pic_output_flag && !(s->no_output_before_recovery_flag &&
+ (IS_RASL(s) || !GDR_IS_RECOVERED(s))))
+ ref->flags |= VVC_FRAME_FLAG_OUTPUT;
ref->poc = poc;
ref->sequence = s->seq_decode;
diff --git a/tests/fate/vvc.mak b/tests/fate/vvc.mak
index 5335460263..7fd0a47214 100644
--- a/tests/fate/vvc.mak
+++ b/tests/fate/vvc.mak
@@ -1,5 +1,6 @@
VVC_SAMPLES_8BIT = \
CodingToolsSets_A_2 \
+ Hierarchical \
VVC_SAMPLES_10BIT = \
APSALF_A_2 \
diff --git a/tests/ref/fate/vvc-conformance-Hierarchical b/tests/ref/fate/vvc-conformance-Hierarchical
new file mode 100644
index 0000000000..0797305b9a
--- /dev/null
+++ b/tests/ref/fate/vvc-conformance-Hierarchical
@@ -0,0 +1,35 @@
+#tb 0: 1/25
+#media_type 0: video
+#codec_id 0: rawvideo
+#dimensions 0: 480x320
+#sar 0: 0/1
+0, 0, 0, 1, 230400, 0x3293f7f1
+0, 1, 1, 1, 230400, 0xe2570fa4
+0, 2, 2, 1, 230400, 0xecd608fb
+0, 3, 3, 1, 230400, 0xea46f9f4
+0, 4, 4, 1, 230400, 0xb715d24a
+0, 5, 5, 1, 230400, 0x69faaf46
+0, 6, 6, 1, 230400, 0xf9a362db
+0, 7, 7, 1, 230400, 0x2dcd19ca
+0, 8, 8, 1, 230400, 0xf8fda185
+0, 9, 9, 1, 230400, 0x48a35bfd
+0, 10, 10, 1, 230400, 0x27efe832
+0, 11, 11, 1, 230400, 0x74279617
+0, 12, 12, 1, 230400, 0x91935248
+0, 13, 13, 1, 230400, 0x29b621e6
+0, 14, 14, 1, 230400, 0x89b1ec0b
+0, 15, 15, 1, 230400, 0x898fdba1
+0, 16, 16, 1, 230400, 0xc6d18e6f
+0, 17, 17, 1, 230400, 0xedff651b
+0, 18, 18, 1, 230400, 0x677e2260
+0, 19, 19, 1, 230400, 0x930918ef
+0, 20, 20, 1, 230400, 0x70da2c30
+0, 21, 21, 1, 230400, 0x699a3b9d
+0, 22, 22, 1, 230400, 0xff3b1b3a
+0, 23, 23, 1, 230400, 0xca11d9a5
+0, 24, 24, 1, 230400, 0x904394e0
+0, 25, 25, 1, 230400, 0x392e5445
+0, 26, 26, 1, 230400, 0x6191f4d8
+0, 27, 27, 1, 230400, 0xa7d7be12
+0, 28, 28, 1, 230400, 0xbb29752c
+0, 29, 29, 1, 230400, 0x14ff297e
--
2.42.0
More information about the ffmpeg-devel
mailing list