[FFmpeg-cvslog] diracdec: Fix codeblock parameters reading

Kieran Kunhya git at videolan.org
Thu Dec 17 00:56:17 CET 2015


ffmpeg | branch: master | Kieran Kunhya <kierank at ob-encoder.com> | Wed Dec 16 23:26:03 2015 +0000| [25f6ccccd69038f80450351f69b8225df6042d68] | committer: Kieran Kunhya

diracdec: Fix codeblock parameters reading

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=25f6ccccd69038f80450351f69b8225df6042d68
---

 libavcodec/diracdec.c |   17 ++++++++++++++++-
 1 file changed, 16 insertions(+), 1 deletion(-)

diff --git a/libavcodec/diracdec.c b/libavcodec/diracdec.c
index abe1a5a..07eb512 100644
--- a/libavcodec/diracdec.c
+++ b/libavcodec/diracdec.c
@@ -1128,7 +1128,22 @@ static int dirac_unpack_idwt_params(DiracContext *s)
 
     CHECKEDREAD(s->wavelet_depth, tmp > MAX_DWT_LEVELS || tmp < 1, "invalid number of DWT decompositions\n")
 
-    if (s->low_delay) {
+    if (!s->low_delay) {
+        /* Codeblock parameters (core syntax only) */
+        if (get_bits1(gb)) {
+            for (i = 0; i <= s->wavelet_depth; i++) {
+                CHECKEDREAD(s->codeblock[i].width , tmp < 1 || tmp > (s->avctx->width >>s->wavelet_depth-i), "codeblock width invalid\n")
+                CHECKEDREAD(s->codeblock[i].height, tmp < 1 || tmp > (s->avctx->height>>s->wavelet_depth-i), "codeblock height invalid\n")
+            }
+
+            CHECKEDREAD(s->codeblock_mode, tmp > 1, "unknown codeblock mode\n")
+        }
+        else {
+            for (i = 0; i <= s->wavelet_depth; i++)
+                s->codeblock[i].width = s->codeblock[i].height = 1;
+        }
+    }
+    else {
         s->num_x        = svq3_get_ue_golomb(gb);
         s->num_y        = svq3_get_ue_golomb(gb);
         if (s->ld_picture) {



More information about the ffmpeg-cvslog mailing list