[FFmpeg-cvslog] avformat/segment: Use av_freep() avoid leaving stale pointers in memory
Michael Niedermayer
git at videolan.org
Tue Jan 6 19:35:34 CET 2015
ffmpeg | branch: release/2.3 | Michael Niedermayer <michaelni at gmx.at> | Thu Dec 25 12:38:20 2014 +0100| [d071c1f0e143b248a5bf8ab85a5ab71615c5a564] | committer: Michael Niedermayer
avformat/segment: Use av_freep() avoid leaving stale pointers in memory
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
(cherry picked from commit 68fa549230af35179df2a2af2bdb84ee6c825bed)
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=d071c1f0e143b248a5bf8ab85a5ab71615c5a564
---
libavformat/segment.c | 14 +++++++-------
1 file changed, 7 insertions(+), 7 deletions(-)
diff --git a/libavformat/segment.c b/libavformat/segment.c
index e73f33f..07351d6 100644
--- a/libavformat/segment.c
+++ b/libavformat/segment.c
@@ -336,7 +336,7 @@ static int segment_end(AVFormatContext *s, int write_trailer, int is_last)
if (seg->list_size && seg->segment_count > seg->list_size) {
entry = seg->segment_list_entries;
seg->segment_list_entries = seg->segment_list_entries->next;
- av_free(entry->filename);
+ av_freep(&entry->filename);
av_freep(&entry);
}
@@ -494,10 +494,10 @@ static int open_null_ctx(AVIOContext **ctx)
return 0;
}
-static void close_null_ctx(AVIOContext *pb)
+static void close_null_ctxp(AVIOContext **pb)
{
- av_free(pb->buffer);
- av_free(pb);
+ av_freep(&(*pb)->buffer);
+ av_freep(pb);
}
static int select_reference_stream(AVFormatContext *s)
@@ -661,7 +661,7 @@ static int seg_write_header(AVFormatContext *s)
s->avoid_negative_ts = 1;
if (!seg->write_header_trailer) {
- close_null_ctx(oc->pb);
+ close_null_ctxp(&oc->pb);
if ((ret = avio_open2(&oc->pb, oc->filename, AVIO_FLAG_WRITE,
&s->interrupt_callback, NULL)) < 0)
goto fail;
@@ -787,7 +787,7 @@ static int seg_write_trailer(struct AVFormatContext *s)
goto fail;
open_null_ctx(&oc->pb);
ret = av_write_trailer(oc);
- close_null_ctx(oc->pb);
+ close_null_ctxp(&oc->pb);
} else {
ret = segment_end(s, 1, 1);
}
@@ -802,7 +802,7 @@ fail:
cur = seg->segment_list_entries;
while (cur) {
next = cur->next;
- av_free(cur->filename);
+ av_freep(&cur->filename);
av_free(cur);
cur = next;
}
More information about the ffmpeg-cvslog
mailing list