Message ID | 20170824231532.16002-3-michael@niedermayer.cc |
---|---|
State | Accepted |
Commit | 96f24d1bee7fe7bac08e2b7c74db1a046c9dc0de |
Headers | show |
On Fri, Aug 25, 2017 at 01:15:29AM +0200, Michael Niedermayer wrote: > From: 孙浩 and 张洪亮(望初) <tony.sh and wangchu.zhl@alibaba-inc.com> > > Fixes: loop.rl2 > > Found-by: Xiaohei and Wangchu from Alibaba Security Team > Signed-off-by: Michael Niedermayer <michael@niedermayer.cc> > --- > libavformat/rl2.c | 15 ++++++++++++--- > 1 file changed, 12 insertions(+), 3 deletions(-) applied [...]
diff --git a/libavformat/rl2.c b/libavformat/rl2.c index 0bec8f1d9a..eb1682dfcb 100644 --- a/libavformat/rl2.c +++ b/libavformat/rl2.c @@ -170,12 +170,21 @@ static av_cold int rl2_read_header(AVFormatContext *s) } /** read offset and size tables */ - for(i=0; i < frame_count;i++) + for(i=0; i < frame_count;i++) { + if (avio_feof(pb)) + return AVERROR_INVALIDDATA; chunk_size[i] = avio_rl32(pb); - for(i=0; i < frame_count;i++) + } + for(i=0; i < frame_count;i++) { + if (avio_feof(pb)) + return AVERROR_INVALIDDATA; chunk_offset[i] = avio_rl32(pb); - for(i=0; i < frame_count;i++) + } + for(i=0; i < frame_count;i++) { + if (avio_feof(pb)) + return AVERROR_INVALIDDATA; audio_size[i] = avio_rl32(pb) & 0xFFFF; + } /** build the sample index */ for(i=0;i<frame_count;i++){