Commit f830e419 authored by michael's avatar michael

Replace i by trailing_ones, part of a patch by dark shikari.

No speed change meassureable with START/STOP_TIMER, but this is needed
for future optimizations.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@16218 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 0b2b584f
...@@ -4091,7 +4091,7 @@ static int decode_residual(H264Context *h, GetBitContext *gb, DCTELEM *block, in ...@@ -4091,7 +4091,7 @@ static int decode_residual(H264Context *h, GetBitContext *gb, DCTELEM *block, in
level[i]= 1 - 2*get_bits1(gb); level[i]= 1 - 2*get_bits1(gb);
} }
if(i<total_coeff) { if(trailing_ones<total_coeff) {
int level_code, mask; int level_code, mask;
int suffix_length = total_coeff > 10 && trailing_ones < 3; int suffix_length = total_coeff > 10 && trailing_ones < 3;
int prefix= get_level_prefix(gb); int prefix= get_level_prefix(gb);
...@@ -4120,11 +4120,10 @@ static int decode_residual(H264Context *h, GetBitContext *gb, DCTELEM *block, in ...@@ -4120,11 +4120,10 @@ static int decode_residual(H264Context *h, GetBitContext *gb, DCTELEM *block, in
if(level_code > 5) if(level_code > 5)
suffix_length++; suffix_length++;
mask= -(level_code&1); mask= -(level_code&1);
level[i]= (((2+level_code)>>1) ^ mask) - mask; level[trailing_ones]= (((2+level_code)>>1) ^ mask) - mask;
i++;
//remaining coefficients have suffix_length > 0 //remaining coefficients have suffix_length > 0
for(;i<total_coeff;i++) { for(i=trailing_ones+1;i<total_coeff;i++) {
static const int suffix_limit[7] = {0,5,11,23,47,95,INT_MAX }; static const int suffix_limit[7] = {0,5,11,23,47,95,INT_MAX };
prefix = get_level_prefix(gb); prefix = get_level_prefix(gb);
if(prefix<15){ if(prefix<15){
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment