Factorize some code into functions, had this in my tree and will be

needed for mp3 encoding.

Originally committed as revision 11509 to svn://svn.ffmpeg.org/ffmpeg/trunk
pull/126/head
Michael Niedermayer 17 years ago
parent 762f804c9e
commit 9f7458b285
  1. 120
      libavcodec/mpegaudiodec.c

@ -126,6 +126,68 @@ static const int32_t scale_factor_mult2[3][3] = {
static DECLARE_ALIGNED_16(MPA_INT, window[512]); static DECLARE_ALIGNED_16(MPA_INT, window[512]);
/**
* Convert region offsets to region sizes and truncate
* size to big_values.
*/
void ff_region_offset2size(GranuleDef *g){
int i, k, j=0;
g->region_size[2] = (576 / 2);
for(i=0;i<3;i++) {
k = FFMIN(g->region_size[i], g->big_values);
g->region_size[i] = k - j;
j = k;
}
}
void ff_init_short_region(MPADecodeContext *s, GranuleDef *g){
if (g->block_type == 2)
g->region_size[0] = (36 / 2);
else {
if (s->sample_rate_index <= 2)
g->region_size[0] = (36 / 2);
else if (s->sample_rate_index != 8)
g->region_size[0] = (54 / 2);
else
g->region_size[0] = (108 / 2);
}
g->region_size[1] = (576 / 2);
}
void ff_init_long_region(MPADecodeContext *s, GranuleDef *g, int ra1, int ra2){
int l;
g->region_size[0] =
band_index_long[s->sample_rate_index][ra1 + 1] >> 1;
/* should not overflow */
l = FFMIN(ra1 + ra2 + 2, 22);
g->region_size[1] =
band_index_long[s->sample_rate_index][l] >> 1;
}
void ff_compute_band_indexes(MPADecodeContext *s, GranuleDef *g){
if (g->block_type == 2) {
if (g->switch_point) {
/* if switched mode, we handle the 36 first samples as
long blocks. For 8000Hz, we handle the 48 first
exponents as long blocks (XXX: check this!) */
if (s->sample_rate_index <= 2)
g->long_end = 8;
else if (s->sample_rate_index != 8)
g->long_end = 6;
else
g->long_end = 4; /* 8000 Hz */
g->short_start = 2 + (s->sample_rate_index != 8);
} else {
g->long_end = 0;
g->short_start = 0;
}
} else {
g->short_start = 13;
g->long_end = 22;
}
}
/* layer 1 unscaling */ /* layer 1 unscaling */
/* n = number of bits of the mantissa minus 1 */ /* n = number of bits of the mantissa minus 1 */
static inline int l1_unscale(int n, int mant, int scale_factor) static inline int l1_unscale(int n, int mant, int scale_factor)
@ -2008,20 +2070,9 @@ static int mp_decode_layer3(MPADecodeContext *s)
g->table_select[i] = get_bits(&s->gb, 5); g->table_select[i] = get_bits(&s->gb, 5);
for(i=0;i<3;i++) for(i=0;i<3;i++)
g->subblock_gain[i] = get_bits(&s->gb, 3); g->subblock_gain[i] = get_bits(&s->gb, 3);
/* compute huffman coded region sizes */ ff_init_short_region(s, g);
if (g->block_type == 2)
g->region_size[0] = (36 / 2);
else {
if (s->sample_rate_index <= 2)
g->region_size[0] = (36 / 2);
else if (s->sample_rate_index != 8)
g->region_size[0] = (54 / 2);
else
g->region_size[0] = (108 / 2);
}
g->region_size[1] = (576 / 2);
} else { } else {
int region_address1, region_address2, l; int region_address1, region_address2;
g->block_type = 0; g->block_type = 0;
g->switch_point = 0; g->switch_point = 0;
for(i=0;i<3;i++) for(i=0;i<3;i++)
@ -2031,47 +2082,10 @@ static int mp_decode_layer3(MPADecodeContext *s)
region_address2 = get_bits(&s->gb, 3); region_address2 = get_bits(&s->gb, 3);
dprintf(s->avctx, "region1=%d region2=%d\n", dprintf(s->avctx, "region1=%d region2=%d\n",
region_address1, region_address2); region_address1, region_address2);
g->region_size[0] = ff_init_long_region(s, g, region_address1, region_address2);
band_index_long[s->sample_rate_index][region_address1 + 1] >> 1;
l = region_address1 + region_address2 + 2;
/* should not overflow */
if (l > 22)
l = 22;
g->region_size[1] =
band_index_long[s->sample_rate_index][l] >> 1;
}
/* convert region offsets to region sizes and truncate
size to big_values */
g->region_size[2] = (576 / 2);
j = 0;
for(i=0;i<3;i++) {
k = FFMIN(g->region_size[i], g->big_values);
g->region_size[i] = k - j;
j = k;
}
/* compute band indexes */
if (g->block_type == 2) {
if (g->switch_point) {
/* if switched mode, we handle the 36 first samples as
long blocks. For 8000Hz, we handle the 48 first
exponents as long blocks (XXX: check this!) */
if (s->sample_rate_index <= 2)
g->long_end = 8;
else if (s->sample_rate_index != 8)
g->long_end = 6;
else
g->long_end = 4; /* 8000 Hz */
g->short_start = 2 + (s->sample_rate_index != 8);
} else {
g->long_end = 0;
g->short_start = 0;
}
} else {
g->short_start = 13;
g->long_end = 22;
} }
ff_region_offset2size(g);
ff_compute_band_indexes(s, g);
g->preflag = 0; g->preflag = 0;
if (!s->lsf) if (!s->lsf)

Loading…
Cancel
Save