From 25ccf5df723c4e933f8cc25f36ba21264ef59a8c Mon Sep 17 00:00:00 2001 From: Carl Eugen Hoyos Date: Thu, 20 Nov 2014 10:14:51 +0100 Subject: [PATCH] lavf/mux: Always call write_trailer() from av_write_trailer() to avoid a leak. Fixes ticket #4049. --- libavformat/mux.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/libavformat/mux.c b/libavformat/mux.c index a09e33cfdd..023832c336 100644 --- a/libavformat/mux.c +++ b/libavformat/mux.c @@ -926,7 +926,7 @@ int av_write_trailer(AVFormatContext *s) for (;; ) { AVPacket pkt; ret = interleave_packet(s, &pkt, NULL, 1); - if (ret < 0) //FIXME cleanup needed for ret<0 ? + if (ret < 0) goto fail; if (!ret) break; @@ -943,10 +943,14 @@ int av_write_trailer(AVFormatContext *s) goto fail; } - if (s->oformat->write_trailer) - ret = s->oformat->write_trailer(s); - fail: + if (s->oformat->write_trailer) + if (ret >= 0) { + ret = s->oformat->write_trailer(s); + } else { + s->oformat->write_trailer(s); + } + if (s->pb) avio_flush(s->pb); if (ret == 0)