aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndreas Rheinhardt <andreas.rheinhardt@outlook.com>2023-09-16 02:54:54 +0200
committerAndreas Rheinhardt <andreas.rheinhardt@outlook.com>2023-09-16 14:54:17 +0200
commit4dae62f7081eda648adb76d47aef90e872606905 (patch)
treea2ca3a5c9c493622a3ee7a53b66f4d842693afe5
parent156f53e9879deefd845f1beffb5c1cadb5ad0ac3 (diff)
downloadffmpeg-4dae62f7081eda648adb76d47aef90e872606905.tar.gz
avcodec/dnxhddec: Use VLC symbol table to avoid lookup
Reviewed-by: Paul B Mahol <onemda@gmail.com> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
-rw-r--r--libavcodec/dnxhddec.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/libavcodec/dnxhddec.c b/libavcodec/dnxhddec.c
index b5f4e053c0..703d0e341c 100644
--- a/libavcodec/dnxhddec.c
+++ b/libavcodec/dnxhddec.c
@@ -142,9 +142,10 @@ static int dnxhd_init_vlc(DNXHDContext *ctx, uint32_t cid, int bitdepth)
ctx->cid_table->dc_bits, 1, 1,
ctx->cid_table->dc_codes, 1, 1, 0)) < 0)
goto out;
- if ((ret = vlc_init(&ctx->run_vlc, DNXHD_VLC_BITS, 62,
+ if ((ret = ff_vlc_init_sparse(&ctx->run_vlc, DNXHD_VLC_BITS, 62,
ctx->cid_table->run_bits, 1, 1,
- ctx->cid_table->run_codes, 2, 2, 0)) < 0)
+ ctx->cid_table->run_codes, 2, 2,
+ ctx->cid_table->run, 1, 1, 0)) < 0)
goto out;
ctx->cid = cid;
@@ -358,7 +359,7 @@ static av_always_inline int dnxhd_decode_dct_block(const DNXHDContext *ctx,
int level_shift,
int dc_shift)
{
- int i, j, index1, index2, len, flags;
+ int i, j, index1, len, flags;
int level, component, sign;
const int *scale;
const uint8_t *weight_matrix;
@@ -425,10 +426,11 @@ static av_always_inline int dnxhd_decode_dct_block(const DNXHDContext *ctx,
}
if (flags & 2) {
+ int run;
UPDATE_CACHE(bs, &row->gb);
- GET_VLC(index2, bs, &row->gb, ctx->run_vlc.table,
+ GET_VLC(run, bs, &row->gb, ctx->run_vlc.table,
DNXHD_VLC_BITS, 2);
- i += ctx->cid_table->run[index2];
+ i += run;
}
if (++i > 63) {