aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-08-09 19:20:39 +0200
committerMichael Niedermayer <michaelni@gmx.at>2014-08-09 19:29:48 +0200
commit5404bf29c3b720ef04314c50b18047a94e4534b6 (patch)
treec0d667da93118449dcd87702058800552468933b
parent2c10833d5e4c055033eb89c0e10484919fe251a5 (diff)
parenta465ed5707f5cbc9713d5e9629d424cd2d46e038 (diff)
downloadffmpeg-5404bf29c3b720ef04314c50b18047a94e4534b6.tar.gz
Merge commit 'a465ed5707f5cbc9713d5e9629d424cd2d46e038' into release/0.10
* commit 'a465ed5707f5cbc9713d5e9629d424cd2d46e038': pgssubdec: Check RLE size before copying Merged-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavcodec/pgssubdec.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/libavcodec/pgssubdec.c b/libavcodec/pgssubdec.c
index 2785d25914..fd84af5596 100644
--- a/libavcodec/pgssubdec.c
+++ b/libavcodec/pgssubdec.c
@@ -207,6 +207,13 @@ static int parse_picture_segment(AVCodecContext *avctx,
/* Decode rle bitmap length, stored size includes width/height data */
rle_bitmap_len = bytestream_get_be24(&buf) - 2*2;
+ if (buf_size > rle_bitmap_len) {
+ av_log(avctx, AV_LOG_ERROR,
+ "Buffer dimension %d larger than the expected RLE data %d\n",
+ buf_size, rle_bitmap_len);
+ return AVERROR_INVALIDDATA;
+ }
+
/* Get bitmap dimensions from data */
width = bytestream_get_be16(&buf);
height = bytestream_get_be16(&buf);