[SCM] libav/upstream.snapshot: wmapro: check the min_samples_per_subframe

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sat Jul 13 06:29:05 UTC 2013


The following commit has been merged in the upstream.snapshot branch:
commit 8bd037293769c5ed65adce83ba097571ff4d6faf
Author: Luca Barbato <lu_zero at gentoo.org>
Date:   Sat Jun 29 01:56:09 2013 +0200

    wmapro: check the min_samples_per_subframe
    
    Must be at least WMAPRO_BLOCK_MIN_SIZE.
    
    Reported-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind
    CC: libav-stable at libav.org
    (cherry picked from commit d4a217a408da4bd63acc02cd8f9ebe378a2ad65a)
    
    Signed-off-by: Reinhard Tartler <siretart at tauware.de>

diff --git a/libavcodec/wmaprodec.c b/libavcodec/wmaprodec.c
index 57c22a4..392d146 100644
--- a/libavcodec/wmaprodec.c
+++ b/libavcodec/wmaprodec.c
@@ -107,6 +107,7 @@
 
 #define WMAPRO_BLOCK_MIN_BITS  6                                           ///< log2 of min block size
 #define WMAPRO_BLOCK_MAX_BITS 13                                           ///< log2 of max block size
+#define WMAPRO_BLOCK_MIN_SIZE (1 << WMAPRO_BLOCK_MIN_BITS)                 ///< minimum block size
 #define WMAPRO_BLOCK_MAX_SIZE (1 << WMAPRO_BLOCK_MAX_BITS)                 ///< maximum block size
 #define WMAPRO_BLOCK_SIZES    (WMAPRO_BLOCK_MAX_BITS - WMAPRO_BLOCK_MIN_BITS + 1) ///< possible block sizes
 
@@ -340,6 +341,12 @@ static av_cold int decode_init(AVCodecContext *avctx)
         return AVERROR_INVALIDDATA;
     }
 
+    if (s->min_samples_per_subframe < WMAPRO_BLOCK_MIN_SIZE) {
+        av_log(avctx, AV_LOG_ERROR, "Invalid minimum block size %i\n",
+               s->max_num_subframes);
+        return AVERROR_INVALIDDATA;
+    }
+
     if (s->avctx->sample_rate <= 0) {
         av_log(avctx, AV_LOG_ERROR, "invalid sample rate\n");
         return AVERROR_INVALIDDATA;

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list