[FFmpeg-cvslog] avcodec/iff: check pixfmt for rgb8 / rgbn
    Michael Niedermayer 
    git at videolan.org
       
    Fri Nov 28 20:02:18 CET 2014
    
    
  
ffmpeg | branch: release/2.1 | Michael Niedermayer <michaelni at gmx.at> | Sun Aug 10 21:59:33 2014 +0200| [f405267493c8baf900195bf7989f371b861041f6] | committer: Michael Niedermayer
avcodec/iff: check pixfmt for rgb8 / rgbn
Fixes out of array access
Found-by: Piotr Bandurski <ami_stuff at o2.pl>
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
(cherry picked from commit 3539d6c63a16e1b2874bb037a86f317449c58770)
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=f405267493c8baf900195bf7989f371b861041f6
---
 libavcodec/iff.c |    4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/libavcodec/iff.c b/libavcodec/iff.c
index 5d69539..f69b420 100644
--- a/libavcodec/iff.c
+++ b/libavcodec/iff.c
@@ -841,9 +841,9 @@ static int decode_frame(AVCodecContext *avctx,
         break;
     case 4:
         bytestream2_init(&gb, buf, buf_size);
-        if (avctx->codec_tag == MKTAG('R', 'G', 'B', '8'))
+        if (avctx->codec_tag == MKTAG('R', 'G', 'B', '8') && avctx->pix_fmt == AV_PIX_FMT_RGB32)
             decode_rgb8(&gb, s->frame->data[0], avctx->width, avctx->height, s->frame->linesize[0]);
-        else if (avctx->codec_tag == MKTAG('R', 'G', 'B', 'N'))
+        else if (avctx->codec_tag == MKTAG('R', 'G', 'B', 'N') && avctx->pix_fmt == AV_PIX_FMT_RGB444)
             decode_rgbn(&gb, s->frame->data[0], avctx->width, avctx->height, s->frame->linesize[0]);
         else
             return unsupported(avctx);
    
    
More information about the ffmpeg-cvslog
mailing list