mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
lavc/decode_video(): always unref the frame if there is no output in decode_video
Not just on failure. This is the same thing that is done in the audio path and should prevent leaks in decoders that allocate a frame, but then end up not writing into it.
This commit is contained in:
parent
85f947aefb
commit
a1ee164869
@ -1416,9 +1416,6 @@ int attribute_align_arg avcodec_decode_video2(AVCodecContext *avctx, AVFrame *pi
|
|||||||
|
|
||||||
emms_c(); //needed to avoid an emms_c() call before every return;
|
emms_c(); //needed to avoid an emms_c() call before every return;
|
||||||
|
|
||||||
if (ret < 0 && picture->buf[0])
|
|
||||||
av_frame_unref(picture);
|
|
||||||
|
|
||||||
if (*got_picture_ptr) {
|
if (*got_picture_ptr) {
|
||||||
if (!avctx->refcounted_frames) {
|
if (!avctx->refcounted_frames) {
|
||||||
avci->to_free = *picture;
|
avci->to_free = *picture;
|
||||||
@ -1427,7 +1424,8 @@ int attribute_align_arg avcodec_decode_video2(AVCodecContext *avctx, AVFrame *pi
|
|||||||
}
|
}
|
||||||
|
|
||||||
avctx->frame_number++;
|
avctx->frame_number++;
|
||||||
}
|
} else
|
||||||
|
av_frame_unref(picture);
|
||||||
} else
|
} else
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user