OSDN Git Service

h261dec, ituh263dec: Avoid unnecessary -1 inside inner loop.
authorReimar Döffinger <Reimar.Doeffinger@gmx.de>
Sun, 31 Aug 2014 18:30:04 +0000 (20:30 +0200)
committerReimar Döffinger <Reimar.Doeffinger@gmx.de>
Mon, 1 Sep 2014 17:41:20 +0000 (19:41 +0200)
3646 -> 3597 decicycles in inner loop when decoding
vsynth1-flv.

Signed-off-by: Reimar Döffinger <Reimar.Doeffinger@gmx.de>
libavcodec/h261dec.c
libavcodec/ituh263dec.c

index f286d23..c9470b1 100644 (file)
@@ -305,6 +305,7 @@ static int h261_decode_block(H261Context *h, int16_t *block, int n, int coded)
     }
     {
     OPEN_READER(re, &s->gb);
+    i--; // offset by -1 to allow direct indexing of scan_table
     for (;;) {
         UPDATE_CACHE(re, &s->gb);
         GET_RL_VLC(level, run, re, &s->gb, rl->rl_vlc[0], TCOEFF_VLC_BITS, 2, 0);
@@ -330,17 +331,17 @@ static int h261_decode_block(H261Context *h, int16_t *block, int n, int coded)
             SKIP_COUNTER(re, &s->gb, 1);
         }
         i += run;
-        if (i > 64) {
+        if (i >= 64) {
             av_log(s->avctx, AV_LOG_ERROR, "run overflow at %dx%d\n",
                    s->mb_x, s->mb_y);
             return -1;
         }
-        j        = scan_table[i-1];
+        j        = scan_table[i];
         block[j] = level;
     }
     CLOSE_READER(re, &s->gb);
     }
-    s->block_last_index[n] = i - 1;
+    s->block_last_index[n] = i;
     return 0;
 }
 
index ad5a3cb..168ac74 100644 (file)
@@ -481,6 +481,7 @@ static int h263_decode_block(MpegEncContext * s, int16_t * block,
 retry:
     {
     OPEN_READER(re, &s->gb);
+    i--; // offset by -1 to allow direct indexing of scan_table
     for(;;) {
         UPDATE_CACHE(re, &s->gb);
         GET_RL_VLC(level, run, re, &s->gb, rl->rl_vlc[0], TEX_VLC_BITS, 2, 0);
@@ -529,9 +530,9 @@ retry:
             SKIP_COUNTER(re, &s->gb, 1);
         }
         i += run;
-        if (i > 64){
-            // redo update without last flag
-            i = i - run + ((run-1)&63);
+        if (i >= 64){
+            // redo update without last flag, revert -1 offset
+            i = i - run + ((run-1)&63) + 1;
             if (i < 64) {
                 // only last marker, no overrun
                 block[scan_table[i]] = level;
@@ -549,7 +550,7 @@ retry:
             av_log(s->avctx, AV_LOG_ERROR, "run overflow at %dx%d i:%d\n", s->mb_x, s->mb_y, s->mb_intra);
             return -1;
         }
-        j = scan_table[i-1];
+        j = scan_table[i];
         block[j] = level;
     }
     CLOSE_READER(re, &s->gb);