diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2011-12-20 16:52:42 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2011-12-20 16:52:42 +0100 |
commit | 3c7f75bd84b4c30a0f86a491a37f759dfaaab86d (patch) | |
tree | d1c51c87984640c71c0930be6f1fdff855c12f99 | |
parent | abab44086fa5b7b3c4cd3f5eabc1348977b506b9 (diff) | |
download | ffmpeg-3c7f75bd84b4c30a0f86a491a37f759dfaaab86d.tar.gz |
avidec: move eof check before continue.
Fixes a infinite loop
Fixes half of Ticket800
Bug found by Oana Stratulat
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r-- | libavformat/avidec.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/libavformat/avidec.c b/libavformat/avidec.c index ec543d76d0..9191b625c4 100644 --- a/libavformat/avidec.c +++ b/libavformat/avidec.c @@ -1232,6 +1232,9 @@ static int avi_read_idx1(AVFormatContext *s, int size) /* Read the entries and sort them in each stream component. */ for(i = 0; i < nb_index_entries; i++) { + if(url_feof(pb)) + return -1; + tag = avio_rl32(pb); flags = avio_rl32(pb); pos = avio_rl32(pb); @@ -1254,8 +1257,6 @@ static int avi_read_idx1(AVFormatContext *s, int size) av_dlog(s, "%d cum_len=%"PRId64"\n", len, ast->cum_len); - if(url_feof(pb)) - return -1; if(last_pos == pos) avi->non_interleaved= 1; |