diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2012-03-24 02:40:24 +0100 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2012-09-29 09:26:04 +0200 |
commit | c20a69630619d14ae92c5541d52c579d7c8f3e94 (patch) | |
tree | ecf7d1cb791fbda39a2ef9952e7e0c1be45f39b7 | |
parent | 12e1e834611afed8121ccc368a83e7eb5c564565 (diff) | |
download | ffmpeg-c20a69630619d14ae92c5541d52c579d7c8f3e94.tar.gz |
cavsdec: check for changing w/h.
Our decoder does not support changing w/h.
Fixes CVE-2012-2777 and CVE-2012-2784.
Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind
Signed-off-by: Anton Khirnov <anton@khirnov.net>
-rw-r--r-- | libavcodec/cavsdec.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/libavcodec/cavsdec.c b/libavcodec/cavsdec.c index 33e639b9ae..e55e4f6e07 100644 --- a/libavcodec/cavsdec.c +++ b/libavcodec/cavsdec.c @@ -1056,12 +1056,21 @@ static int decode_pic(AVSContext *h) { static int decode_seq_header(AVSContext *h) { MpegEncContext *s = &h->s; int frame_rate_code; + int width, height; h->profile = get_bits(&s->gb,8); h->level = get_bits(&s->gb,8); skip_bits1(&s->gb); //progressive sequence - s->width = get_bits(&s->gb,14); - s->height = get_bits(&s->gb,14); + + width = get_bits(&s->gb, 14); + height = get_bits(&s->gb, 14); + if ((s->width || s->height) && (s->width != width || s->height != height)) { + av_log_missing_feature(s, "Width/height changing in CAVS is", 0); + return AVERROR_PATCHWELCOME; + } + s->width = width; + s->height = height; + skip_bits(&s->gb,2); //chroma format skip_bits(&s->gb,3); //sample_precision h->aspect_ratio = get_bits(&s->gb,4); |