Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/FFmpeg/FFmpeg.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLaurent Aimar <fenrir@videolan.org>2011-09-08 00:17:39 +0400
committerReinhard Tartler <siretart@tauware.de>2011-12-24 15:20:32 +0400
commitf5a8c4242eda7a41d8c93d9ddf352cb31830b06b (patch)
treeae44033fe585905eef4c3784b4a01842731a59fa /libavcodec
parent1edc513bcf78341b4614081812cc7b66cd84b465 (diff)
Fixed invalid writes in wavpack decoder on corrupted bitstreams.
Signed-off-by: Martin Storsjö <martin@martin.st> (cherry picked from commit 0aedab03405849962b469277afe047aa2c61a87f) Signed-off-by: Anton Khirnov <anton@khirnov.net> (cherry picked from commit 685940da4c843beb9283a21718cbd2fa4fa5d796) Conflicts: libavcodec/wavpack.c Signed-off-by: Reinhard Tartler <siretart@tauware.de>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/wavpack.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/libavcodec/wavpack.c b/libavcodec/wavpack.c
index 906ccea766..968ffa600b 100644
--- a/libavcodec/wavpack.c
+++ b/libavcodec/wavpack.c
@@ -1009,7 +1009,7 @@ static int wavpack_decode_frame(AVCodecContext *avctx,
int16_t *dst = (int16_t*)samples + samplecount * 2;
int16_t *src = (int16_t*)samples + samplecount;
int cnt = samplecount;
- while(cnt--){
+ while(cnt-- > 0){
*--dst = *--src;
*--dst = *src;
}
@@ -1018,7 +1018,7 @@ static int wavpack_decode_frame(AVCodecContext *avctx,
int32_t *dst = (int32_t*)samples + samplecount * 2;
int32_t *src = (int32_t*)samples + samplecount;
int cnt = samplecount;
- while(cnt--){
+ while(cnt-- > 0){
*--dst = *--src;
*--dst = *src;
}
@@ -1027,7 +1027,7 @@ static int wavpack_decode_frame(AVCodecContext *avctx,
float *dst = (float*)samples + samplecount * 2;
float *src = (float*)samples + samplecount;
int cnt = samplecount;
- while(cnt--){
+ while(cnt-- > 0){
*--dst = *--src;
*--dst = *src;
}