Commit b440c1ff authored by melanson's avatar melanson

Modify unpack_vlcs() so that there are fewer dereferences through the

main (heavily iterated) loop.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@19934 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent eda0794e
...@@ -1035,9 +1035,15 @@ static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb, ...@@ -1035,9 +1035,15 @@ static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb,
int zero_run = 0; int zero_run = 0;
DCTELEM coeff = 0; DCTELEM coeff = 0;
Vp3Fragment *fragment; Vp3Fragment *fragment;
uint8_t *perm= s->scantable.permutated;
int bits_to_get; int bits_to_get;
/* local references to structure members to avoid repeated deferences */
uint8_t *perm= s->scantable.permutated;
int *coded_fragment_list = s->coded_fragment_list;
Vp3Fragment *all_fragments = s->all_fragments;
uint8_t *coeff_counts = s->coeff_counts;
VLC_TYPE (*vlc_table)[2] = table->table;
if ((first_fragment >= s->fragment_count) || if ((first_fragment >= s->fragment_count) ||
(last_fragment >= s->fragment_count)) { (last_fragment >= s->fragment_count)) {
...@@ -1047,15 +1053,15 @@ static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb, ...@@ -1047,15 +1053,15 @@ static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb,
} }
for (i = first_fragment; i <= last_fragment; i++) { for (i = first_fragment; i <= last_fragment; i++) {
int fragment_num = s->coded_fragment_list[i]; int fragment_num = coded_fragment_list[i];
if (s->coeff_counts[fragment_num] > coeff_index) if (coeff_counts[fragment_num] > coeff_index)
continue; continue;
fragment = &s->all_fragments[fragment_num]; fragment = &all_fragments[fragment_num];
if (!eob_run) { if (!eob_run) {
/* decode a VLC into a token */ /* decode a VLC into a token */
token = get_vlc2(gb, table->table, 5, 3); token = get_vlc2(gb, vlc_table, 5, 3);
/* use the token to get a zero run, a coefficient, and an eob run */ /* use the token to get a zero run, a coefficient, and an eob run */
if (token <= 6) { if (token <= 6) {
eob_run = eob_run_base[token]; eob_run = eob_run_base[token];
...@@ -1076,16 +1082,16 @@ static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb, ...@@ -1076,16 +1082,16 @@ static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb,
} }
if (!eob_run) { if (!eob_run) {
s->coeff_counts[fragment_num] += zero_run; coeff_counts[fragment_num] += zero_run;
if (s->coeff_counts[fragment_num] < 64){ if (coeff_counts[fragment_num] < 64){
fragment->next_coeff->coeff= coeff; fragment->next_coeff->coeff= coeff;
fragment->next_coeff->index= perm[s->coeff_counts[fragment_num]++]; //FIXME perm here already? fragment->next_coeff->index= perm[coeff_counts[fragment_num]++]; //FIXME perm here already?
fragment->next_coeff->next= s->next_coeff; fragment->next_coeff->next= s->next_coeff;
s->next_coeff->next=NULL; s->next_coeff->next=NULL;
fragment->next_coeff= s->next_coeff++; fragment->next_coeff= s->next_coeff++;
} }
} else { } else {
s->coeff_counts[fragment_num] |= 128; coeff_counts[fragment_num] |= 128;
eob_run--; eob_run--;
} }
} }
......
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