avoid a few if(x==0) checks in the inner loops

Originally committed as revision 6073 to svn://svn.ffmpeg.org/ffmpeg/trunk
pull/126/head
Michael Niedermayer 18 years ago
parent 5340a0bc9c
commit e90a72701e
  1. 40
      libavcodec/mpegaudiodec.c

@ -2299,12 +2299,22 @@ static int mp_decode_layer3(MPADecodeContext *s)
if (g->block_type == 2) { if (g->block_type == 2) {
n = g->switch_point ? 17 : 18; n = g->switch_point ? 17 : 18;
j = 0; j = 0;
for(i=0;i<n;i++) if(slen1){
g->scale_factors[j++] = get_bitsz(&s->gb, slen1); for(i=0;i<n;i++)
for(i=0;i<18;i++) g->scale_factors[j++] = get_bits(&s->gb, slen1);
g->scale_factors[j++] = get_bitsz(&s->gb, slen2); }else{
for(i=0;i<3;i++) for(i=0;i<n;i++)
g->scale_factors[j++] = 0; g->scale_factors[j++] = 0;
}
if(slen2){
for(i=0;i<18;i++)
g->scale_factors[j++] = get_bits(&s->gb, slen2);
for(i=0;i<3;i++)
g->scale_factors[j++] = 0;
}else{
for(i=0;i<21;i++)
g->scale_factors[j++] = 0;
}
} else { } else {
sc = granules[ch][0].scale_factors; sc = granules[ch][0].scale_factors;
j = 0; j = 0;
@ -2312,8 +2322,13 @@ static int mp_decode_layer3(MPADecodeContext *s)
n = (k == 0 ? 6 : 5); n = (k == 0 ? 6 : 5);
if ((g->scfsi & (0x8 >> k)) == 0) { if ((g->scfsi & (0x8 >> k)) == 0) {
slen = (k < 2) ? slen1 : slen2; slen = (k < 2) ? slen1 : slen2;
for(i=0;i<n;i++) if(slen){
g->scale_factors[j++] = get_bitsz(&s->gb, slen); for(i=0;i<n;i++)
g->scale_factors[j++] = get_bits(&s->gb, slen);
}else{
for(i=0;i<n;i++)
g->scale_factors[j++] = 0;
}
} else { } else {
/* simply copy from last granule */ /* simply copy from last granule */
for(i=0;i<n;i++) { for(i=0;i<n;i++) {
@ -2375,8 +2390,13 @@ static int mp_decode_layer3(MPADecodeContext *s)
for(k=0;k<4;k++) { for(k=0;k<4;k++) {
n = lsf_nsf_table[tindex2][tindex][k]; n = lsf_nsf_table[tindex2][tindex][k];
sl = slen[k]; sl = slen[k];
for(i=0;i<n;i++) if(s1){
g->scale_factors[j++] = get_bitsz(&s->gb, sl); for(i=0;i<n;i++)
g->scale_factors[j++] = get_bits(&s->gb, sl);
}else{
for(i=0;i<n;i++)
g->scale_factors[j++] = 0;
}
} }
/* XXX: should compute exact size */ /* XXX: should compute exact size */
for(;j<40;j++) for(;j<40;j++)

Loading…
Cancel
Save