diff options
author | Reimar Döffinger <Reimar.Doeffinger@gmx.de> | 2011-05-07 17:49:42 +0200 |
---|---|---|
committer | Reimar Döffinger <Reimar.Doeffinger@gmx.de> | 2011-05-07 18:08:46 +0200 |
commit | 6fd00e9dd94ac3aecf4fa14ca6fa23c395215ac9 (patch) | |
tree | bfe247ef8b130f84498216d3718dfdfaa2aebac5 /libavcodec/aacdec.c | |
parent | 5631729c3de589b45498af5272b47b0792ca07d4 (diff) | |
download | ffmpeg-6fd00e9dd94ac3aecf4fa14ca6fa23c395215ac9.tar.gz |
aacdec: add decode_channel_map overread check
All decode_channel_map calls together can easily read
more data than the amount of padding available.
Thus below patch adds an input length check before reading them.
Fixes some invalid reads with sample from
http://bugzilla.mplayerhq.hu/show_bug.cgi?id=1138
Diffstat (limited to 'libavcodec/aacdec.c')
-rw-r--r-- | libavcodec/aacdec.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/libavcodec/aacdec.c b/libavcodec/aacdec.c index 76b14a194c..48c0367b06 100644 --- a/libavcodec/aacdec.c +++ b/libavcodec/aacdec.c @@ -315,6 +315,10 @@ static int decode_pce(AVCodecContext *avctx, MPEG4AudioConfig *m4ac, if (get_bits1(gb)) skip_bits(gb, 3); // mixdown_coeff_index and pseudo_surround + if (get_bits_left(gb) < 4 * (num_front + num_side + num_back + num_lfe + num_assoc_data + num_cc)) { + av_log(avctx, AV_LOG_ERROR, overread_err); + return -1; + } decode_channel_map(new_che_pos[TYPE_CPE], new_che_pos[TYPE_SCE], AAC_CHANNEL_FRONT, gb, num_front); decode_channel_map(new_che_pos[TYPE_CPE], new_che_pos[TYPE_SCE], AAC_CHANNEL_SIDE, gb, num_side ); decode_channel_map(new_che_pos[TYPE_CPE], new_che_pos[TYPE_SCE], AAC_CHANNEL_BACK, gb, num_back ); |