From: Laurent Aimar Date: Wed, 7 Sep 2011 20:17:39 +0000 (+0200) Subject: Fixed invalid writes in wavpack decoder on corrupted bitstreams. X-Git-Tag: v0.8b1~1578 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=0aedab03405849962b469277afe047aa2c61a87f;p=platform%2Fupstream%2Flibav.git Fixed invalid writes in wavpack decoder on corrupted bitstreams. Signed-off-by: Martin Storsjö --- diff --git a/libavcodec/wavpack.c b/libavcodec/wavpack.c index fccafa8..41a1176 100644 --- a/libavcodec/wavpack.c +++ b/libavcodec/wavpack.c @@ -1114,7 +1114,7 @@ static int wavpack_decode_block(AVCodecContext *avctx, int block_no, int16_t *dst = (int16_t*)samples + 1; int16_t *src = (int16_t*)samples; int cnt = samplecount; - while(cnt--){ + while(cnt-- > 0){ *dst = *src; src += channel_stride; dst += channel_stride; @@ -1123,7 +1123,7 @@ static int wavpack_decode_block(AVCodecContext *avctx, int block_no, int32_t *dst = (int32_t*)samples + 1; int32_t *src = (int32_t*)samples; int cnt = samplecount; - while(cnt--){ + while(cnt-- > 0){ *dst = *src; src += channel_stride; dst += channel_stride; @@ -1132,7 +1132,7 @@ static int wavpack_decode_block(AVCodecContext *avctx, int block_no, float *dst = (float*)samples + 1; float *src = (float*)samples; int cnt = samplecount; - while(cnt--){ + while(cnt-- > 0){ *dst = *src; src += channel_stride; dst += channel_stride;