From ccb919e34b1276db5cfcd903e405e47ccb932d58 Mon Sep 17 00:00:00 2001 From: Kostya Shishkov Date: Sat, 20 Aug 2011 13:11:14 +0200 Subject: [PATCH] WavPack demuxer: do not rely on index when timestamp is not in indexed range. This fixes the situation when there are not enough entries in the index (e.g. on initial seek there's only one index entry in the index) and index search returns just the last known entry. That causes seeking function just to seek there instead of trying harder to get at the requested position. Signed-off-by: Luca Barbato --- libavformat/wv.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/libavformat/wv.c b/libavformat/wv.c index 5c9c31c72a..d057262029 100644 --- a/libavformat/wv.c +++ b/libavformat/wv.c @@ -330,7 +330,8 @@ static int wv_read_seek(AVFormatContext *s, int stream_index, int64_t timestamp, int64_t pos, pts; /* if found, seek there */ - if (index >= 0){ + if (index >= 0 && + timestamp <= st->index_entries[st->nb_index_entries - 1].timestamp) { wc->block_parsed = 1; avio_seek(s->pb, st->index_entries[index].pos, SEEK_SET); return 0;