applehttp: Use the last segment duration as reload interval
According to draft-pantos-http-live-streaming-07, 6.3.4, the duration of the last media segment in the playlist should be used as initial minimum reload delay. Signed-off-by: Martin Storsjö <martin@martin.st>
This commit is contained in:
parent
7af507ea99
commit
356ae5f65b
@ -377,10 +377,15 @@ static int read_data(void *opaque, uint8_t *buf, int buf_size)
|
|||||||
restart:
|
restart:
|
||||||
if (!v->input) {
|
if (!v->input) {
|
||||||
reload:
|
reload:
|
||||||
/* If this is a live stream and target_duration has elapsed since
|
/* If this is a live stream and the reload interval has elapsed since
|
||||||
* the last playlist reload, reload the variant playlists now. */
|
* the last playlist reload, reload the variant playlists now. */
|
||||||
|
int64_t reload_interval = v->n_segments > 0 ?
|
||||||
|
v->segments[v->n_segments - 1]->duration :
|
||||||
|
v->target_duration;
|
||||||
|
reload_interval *= 1000000;
|
||||||
|
|
||||||
if (!v->finished &&
|
if (!v->finished &&
|
||||||
av_gettime() - v->last_load_time >= v->target_duration*1000000 &&
|
av_gettime() - v->last_load_time >= reload_interval &&
|
||||||
(ret = parse_playlist(c, v->url, v, NULL)) < 0)
|
(ret = parse_playlist(c, v->url, v, NULL)) < 0)
|
||||||
return ret;
|
return ret;
|
||||||
if (v->cur_seq_no < v->start_seq_no) {
|
if (v->cur_seq_no < v->start_seq_no) {
|
||||||
@ -392,8 +397,7 @@ reload:
|
|||||||
if (v->cur_seq_no >= v->start_seq_no + v->n_segments) {
|
if (v->cur_seq_no >= v->start_seq_no + v->n_segments) {
|
||||||
if (v->finished)
|
if (v->finished)
|
||||||
return AVERROR_EOF;
|
return AVERROR_EOF;
|
||||||
while (av_gettime() - v->last_load_time <
|
while (av_gettime() - v->last_load_time < reload_interval) {
|
||||||
v->target_duration*1000000) {
|
|
||||||
if (ff_check_interrupt(c->interrupt_callback))
|
if (ff_check_interrupt(c->interrupt_callback))
|
||||||
return AVERROR_EXIT;
|
return AVERROR_EXIT;
|
||||||
usleep(100*1000);
|
usleep(100*1000);
|
||||||
|
Loading…
Reference in New Issue
Block a user