diff options
author | James Almer <jamrial@gmail.com> | 2022-02-01 12:06:14 -0300 |
---|---|---|
committer | James Almer <jamrial@gmail.com> | 2022-02-01 13:04:16 -0300 |
commit | 911d7f167c30f27a042b8558dfcf012b3c20e858 (patch) | |
tree | 4a648363a4c1b913cfe24b381541958df238c71b /libavcodec | |
parent | a394d35a43b1101147580a8d89eb74046b21808f (diff) | |
download | ffmpeg-911d7f167c30f27a042b8558dfcf012b3c20e858.tar.gz |
avcodec/libdav1d: free the Dav1dData packet on dav1d_send_data() failure
We still own it on failure, and there's no point trying to feed it again.
This should address the issue reported in dav1d #383 and part of VLC #26259.
Signed-off-by: James Almer <jamrial@gmail.com>
Reviewed-by: Ronald S. Bultje <rsbultje@gmail.com>
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/libdav1d.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/libavcodec/libdav1d.c b/libavcodec/libdav1d.c index 29fa4f9c3d..872e60e000 100644 --- a/libavcodec/libdav1d.c +++ b/libavcodec/libdav1d.c @@ -347,8 +347,10 @@ static int libdav1d_receive_frame(AVCodecContext *c, AVFrame *frame) if (res < 0) { if (res == AVERROR(EINVAL)) res = AVERROR_INVALIDDATA; - if (res != AVERROR(EAGAIN)) + if (res != AVERROR(EAGAIN)) { + dav1d_data_unref(data); return res; + } } res = dav1d_get_picture(dav1d->c, p); |