[FFmpeg-devel] [PATCH 2/2] avcodec/libdav1d: honor the requested skip_frame level

James Almer jamrial at gmail.com
Fri Jan 7 16:21:34 EET 2022


This supports dropping non-intra, non-key, or all frames.

Signed-off-by: James Almer <jamrial at gmail.com>
---
 libavcodec/libdav1d.c | 9 +++++++++
 1 file changed, 9 insertions(+)

diff --git a/libavcodec/libdav1d.c b/libavcodec/libdav1d.c
index 8e45f533cb..9252a2572d 100644
--- a/libavcodec/libdav1d.c
+++ b/libavcodec/libdav1d.c
@@ -299,6 +299,7 @@ static int libdav1d_receive_frame(AVCodecContext *c, AVFrame *frame)
 #endif
     int res;
 
+redo:
     if (!data->sz) {
         AVPacket *const pkt = dav1d->pkt;
 
@@ -363,6 +364,14 @@ static int libdav1d_receive_frame(AVCodecContext *c, AVFrame *frame)
 
     av_assert0(p->data[0] && p->allocator_data);
 
+    if ((c->skip_frame >= AVDISCARD_NONINTRA && (p->frame_hdr->frame_type != DAV1D_FRAME_TYPE_KEY &&
+                                                 p->frame_hdr->frame_type != DAV1D_FRAME_TYPE_INTRA)) ||
+        (c->skip_frame >= AVDISCARD_NONKEY   &&  p->frame_hdr->frame_type != DAV1D_FRAME_TYPE_KEY) ||
+         c->skip_frame >= AVDISCARD_ALL) {
+        dav1d_picture_unref(p);
+        goto redo;
+    }
+
     // This requires the custom allocator above
     frame->buf[0] = av_buffer_ref(p->allocator_data);
     if (!frame->buf[0]) {
-- 
2.34.1



More information about the ffmpeg-devel mailing list