diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2014-10-27 20:48:58 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-10-27 20:55:57 +0100 |
commit | a050cf0c451bdf1c1bd512c4fce6b6f8a5e85102 (patch) | |
tree | e652e292ea2aa475bf6bd05a558daf4471c1eb9b /libavcodec/sgidec.c | |
parent | 3b20ed85489a14cb5028c873d06960dbc5eef88a (diff) | |
download | ffmpeg-a050cf0c451bdf1c1bd512c4fce6b6f8a5e85102.tar.gz |
avcodec/sgidec: fix count check
Fixes: asan_heap-oob_22b30d4_39_038.sgi
Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/sgidec.c')
-rw-r--r-- | libavcodec/sgidec.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/libavcodec/sgidec.c b/libavcodec/sgidec.c index 8338863637..3ddbf77bc8 100644 --- a/libavcodec/sgidec.c +++ b/libavcodec/sgidec.c @@ -98,7 +98,7 @@ static int expand_rle_row16(SgiState *s, uint16_t *out_buf, break; /* Check for buffer overflow. */ - if (pixelstride * (count - 1) >= len) { + if (out_end - out_buf <= pixelstride * (count - 1)) { av_log(s->avctx, AV_LOG_ERROR, "Invalid pixel count.\n"); return AVERROR_INVALIDDATA; } |