Mercurial > libavcodec.hg
diff vc1.c @ 6145:ddf5d7fae101 libavcodec
Select scan tables for 8x4 and 4x8 blocks only once.
Patch by Christophe GISQUET ([christophe][gisquet] <whirlpool sign> free <spot> fr)
Thread [PATCH] Determine once and for all zz scan tables to use in VC-1 VLD
author | kostya |
---|---|
date | Mon, 14 Jan 2008 06:10:02 +0000 |
parents | a2b438bcb1d2 |
children | 49a4e4d78692 |
line wrap: on
line diff
--- a/vc1.c Mon Jan 14 04:27:03 2008 +0000 +++ b/vc1.c Mon Jan 14 06:10:02 2008 +0000 @@ -777,10 +777,14 @@ if (v->profile == PROFILE_ADVANCED) { + v->zz_8x4 = ff_vc1_adv_progressive_8x4_zz; + v->zz_4x8 = ff_vc1_adv_progressive_4x8_zz; return decode_sequence_header_adv(v, gb); } else { + v->zz_8x4 = ff_vc1_simple_progressive_8x4_zz; + v->zz_4x8 = ff_vc1_simple_progressive_4x8_zz; v->res_sm = get_bits(gb, 2); //reserved if (v->res_sm) { @@ -2961,13 +2965,10 @@ i += skip; if(i > 31) break; - if(v->profile < PROFILE_ADVANCED) - idx = ff_vc1_simple_progressive_8x4_zz[i++]; - else - idx = ff_vc1_adv_progressive_8x4_zz[i++]; - block[idx + off] = value * scale; + idx = v->zz_8x4[i++]+off; + block[idx] = value * scale; if(!v->pquantizer) - block[idx + off] += (block[idx + off] < 0) ? -mquant : mquant; + block[idx] += (block[idx] < 0) ? -mquant : mquant; } if(!(subblkpat & (1 << (1 - j))) && !skip_block) s->dsp.vc1_inv_trans_8x4(dst + j*4*linesize, linesize, block + off); @@ -2983,13 +2984,10 @@ i += skip; if(i > 31) break; - if(v->profile < PROFILE_ADVANCED) - idx = ff_vc1_simple_progressive_4x8_zz[i++]; - else - idx = ff_vc1_adv_progressive_4x8_zz[i++]; - block[idx + off] = value * scale; + idx = v->zz_4x8[i++]+off; + block[idx] = value * scale; if(!v->pquantizer) - block[idx + off] += (block[idx + off] < 0) ? -mquant : mquant; + block[idx] += (block[idx] < 0) ? -mquant : mquant; } if(!(subblkpat & (1 << (1 - j))) && !skip_block) s->dsp.vc1_inv_trans_4x8(dst + j*4, linesize, block + off);