Commit 1004a92c authored by Andreas Rheinhardt's avatar Andreas Rheinhardt

avformat/mux: Fix leaks on error when writing noninterleaved uncoded frames

If writing uncoded frames in noninterleaved mode fails at the preparatory
steps (i.e. before it reaches write_packet()), the packet would not be
unreferenced and the frame would leak. This is fixed by unreferencing
the packet in write_uncoded_frame_internal() instead.

This also makes it possible to remove the unreferencing in
write_packet() itself: In noninterleaved mode frames are now freed in
write_uncoded_frame_internal(), while they are freed in interleaved
mode when their containing packet gets unreferenced (like normal
packets).
Signed-off-by: 's avatarAndreas Rheinhardt <andreas.rheinhardt@gmail.com>
parent ad1dc918
...@@ -743,7 +743,6 @@ static int write_packet(AVFormatContext *s, AVPacket *pkt) ...@@ -743,7 +743,6 @@ static int write_packet(AVFormatContext *s, AVPacket *pkt)
AVFrame **frame = (AVFrame **)pkt->data; AVFrame **frame = (AVFrame **)pkt->data;
av_assert0(pkt->size == sizeof(*frame)); av_assert0(pkt->size == sizeof(*frame));
ret = s->oformat->write_uncoded_frame(s, pkt->stream_index, frame, 0); ret = s->oformat->write_uncoded_frame(s, pkt->stream_index, frame, 0);
av_packet_unref(pkt);
} else { } else {
ret = s->oformat->write_packet(s, pkt); ret = s->oformat->write_packet(s, pkt);
} }
...@@ -1318,6 +1317,7 @@ static int write_uncoded_frame_internal(AVFormatContext *s, int stream_index, ...@@ -1318,6 +1317,7 @@ static int write_uncoded_frame_internal(AVFormatContext *s, int stream_index,
AVFrame *frame, int interleaved) AVFrame *frame, int interleaved)
{ {
AVPacket pkt, *pktp; AVPacket pkt, *pktp;
int ret;
av_assert0(s->oformat); av_assert0(s->oformat);
if (!s->oformat->write_uncoded_frame) { if (!s->oformat->write_uncoded_frame) {
...@@ -1354,8 +1354,11 @@ static int write_uncoded_frame_internal(AVFormatContext *s, int stream_index, ...@@ -1354,8 +1354,11 @@ static int write_uncoded_frame_internal(AVFormatContext *s, int stream_index,
pkt.flags |= AV_PKT_FLAG_UNCODED_FRAME; pkt.flags |= AV_PKT_FLAG_UNCODED_FRAME;
} }
return interleaved ? av_interleaved_write_frame(s, pktp) : ret = interleaved ? av_interleaved_write_frame(s, pktp) :
av_write_frame(s, pktp); av_write_frame(s, pktp);
if (pktp)
av_packet_unref(pktp);
return ret;
} }
int av_write_uncoded_frame(AVFormatContext *s, int stream_index, int av_write_uncoded_frame(AVFormatContext *s, int stream_index,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment