aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/adpcm.c
diff options
context:
space:
mode:
authorVitor Sessak <vitor1001@gmail.com>2009-04-27 16:06:01 +0000
committerVitor Sessak <vitor1001@gmail.com>2009-04-27 16:06:01 +0000
commit6cf92f6d26e08bbb11f89d8422712d3f1f48faef (patch)
tree001d93aa0c7682849062e96006acbac6d7971a03 /libavcodec/adpcm.c
parent8a06cb14f9f57f14e0de52451a4554e688bb854a (diff)
downloadffmpeg-6cf92f6d26e08bbb11f89d8422712d3f1f48faef.tar.gz
Check if there is enough bytes before reading the buffer in the EA ADPCM
decoder. Fix issue 990. Originally committed as revision 18707 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/adpcm.c')
-rw-r--r--libavcodec/adpcm.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/libavcodec/adpcm.c b/libavcodec/adpcm.c
index d923fbe3a0..8184378a16 100644
--- a/libavcodec/adpcm.c
+++ b/libavcodec/adpcm.c
@@ -1209,11 +1209,11 @@ static int adpcm_decode_frame(AVCodecContext *avctx,
}
break;
case CODEC_ID_ADPCM_EA:
- samples_in_chunk = AV_RL32(src);
- if (samples_in_chunk >= ((buf_size - 12) * 2)) {
+ if (buf_size < 4 || AV_RL32(src) >= ((buf_size - 12) * 2)) {
src += buf_size;
break;
}
+ samples_in_chunk = AV_RL32(src);
src += 4;
current_left_sample = (int16_t)bytestream_get_le16(&src);
previous_left_sample = (int16_t)bytestream_get_le16(&src);