[FFmpeg-cvslog] applehttp: Properly clean up if unable to probe a segment
Martin Storsjö
git at videolan.org
Thu Dec 15 00:19:52 CET 2011
ffmpeg | branch: master | Martin Storsjö <martin at martin.st> | Wed Dec 14 20:34:58 2011 +0200| [115a57302a7d6661426304bec3a5bc72d0edf4b0] | committer: Martin Storsjö
applehttp: Properly clean up if unable to probe a segment
This avoids a segfault if the probe function wasn't able to
determine the format.
The bug was found by Panagiotis H.M. Issaris.
Signed-off-by: Martin Storsjö <martin at martin.st>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=115a57302a7d6661426304bec3a5bc72d0edf4b0
---
libavformat/applehttp.c | 9 ++++++++-
1 files changed, 8 insertions(+), 1 deletions(-)
diff --git a/libavformat/applehttp.c b/libavformat/applehttp.c
index 19f2b20..6c4d56d 100644
--- a/libavformat/applehttp.c
+++ b/libavformat/applehttp.c
@@ -503,8 +503,15 @@ static int applehttp_read_header(AVFormatContext *s, AVFormatParameters *ap)
v->pb.seekable = 0;
ret = av_probe_input_buffer(&v->pb, &in_fmt, v->segments[0]->url,
NULL, 0, 0);
- if (ret < 0)
+ if (ret < 0) {
+ /* Free the ctx - it isn't initialized properly at this point,
+ * so avformat_close_input shouldn't be called. If
+ * avformat_open_input fails below, it frees and zeros the
+ * context, so it doesn't need any special treatment like this. */
+ avformat_free_context(v->ctx);
+ v->ctx = NULL;
goto fail;
+ }
v->ctx->pb = &v->pb;
ret = avformat_open_input(&v->ctx, v->segments[0]->url, in_fmt, NULL);
if (ret < 0)
More information about the ffmpeg-cvslog
mailing list