[FFmpeg-devel] [PATCH] avformat/http: Return an error in case of prematurely ending data
Michael Niedermayer
michaelni at gmx.at
Sun Mar 29 00:33:35 CET 2015
Fixes Ticket 4039
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
---
libavformat/http.c | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/libavformat/http.c b/libavformat/http.c
index da3c9be..a1d3763 100644
--- a/libavformat/http.c
+++ b/libavformat/http.c
@@ -907,6 +907,14 @@ static int http_buf_read(URLContext *h, uint8_t *buf, int size)
s->filesize >= 0 && s->off >= s->filesize)
return AVERROR_EOF;
len = ffurl_read(s->hd, buf, size);
+ if (!len && (!s->willclose || s->chunksize < 0) &&
+ s->filesize >= 0 && s->off < s->filesize) {
+ av_log(h, AV_LOG_ERROR,
+ "Streams ends prematurly at %"PRId64", should be %"PRId64"\n",
+ s->off, s->filesize
+ );
+ return AVERROR(EIO);
+ }
}
if (len > 0) {
s->off += len;
--
1.7.9.5
More information about the ffmpeg-devel
mailing list