[FFmpeg-devel] [PATCH] Check for invalid slice offsets in real decoder.

Laurent Aimar fenrir at elivagar.org
Tue Sep 20 01:42:04 CEST 2011


On Tue, Sep 20, 2011 at 01:37:03AM +0200, Michael Niedermayer wrote:
> On Mon, Sep 19, 2011 at 10:48:53PM +0200, fenrir at elivagar.org wrote:
> > From: Laurent Aimar <fenrir at videolan.org>
> > 
> > ---
> >  libavcodec/rv34.c |    9 +++++----
> >  1 files changed, 5 insertions(+), 4 deletions(-)
> > 
> > diff --git a/libavcodec/rv34.c b/libavcodec/rv34.c
> > index 8223e92..a760e5e 100644
> > --- a/libavcodec/rv34.c
> > +++ b/libavcodec/rv34.c
> > @@ -1488,8 +1488,9 @@ int ff_rv34_decode_frame(AVCodecContext *avctx,
> >          slice_count = avctx->slice_count;
> >  
> >      //parse first slice header to check whether this frame can be decoded
> > -    if(get_slice_offset(avctx, slices_hdr, 0) > buf_size){
> > -        av_log(avctx, AV_LOG_ERROR, "Slice offset is greater than frame size\n");
> > +    if(get_slice_offset(avctx, slices_hdr, 0) < 0 ||
> > +       get_slice_offset(avctx, slices_hdr, 0) > buf_size){
> > +        av_log(avctx, AV_LOG_ERROR, "Slice offset is invalid\n");
> >          return -1;
> >      }
> >      init_get_bits(&s->gb, buf+get_slice_offset(avctx, slices_hdr, 0), (buf_size-get_slice_offset(avctx, slices_hdr, 0))*8);
> > @@ -1512,8 +1513,8 @@ int ff_rv34_decode_frame(AVCodecContext *avctx,
> >          else
> >              size = get_slice_offset(avctx, slices_hdr, i+1) - offset;
> >  
> > -        if(offset > buf_size){
> > -            av_log(avctx, AV_LOG_ERROR, "Slice offset is greater than frame size\n");
> > +        if(offset < 0 || offset > buf_size || size < 0){
> > +            av_log(avctx, AV_LOG_ERROR, "Slice offset is invalid\n");
> >              break;
> >          }
> 
> applied but i think this is not sufficient
> slice i+2 is read a bit below and seem unchecked
Good catch, I will provid a patch.
Thanks.

-- 
fenrir


More information about the ffmpeg-devel mailing list