diff options
author | Anton Khirnov <anton@khirnov.net> | 2013-01-29 12:24:09 +0100 |
---|---|---|
committer | Reinhard Tartler <siretart@tauware.de> | 2013-02-07 07:18:57 +0100 |
commit | b7765d00f911fe0f8fcda21b93a540f27d2ba2f5 (patch) | |
tree | cf20a97cdca28b098bf336f4d5963f95f5610ee0 /libavcodec | |
parent | d0249f1c2e55d4ac48655ccc789833489891bb81 (diff) | |
download | ffmpeg-b7765d00f911fe0f8fcda21b93a540f27d2ba2f5.tar.gz |
msrledec: check bounds before constructing a possibly invalid pointer,
CC:libav-stable@libav.org
(cherry picked from commit 9bd6375d5f16842306dcecde637ffe605acda26b)
Signed-off-by: Reinhard Tartler <siretart@tauware.de>
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/msrledec.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/libavcodec/msrledec.c b/libavcodec/msrledec.c index fad94151c9..af2a2478b1 100644 --- a/libavcodec/msrledec.c +++ b/libavcodec/msrledec.c @@ -144,8 +144,7 @@ static int msrle_decode_8_16_24_32(AVCodecContext *avctx, AVPicture *pic, if(p1 == 0) { //Escape code p2 = bytestream2_get_byte(gb); if(p2 == 0) { //End-of-line - output = pic->data[0] + (--line) * pic->linesize[0]; - if (line < 0) { + if (--line < 0) { if (bytestream2_get_be16(gb) == 1) { // end-of-picture return 0; } else { @@ -155,6 +154,7 @@ static int msrle_decode_8_16_24_32(AVCodecContext *avctx, AVPicture *pic, return AVERROR_INVALIDDATA; } } + output = pic->data[0] + line * pic->linesize[0]; pos = 0; continue; } else if(p2 == 1) { //End-of-picture |