summaryrefslogtreecommitdiff
path: root/libavcodec/wmadec.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2008-07-11 19:45:52 +0000
committerMichael Niedermayer <michaelni@gmx.at>2008-07-11 19:45:52 +0000
commit362aba4be71f2d5d6c85f7bf8dd800faf5c1069f (patch)
treef0e9a5d4ae914a742691198bbc8fce59e5265f0b /libavcodec/wmadec.c
parent0261e3651a9e09bd661fd338a79e04bc0a02cf71 (diff)
Check that we have enough output space available.
Originally committed as revision 14170 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/wmadec.c')
-rw-r--r--libavcodec/wmadec.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/libavcodec/wmadec.c b/libavcodec/wmadec.c
index 361a73d273..0b46fe0884 100644
--- a/libavcodec/wmadec.c
+++ b/libavcodec/wmadec.c
@@ -781,6 +781,11 @@ static int wma_decode_superframe(AVCodecContext *avctx,
skip_bits(&s->gb, 4); /* super frame index */
nb_frames = get_bits(&s->gb, 4) - 1;
+ if((nb_frames+1) * s->nb_channels * s->frame_len * sizeof(int16_t) > *data_size){
+ av_log(s->avctx, AV_LOG_ERROR, "Insufficient output space\n");
+ goto fail;
+ }
+
bit_offset = get_bits(&s->gb, s->byte_offset_bits + 3);
if (s->last_superframe_len > 0) {
@@ -836,6 +841,10 @@ static int wma_decode_superframe(AVCodecContext *avctx,
s->last_superframe_len = len;
memcpy(s->last_superframe, buf + pos, len);
} else {
+ if(s->nb_channels * s->frame_len * sizeof(int16_t) > *data_size){
+ av_log(s->avctx, AV_LOG_ERROR, "Insufficient output space\n");
+ goto fail;
+ }
/* single frame decode */
if (wma_decode_frame(s, samples) < 0)
goto fail;