46 #define BACKSTEP_SIZE 512
48 #define LAST_BUF_SIZE 2 * BACKSTEP_SIZE + EXTRABYTES
100 0 + 128 + 128 + 128 + 130 + 128 + 154 + 166 +
101 142 + 204 + 190 + 170 + 542 + 460 + 662 + 414
104 0, 128, 128, 128, 130, 128, 154, 166,
105 142, 204, 190, 170, 542, 460, 662, 414
132 #define SCALE_GEN(v) \
133 { FIXR_OLD(1.0 * (v)), FIXR_OLD(0.7937005259 * (v)), FIXR_OLD(0.6299605249 * (v)) }
149 for (i = 0; i < 3; i++) {
159 if (s->sample_rate_index != 8)
164 if (s->sample_rate_index <= 2)
166 else if (s->sample_rate_index != 8)
180 l =
FFMIN(ra1 + ra2 + 2, 22);
188 if(s->sample_rate_index == 8)
193 if (s->sample_rate_index <= 2)
222 return (
int)((val + (1LL << (shift - 1))) >> shift);
236 val = (val + (1 << (shift - 1))) >> shift;
255 m = (m + (1 << (e - 1))) >> e;
266 for (i = 0; i < 64; i++) {
275 for (i = 0; i < 15; i++) {
278 norm = ((INT64_C(1) <<
n) *
FRAC_ONE) / ((1 <<
n) - 1);
282 av_dlog(NULL,
"%d: norm=%x s=%x %x %x\n", i, norm,
292 for (i = 1; i < 16; i++) {
295 uint8_t tmp_bits [512] = { 0 };
296 uint16_t tmp_codes[512] = { 0 };
301 for (x = 0; x < xsize; x++) {
302 for (y = 0; y < xsize; y++) {
303 tmp_bits [(x << 5) | y | ((x&&y)<<4)]= h->
bits [j ];
304 tmp_codes[(x << 5) | y | ((x&&
y)<<4)]= h->
codes[j++];
312 tmp_bits, 1, 1, tmp_codes, 2, 2,
319 for (i = 0; i < 2; i++) {
322 init_vlc(&huff_quad_vlc[i], i == 0 ? 7 : 4, 16,
329 for (i = 0; i < 9; i++) {
331 for (j = 0; j < 22; j++) {
342 for (i = 0; i < 4; i++) {
345 int val1, val2, val3, steps;
358 for (i = 0; i < 7; i++) {
362 f = tan((
double)i *
M_PI / 12.0);
363 v =
FIXR(f / (1.0 + f));
371 for (i = 7; i < 16; i++)
374 for (i = 0; i < 16; i++) {
378 for (j = 0; j < 2; j++) {
379 e = -(j + 1) * ((i + 1) >> 1);
384 av_dlog(NULL,
"is_table_lsf %d %d: %f %f\n",
390 for (i = 0; i < 8; i++) {
393 cs = 1.0 / sqrt(1.0 + ci * ci);
411 static int initialized_tables = 0;
414 if (!initialized_tables) {
416 initialized_tables = 1;
437 #define C3 FIXHR(0.86602540378443864676/2)
438 #define C4 FIXHR(0.70710678118654752439/2) //0.5 / cos(pi*(9)/36)
439 #define C5 FIXHR(0.51763809020504152469/2) //0.5 / cos(pi*(5)/36)
440 #define C6 FIXHR(1.93185165257813657349/4) //0.5 / cos(pi*(15)/36)
449 in1 = in[1*3] + in[0*3];
450 in2 = in[2*3] + in[1*3];
451 in3 = in[3*3] + in[2*3];
452 in4 = in[4*3] + in[3*3];
453 in5 = in[5*3] + in[4*3];
488 int bound, i,
v,
n, ch, j, mant;
493 bound = (s->mode_ext + 1) * 4;
498 for (i = 0; i < bound; i++) {
499 for (ch = 0; ch < s->nb_channels; ch++) {
503 for (i = bound; i <
SBLIMIT; i++)
507 for (i = 0; i < bound; i++) {
508 for (ch = 0; ch < s->nb_channels; ch++) {
509 if (allocation[ch][i])
513 for (i = bound; i <
SBLIMIT; i++) {
514 if (allocation[0][i]) {
521 for (j = 0; j < 12; j++) {
522 for (i = 0; i < bound; i++) {
523 for (ch = 0; ch < s->nb_channels; ch++) {
524 n = allocation[ch][i];
527 v =
l1_unscale(n, mant, scale_factors[ch][i]);
534 for (i = bound; i <
SBLIMIT; i++) {
535 n = allocation[0][i];
555 int table, bit_alloc_bits, i, j, ch, bound,
v;
559 int scale, qindex,
bits, steps, k, l,
m,
b;
563 s->sample_rate, s->lsf);
568 bound = (s->mode_ext + 1) * 4;
572 av_dlog(s->
avctx,
"bound=%d sblimit=%d\n", bound, sblimit);
580 for (i = 0; i < bound; i++) {
581 bit_alloc_bits = alloc_table[j];
582 for (ch = 0; ch < s->nb_channels; ch++)
583 bit_alloc[ch][i] =
get_bits(&s->
gb, bit_alloc_bits);
584 j += 1 << bit_alloc_bits;
586 for (i = bound; i < sblimit; i++) {
587 bit_alloc_bits = alloc_table[j];
591 j += 1 << bit_alloc_bits;
595 for (i = 0; i < sblimit; i++) {
596 for (ch = 0; ch < s->nb_channels; ch++) {
597 if (bit_alloc[ch][i])
603 for (i = 0; i < sblimit; i++) {
604 for (ch = 0; ch < s->nb_channels; ch++) {
605 if (bit_alloc[ch][i]) {
606 sf = scale_factors[ch][i];
607 switch (scale_code[ch][i]) {
635 for (k = 0; k < 3; k++) {
636 for (l = 0; l < 12; l += 3) {
638 for (i = 0; i < bound; i++) {
639 bit_alloc_bits = alloc_table[j];
640 for (ch = 0; ch < s->nb_channels; ch++) {
641 b = bit_alloc[ch][i];
643 scale = scale_factors[ch][i][k];
644 qindex = alloc_table[j+
b];
660 for (m = 0; m < 3; m++) {
673 j += 1 << bit_alloc_bits;
676 for (i = bound; i < sblimit; i++) {
677 bit_alloc_bits = alloc_table[j];
680 int mant, scale0, scale1;
681 scale0 = scale_factors[0][i][k];
682 scale1 = scale_factors[1][i][k];
683 qindex = alloc_table[j+
b];
706 for (m = 0; m < 3; m++) {
723 j += 1 << bit_alloc_bits;
726 for (i = sblimit; i <
SBLIMIT; i++) {
727 for (ch = 0; ch < s->nb_channels; ch++) {
738 #define SPLIT(dst,sf,n) \
740 int m = (sf * 171) >> 9; \
743 } else if (n == 4) { \
746 } else if (n == 5) { \
747 int m = (sf * 205) >> 10; \
750 } else if (n == 6) { \
751 int m = (sf * 171) >> 10; \
761 SPLIT(slen[3], sf, n3)
762 SPLIT(slen[2], sf, n2)
763 SPLIT(slen[1], sf, n1)
771 int len, i, j, k, l,
v0,
shift, gain, gains[3];
781 v0 = gain - ((g->
scale_factors[i] + pretab[i]) << shift) + 400;
783 for (j = len; j > 0; j--)
795 for (l = 0; l < 3; l++) {
797 for (j = len; j > 0; j--)
832 #define READ_FLIP_SIGN(dst,src) \
833 v = AV_RN32A(src) ^ (get_bits1(&s->gb) << 31); \
836 #define READ_FLIP_SIGN(dst,src) \
837 v = -get_bits1(&s->gb); \
838 *(dst) = (*(src) ^ v) - v;
842 int16_t *exponents,
int end_pos2)
846 int last_pos, bits_left;
852 for (i = 0; i < 3; i++) {
853 int j, k, l, linbits;
889 exponent= exponents[s_index];
936 while (s_index <= 572) {
939 if (pos >= end_pos) {
940 if (pos > end_pos2 && last_pos) {
945 av_log(s->
avctx,
AV_LOG_INFO,
"overread, skip %d enddists: %d %d\n", last_pos - pos, end_pos-pos, end_pos2-pos);
963 static const int idxtab[16] = { 3,3,2,2,1,1,1,1,0,0,0,0,0,0,0,0 };
965 int pos = s_index + idxtab[code];
966 code ^= 8 >> idxtab[code];
1002 if (s->sample_rate_index != 8)
1014 for (j = len; j > 0; j--) {
1015 *dst++ = ptr[0*
len];
1016 *dst++ = ptr[1*
len];
1017 *dst++ = ptr[2*
len];
1021 memcpy(ptr1, tmp, len * 3 *
sizeof(*ptr1));
1025 #define ISQRT2 FIXR(0.70710678118654752440)
1030 int sf_max, sf,
len, non_zero_found;
1031 INTFLOAT (*is_tab)[16], *tab0, *
tab1, tmp0, tmp1, v1, v2;
1032 int non_zero_found_short[3];
1047 non_zero_found_short[0] = 0;
1048 non_zero_found_short[1] = 0;
1049 non_zero_found_short[2] = 0;
1056 for (l = 2; l >= 0; l--) {
1059 if (!non_zero_found_short[l]) {
1061 for (j = 0; j <
len; j++) {
1063 non_zero_found_short[l] = 1;
1073 for (j = 0; j <
len; j++) {
1083 for (j = 0; j <
len; j++) {
1094 non_zero_found = non_zero_found_short[0] |
1095 non_zero_found_short[1] |
1096 non_zero_found_short[2];
1098 for (i = g1->
long_end - 1;i >= 0;i--) {
1103 if (!non_zero_found) {
1104 for (j = 0; j <
len; j++) {
1111 k = (i == 21) ? 20 : i;
1117 for (j = 0; j <
len; j++) {
1127 for (j = 0; j <
len; j++) {
1145 for (i = 0; i < 576; i++) {
1148 tab0[i] = tmp0 + tmp1;
1149 tab1[i] = tmp0 - tmp1;
1165 #ifndef compute_antialias
1167 #define AA(j) do { \
1168 float tmp0 = ptr[-1-j]; \
1169 float tmp1 = ptr[ j]; \
1170 ptr[-1-j] = tmp0 * csa_table[j][0] - tmp1 * csa_table[j][1]; \
1171 ptr[ j] = tmp0 * csa_table[j][1] + tmp1 * csa_table[j][0]; \
1174 #define AA(j) do { \
1175 int tmp0 = ptr[-1-j]; \
1176 int tmp1 = ptr[ j]; \
1177 int tmp2 = MULH(tmp0 + tmp1, csa_table[j][0]); \
1178 ptr[-1-j] = 4 * (tmp2 - MULH(tmp1, csa_table[j][2])); \
1179 ptr[ j] = 4 * (tmp2 + MULH(tmp0, csa_table[j][3])); \
1199 for (i = n; i > 0; i--) {
1219 int i, j, mdct_long_end, sblimit;
1224 while (ptr >= ptr1) {
1228 if (p[0] | p[1] | p[2] | p[3] | p[4] | p[5])
1231 sblimit = ((ptr - g->
sb_hybrid) / 18) + 1;
1240 mdct_long_end = sblimit;
1247 buf = mdct_buf + 4*18*(mdct_long_end >> 2) + (mdct_long_end & 3);
1248 ptr = g->
sb_hybrid + 18 * mdct_long_end;
1250 for (j = mdct_long_end; j < sblimit; j++) {
1252 win =
RENAME(ff_mdct_win)[2 + (4 & -(j & 1))];
1253 out_ptr = sb_samples + j;
1255 for (i = 0; i < 6; i++) {
1256 *out_ptr = buf[4*i];
1260 for (i = 0; i < 6; i++) {
1261 *out_ptr =
MULH3(out2[i ], win[i ], 1) + buf[4*(i + 6*1)];
1262 buf[4*(i + 6*2)] =
MULH3(out2[i + 6], win[i + 6], 1);
1266 for (i = 0; i < 6; i++) {
1267 *out_ptr =
MULH3(out2[i ], win[i ], 1) + buf[4*(i + 6*2)];
1268 buf[4*(i + 6*0)] =
MULH3(out2[i + 6], win[i + 6], 1);
1272 for (i = 0; i < 6; i++) {
1273 buf[4*(i + 6*0)] =
MULH3(out2[i ], win[i ], 1) + buf[4*(i + 6*0)];
1274 buf[4*(i + 6*1)] =
MULH3(out2[i + 6], win[i + 6], 1);
1275 buf[4*(i + 6*2)] = 0;
1278 buf += (j&3) != 3 ? 1 : (4*18-3);
1281 for (j = sblimit; j <
SBLIMIT; j++) {
1283 out_ptr = sb_samples + j;
1284 for (i = 0; i < 18; i++) {
1285 *out_ptr = buf[4*i];
1289 buf += (j&3) != 3 ? 1 : (4*18-3);
1296 int nb_granules, main_data_begin;
1297 int gr, ch, blocksplit_flag, i, j, k,
n, bits_pos;
1299 int16_t exponents[576];
1308 if (s->nb_channels == 2)
1313 for (ch = 0; ch < s->nb_channels; ch++) {
1319 for (gr = 0; gr < nb_granules; gr++) {
1320 for (ch = 0; ch < s->nb_channels; ch++) {
1341 if (blocksplit_flag) {
1348 for (i = 0; i < 2; i++)
1350 for (i = 0; i < 3; i++)
1354 int region_address1, region_address2;
1357 for (i = 0; i < 3; i++)
1363 region_address1, region_address2);
1391 #if !UNCHECKED_BITSTREAM_READER
1395 for (gr = 0; gr < nb_granules && (s->
last_buf_size >> 3) < main_data_begin; gr++) {
1396 for (ch = 0; ch < s->nb_channels; ch++) {
1415 for (; gr < nb_granules; gr++) {
1416 for (ch = 0; ch < s->nb_channels; ch++) {
1422 int slen, slen1, slen2;
1427 av_dlog(s->
avctx,
"slen1=%d slen2=%d\n", slen1, slen2);
1432 for (i = 0; i <
n; i++)
1435 for (i = 0; i <
n; i++)
1439 for (i = 0; i < 18; i++)
1441 for (i = 0; i < 3; i++)
1444 for (i = 0; i < 21; i++)
1450 for (k = 0; k < 4; k++) {
1452 if ((g->
scfsi & (0x8 >> k)) == 0) {
1453 slen = (k < 2) ? slen1 : slen2;
1455 for (i = 0; i <
n; i++)
1458 for (i = 0; i <
n; i++)
1463 for (i = 0; i <
n; i++) {
1472 int tindex, tindex2, slen[4], sl, sf;
1487 }
else if (sf < 244) {
1499 }
else if (sf < 500) {
1510 for (k = 0; k < 4; k++) {
1514 for (i = 0; i <
n; i++)
1517 for (i = 0; i <
n; i++)
1535 for (ch = 0; ch < s->nb_channels; ch++) {
1545 return nb_granules * 18;
1551 int i, nb_frames, ch,
ret;
1557 if (s->error_protection)
1596 av_assert1(i <= buf_size - HEADER_SIZE && i >= 0);
1614 for (ch = 0; ch < s->nb_channels; ch++) {
1617 samples_ptr = samples[ch];
1620 samples_ptr = samples[0] + ch;
1621 sample_stride = s->nb_channels;
1623 for (i = 0; i < nb_frames; i++) {
1626 RENAME(ff_mpa_synth_window),
1629 samples_ptr += 32 * sample_stride;
1633 return nb_frames * 32 *
sizeof(
OUT_INT) * s->nb_channels;
1640 int buf_size = avpkt->
size;
1645 while(buf_size && !*buf){
1654 if (header>>8 ==
AV_RB32(
"TAG")>>8) {
1674 if (s->frame_size <= 0 || s->frame_size > buf_size) {
1677 }
else if (s->frame_size < buf_size) {
1679 buf_size= s->frame_size;
1718 #if CONFIG_MP3ADU_DECODER || CONFIG_MP3ADUFLOAT_DECODER
1720 int *got_frame_ptr,
AVPacket *avpkt)
1723 int buf_size = avpkt->
size;
1742 header =
AV_RB32(buf) | 0xffe00000;
1757 s->frame_size =
len;
1773 #if CONFIG_MP3ON4_DECODER || CONFIG_MP3ON4FLOAT_DECODER
1778 typedef struct MP3On4DecodeContext {
1783 } MP3On4DecodeContext;
1790 static const uint8_t mp3Frames[8] = { 0, 1, 1, 2, 3, 3, 4, 5 };
1793 static const uint8_t chan_offset[8][5] = {
1805 static const int16_t chan_layout[8] = {
1818 MP3On4DecodeContext *s = avctx->
priv_data;
1821 for (i = 0; i < s->frames; i++)
1830 MP3On4DecodeContext *s = avctx->
priv_data;
1851 s->syncword = 0xffe00000;
1853 s->syncword = 0xfff00000;
1862 if (!s->mp3decctx[0])
1869 s->mp3decctx[0]->adu_mode = 1;
1874 for (i = 1; i < s->frames; i++) {
1876 if (!s->mp3decctx[i])
1878 s->mp3decctx[i]->adu_mode = 1;
1879 s->mp3decctx[i]->avctx = avctx;
1880 s->mp3decctx[i]->mpadsp = s->mp3decctx[0]->mpadsp;
1885 decode_close_mp3on4(avctx);
1893 MP3On4DecodeContext *s = avctx->
priv_data;
1895 for (i = 0; i < s->frames; i++)
1900 static int decode_frame_mp3on4(
AVCodecContext *avctx,
void *data,
1901 int *got_frame_ptr,
AVPacket *avpkt)
1905 int buf_size = avpkt->
size;
1906 MP3On4DecodeContext *s = avctx->
priv_data;
1908 int fsize, len = buf_size, out_size = 0;
1927 for (fr = 0; fr < s->frames; fr++) {
1930 m = s->mp3decctx[fr];
1937 header = (
AV_RB32(buf) & 0x000fffff) | s->syncword;
1946 if (ch + m->nb_channels > avctx->
channels ||
1947 s->coff[fr] + m->nb_channels > avctx->
channels) {
1952 ch += m->nb_channels;
1954 outptr[0] = out_samples[s->coff[fr]];
1955 if (m->nb_channels > 1)
1956 outptr[1] = out_samples[s->coff[fr] + 1];
1961 if (m->nb_channels > 1)
1978 avctx->
sample_rate = s->mp3decctx[0]->sample_rate;