avformat/hls: do not care about stream start timestamps

While selecting a packet to return to caller in read_packet(), the code
corrects the timestamps for starting timestamps.

However, this is wrong, since for live streams the initial timestamps
might differ just because of the time delay between the retrieval of the
various Media Playlists.

Fortunately, spec 6.2.4 mandates that all variant streams must have
matching timestamps, so we do not need to correct for initial
timestamps.

Drop the correction code.

Note that ID3 timestamps were previously ignored, so this code was
previously actually needed.

Signed-off-by: Anssi Hannula <anssi.hannula@iki.fi>
pull/64/head
Anssi Hannula 11 years ago
parent d549b0910c
commit 8fd6875c83
  1. 7
      libavformat/hls.c

@ -1528,19 +1528,12 @@ start:
} else if (pls->cur_seq_no == minpls->cur_seq_no) { } else if (pls->cur_seq_no == minpls->cur_seq_no) {
int64_t dts = pls->pkt.dts; int64_t dts = pls->pkt.dts;
int64_t mindts = minpls->pkt.dts; int64_t mindts = minpls->pkt.dts;
AVStream *st = pls->ctx->streams[pls->pkt.stream_index];
AVStream *minst = minpls->ctx->streams[minpls->pkt.stream_index];
AVRational tb = get_timebase( pls); AVRational tb = get_timebase( pls);
AVRational mintb = get_timebase(minpls); AVRational mintb = get_timebase(minpls);
if (dts == AV_NOPTS_VALUE) { if (dts == AV_NOPTS_VALUE) {
minplaylist = i; minplaylist = i;
} else if (mindts != AV_NOPTS_VALUE) { } else if (mindts != AV_NOPTS_VALUE) {
if (st->start_time != AV_NOPTS_VALUE)
dts -= st->start_time;
if (minst->start_time != AV_NOPTS_VALUE)
mindts -= minst->start_time;
if (av_compare_ts(dts, tb, if (av_compare_ts(dts, tb,
mindts, mintb) < 0) mindts, mintb) < 0)
minplaylist = i; minplaylist = i;

Loading…
Cancel
Save