[FFmpeg-cvslog] avcodec/vp3data: combine eob_run_base and eob_run_get_bits tables

Peter Ross git at videolan.org
Sat Jun 8 03:45:00 EEST 2019


ffmpeg | branch: master | Peter Ross <pross at xvid.org> | Fri May 24 20:10:32 2019 +1000| [b6ca032adebe05573d9fe9c3a2625240f55b33b0] | committer: Peter Ross

avcodec/vp3data: combine eob_run_base and eob_run_get_bits tables

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

 libavcodec/vp3.c     | 6 +++---
 libavcodec/vp3data.h | 9 ++++-----
 2 files changed, 7 insertions(+), 8 deletions(-)

diff --git a/libavcodec/vp3.c b/libavcodec/vp3.c
index b248c90413..63f60c9109 100644
--- a/libavcodec/vp3.c
+++ b/libavcodec/vp3.c
@@ -988,9 +988,9 @@ static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb,
         token = get_vlc2(gb, vlc_table, 11, 3);
         /* use the token to get a zero run, a coefficient, and an eob run */
         if ((unsigned) token <= 6U) {
-            eob_run = eob_run_base[token];
-            if (eob_run_get_bits[token])
-                eob_run += get_bits(gb, eob_run_get_bits[token]);
+            eob_run = eob_run_table[token].base;
+            if (eob_run_table[token].bits)
+                eob_run += get_bits(gb, eob_run_table[token].bits);
 
             if (!eob_run)
                 eob_run = INT_MAX;
diff --git a/libavcodec/vp3data.h b/libavcodec/vp3data.h
index c82b1b3a86..d520a10c76 100644
--- a/libavcodec/vp3data.h
+++ b/libavcodec/vp3data.h
@@ -198,11 +198,10 @@ static const int8_t fixed_motion_vector_table[64] = {
 };
 
 /* only tokens 0..6 indicate eob runs */
-static const uint8_t eob_run_base[7] = {
-    1, 2, 3, 4, 8, 16, 0
-};
-static const uint8_t eob_run_get_bits[7] = {
-    0, 0, 0, 2, 3, 4, 12
+static const struct {
+    uint8_t base, bits;
+} eob_run_table[7] = {
+    {1, 0}, {2, 0}, {3, 0}, {4, 2}, {8, 3}, {16, 4}, {0, 12}
 };
 
 static const uint8_t zero_run_base[32] = {



More information about the ffmpeg-cvslog mailing list