diff options
author | Michael Niedermayer <michael@niedermayer.cc> | 2018-09-13 04:24:49 +0200 |
---|---|---|
committer | Michael Niedermayer <michael@niedermayer.cc> | 2018-09-15 20:02:43 +0200 |
commit | 6645783a3aa46107405c2f7aca65e7a7f13cf5a6 (patch) | |
tree | 713cecc22e26d91659d63607c3448f2810992c14 | |
parent | fb0cd972a704fbe8100837c16b18e2cbde3d5215 (diff) | |
download | ffmpeg-6645783a3aa46107405c2f7aca65e7a7f13cf5a6.tar.gz |
avcodec/dvdsubdec: Avoid branch in decode_run_8bit()
Speed improvment 35.5 sec -> 34.7sec
Reviewed-by: Paul B Mahol <onemda@gmail.com>
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
(cherry picked from commit 71bf0330505e2108935d05c5c018ec65eac4b946)
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
-rw-r--r-- | libavcodec/dvdsubdec.c | 5 |
1 files changed, 1 insertions, 4 deletions
diff --git a/libavcodec/dvdsubdec.c b/libavcodec/dvdsubdec.c index 5e0820e697..d017e771fc 100644 --- a/libavcodec/dvdsubdec.c +++ b/libavcodec/dvdsubdec.c @@ -82,10 +82,7 @@ static int decode_run_8bit(GetBitContext *gb, int *color) { int len; int has_run = get_bits1(gb); - if (get_bits1(gb)) - *color = get_bits(gb, 8); - else - *color = get_bits(gb, 2); + *color = get_bits(gb, 2 + 6*get_bits1(gb)); if (has_run) { if (get_bits1(gb)) { len = get_bits(gb, 7); |