From d7cf99109a79a1632a90c801968ca196174894c5 Mon Sep 17 00:00:00 2001 From: Andreas Rheinhardt <andreas.rheinhardt@outlook.com> Date: Fri, 7 Mar 2025 04:20:52 +0100 Subject: [PATCH 8/9] avcodec/eamad: Optimize processing escape codes Said escape code is only six bits long, so that one has at least 25 - 6 bits in the bitstream reader's cache after reading it; therefore the whole following 16 bits (containing the actual code) are already in the bitstream reader's cache, making it unnecessary to reload the cache. This is the eamad analogue of fe9bc1cc45e2bebba1efa7b9a20b0d66679bf2d5. Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com> --- libavcodec/eamad.c | 2 -- 1 file changed, 2 deletions(-) diff --git a/libavcodec/eamad.c b/libavcodec/eamad.c index 1c3f97653c..41a133c424 100644 --- a/libavcodec/eamad.c +++ b/libavcodec/eamad.c @@ -160,10 +160,8 @@ static inline int decode_block_intra(MadContext *s, int16_t * block) LAST_SKIP_BITS(re, &s->gb, 1); } else { /* escape */ - UPDATE_CACHE(re, &s->gb); level = SHOW_SBITS(re, &s->gb, 10); SKIP_BITS(re, &s->gb, 10); - UPDATE_CACHE(re, &s->gb); run = SHOW_UBITS(re, &s->gb, 6)+1; LAST_SKIP_BITS(re, &s->gb, 6); i += run; -- 2.45.2