[FFmpeg-cvslog] r18235 - trunk/libavcodec/mlpdec.c

ramiro subversion
Mon Mar 30 05:20:01 CEST 2009


Author: ramiro
Date: Mon Mar 30 05:20:01 2009
New Revision: 18235

Log:
mlpdec: More validation for read_channel_params()

Modified:
   trunk/libavcodec/mlpdec.c

Modified: trunk/libavcodec/mlpdec.c
==============================================================================
--- trunk/libavcodec/mlpdec.c	Mon Mar 30 05:12:39 2009	(r18234)
+++ trunk/libavcodec/mlpdec.c	Mon Mar 30 05:20:01 2009	(r18235)
@@ -561,6 +561,11 @@ static int read_channel_params(MLPDecode
             if (read_filter_params(m, gbp, ch, IIR) < 0)
                 return -1;
 
+    if (fir->order + iir->order > 8) {
+        av_log(m->avctx, AV_LOG_ERROR, "Total filter orders too high.\n");
+        return -1;
+    }
+
     if (fir->order && iir->order &&
         fir->shift != iir->shift) {
         av_log(m->avctx, AV_LOG_ERROR,
@@ -582,9 +587,12 @@ static int read_channel_params(MLPDecode
     cp->codebook  = get_bits(gbp, 2);
     cp->huff_lsbs = get_bits(gbp, 5);
 
-    cp->sign_huff_offset = calculate_sign_huff(m, substr, ch);
+    if (cp->huff_lsbs > 24) {
+        av_log(m->avctx, AV_LOG_ERROR, "Invalid huff_lsbs.\n");
+        return -1;
+    }
 
-    /* TODO: validate */
+    cp->sign_huff_offset = calculate_sign_huff(m, substr, ch);
 
     return 0;
 }



More information about the ffmpeg-cvslog mailing list