diff options
author | Reimar Döffinger <Reimar.Doeffinger@gmx.de> | 2014-08-31 15:41:13 +0200 |
---|---|---|
committer | Reimar Döffinger <Reimar.Doeffinger@gmx.de> | 2014-08-31 20:13:51 +0200 |
commit | c0d32686ddc1184e57b21802838d4654f2fd5389 (patch) | |
tree | 61483bbd63d8bb1b37e9c62a3752fcd04e86c08a /libavcodec/h261dec.c | |
parent | da0a670b3c3eaa1e700cd54342dc609d7474af26 (diff) | |
download | ffmpeg-c0d32686ddc1184e57b21802838d4654f2fd5389.tar.gz |
h261dec: Optimize new RL_VLC based decoding.
Together with the switch to RL_VLC this results in about
10% speedup for this inner loop.
Signed-off-by: Reimar Döffinger <Reimar.Doeffinger@gmx.de>
Diffstat (limited to 'libavcodec/h261dec.c')
-rw-r--r-- | libavcodec/h261dec.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/libavcodec/h261dec.c b/libavcodec/h261dec.c index 5f0eb59e3c..f286d23635 100644 --- a/libavcodec/h261dec.c +++ b/libavcodec/h261dec.c @@ -318,27 +318,25 @@ static int h261_decode_block(H261Context *h, int16_t *block, int n, int coded) /* The remaining combinations of (run, level) are encoded with a * 20-bit word consisting of 6 bits escape, 6 bits run and 8 bits * level. */ - run = SHOW_UBITS(re, &s->gb, 6); + run = SHOW_UBITS(re, &s->gb, 6) + 1; SKIP_CACHE(re, &s->gb, 6); level = SHOW_SBITS(re, &s->gb, 8); SKIP_COUNTER(re, &s->gb, 6 + 8); } else if (level == 0) { break; } else { - run--; if (SHOW_UBITS(re, &s->gb, 1)) level = -level; 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]; + j = scan_table[i-1]; block[j] = level; - i++; } CLOSE_READER(re, &s->gb); } |