mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-08 13:22:53 +02:00
hls: only seek if there is an offset
If there is no #EXT-X-BYTERANGE specified, there is no need to seek.
Seeking fails anyway for rtmp, because this protocol does not support
url_seek.
This fixes CNN.m3u from trac ticket 4797 (i.e. Debian bug #798189).
Reviewed-by: wm4 <nfxjfg@googlemail.com>
Signed-off-by: Andreas Cadhalpun <Andreas.Cadhalpun@googlemail.com>
(cherry picked from commit f9f0b4c08e
)
Signed-off-by: Andreas Cadhalpun <Andreas.Cadhalpun@googlemail.com>
This commit is contained in:
parent
8118fdf8bb
commit
173053a125
@ -1043,7 +1043,7 @@ static int open_input(HLSContext *c, struct playlist *pls)
|
|||||||
/* Seek to the requested position. If this was a HTTP request, the offset
|
/* Seek to the requested position. If this was a HTTP request, the offset
|
||||||
* should already be where want it to, but this allows e.g. local testing
|
* should already be where want it to, but this allows e.g. local testing
|
||||||
* without a HTTP server. */
|
* without a HTTP server. */
|
||||||
if (ret == 0 && seg->key_type == KEY_NONE) {
|
if (ret == 0 && seg->key_type == KEY_NONE && seg->url_offset) {
|
||||||
int seekret = ffurl_seek(pls->input, seg->url_offset, SEEK_SET);
|
int seekret = ffurl_seek(pls->input, seg->url_offset, SEEK_SET);
|
||||||
if (seekret < 0) {
|
if (seekret < 0) {
|
||||||
av_log(pls->parent, AV_LOG_ERROR, "Unable to seek to offset %"PRId64" of HLS segment '%s'\n", seg->url_offset, seg->url);
|
av_log(pls->parent, AV_LOG_ERROR, "Unable to seek to offset %"PRId64" of HLS segment '%s'\n", seg->url_offset, seg->url);
|
||||||
|
Loading…
Reference in New Issue
Block a user