Commit 20de5f0c authored by cehoyos's avatar cehoyos

Fix a bug with reading non-interleaved AVI if one the streams is

shorter.

Patch by Maksym Veremeyenko, verem m1stereo tv


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@19798 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent cf0e3863
...@@ -679,12 +679,18 @@ static int avi_read_packet(AVFormatContext *s, AVPacket *pkt) ...@@ -679,12 +679,18 @@ static int avi_read_packet(AVFormatContext *s, AVPacket *pkt)
AVStream *st = s->streams[i]; AVStream *st = s->streams[i];
AVIStream *ast = st->priv_data; AVIStream *ast = st->priv_data;
int64_t ts= ast->frame_offset; int64_t ts= ast->frame_offset;
int64_t last_ts;
if(!st->nb_index_entries) if(!st->nb_index_entries)
continue; continue;
if(ast->sample_size) if(ast->sample_size)
ts /= ast->sample_size; ts /= ast->sample_size;
last_ts = st->index_entries[st->nb_index_entries - 1].timestamp;
if(!ast->remaining && ts > last_ts)
continue;
ts = av_rescale_q(ts, st->time_base, AV_TIME_BASE_Q); ts = av_rescale_q(ts, st->time_base, AV_TIME_BASE_Q);
// av_log(s, AV_LOG_DEBUG, "%"PRId64" %d/%d %"PRId64"\n", ts, st->time_base.num, st->time_base.den, ast->frame_offset); // av_log(s, AV_LOG_DEBUG, "%"PRId64" %d/%d %"PRId64"\n", ts, st->time_base.num, st->time_base.den, ast->frame_offset);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment