]> git.sesse.net Git - ffmpeg/commitdiff
http: Do not try to make a new request when seeking past the end of the file
authorJustin Ruggles <justin.ruggles@gmail.com>
Wed, 20 Feb 2019 14:52:43 +0000 (09:52 -0500)
committerVittorio Giovara <vittorio.giovara@gmail.com>
Tue, 26 Feb 2019 19:48:27 +0000 (14:48 -0500)
This avoids making invalid HTTP Range requests for a byte range past the
known end of the file during a seek. Those requests generally return a HTTP
response of 416 Range Not Satisfiable, which causes an error response.

Reference: https://tools.ietf.org/html/rfc7233

Signed-off-by: Vittorio Giovara <vittorio.giovara@gmail.com>
libavformat/http.c

index 072a6ce0b92f408a1f0991a611847db0cac03162..ed0eb1c875da17de198cd191bf1511221004d32e 100644 (file)
@@ -1691,6 +1691,13 @@ static int64_t http_seek_internal(URLContext *h, int64_t off, int whence, int fo
     if (s->off && h->is_streamed)
         return AVERROR(ENOSYS);
 
+    /* do not try to make a new connection if seeking past the end of the file */
+    if (s->end_off || s->filesize != UINT64_MAX) {
+        uint64_t end_pos = s->end_off ? s->end_off : s->filesize;
+        if (s->off >= end_pos)
+            return s->off;
+    }
+
     /* we save the old context in case the seek fails */
     old_buf_size = s->buf_end - s->buf_ptr;
     memcpy(old_buf, s->buf_ptr, old_buf_size);