Go to the documentation of this file.
27 #include "config_components.h"
52 #define BACKSTEP_SIZE 512
54 #define LAST_BUF_SIZE 2 * BACKSTEP_SIZE + EXTRABYTES
100 #define HEADER_SIZE 4
112 #define SCALE_GEN(v) \
113 { FIXR_OLD(1.0 * (v)), FIXR_OLD(0.7937005259 * (v)), FIXR_OLD(0.6299605249 * (v)) }
128 g->region_size[2] = 576 / 2;
129 for (
i = 0;
i < 3;
i++) {
130 k =
FFMIN(
g->region_size[
i],
g->big_values);
131 g->region_size[
i] = k - j;
138 if (
g->block_type == 2) {
139 if (
s->sample_rate_index != 8)
140 g->region_size[0] = (36 / 2);
142 g->region_size[0] = (72 / 2);
144 if (
s->sample_rate_index <= 2)
145 g->region_size[0] = (36 / 2);
146 else if (
s->sample_rate_index != 8)
147 g->region_size[0] = (54 / 2);
149 g->region_size[0] = (108 / 2);
151 g->region_size[1] = (576 / 2);
160 l =
FFMIN(ra1 + ra2 + 2, 22);
166 if (
g->block_type == 2) {
167 if (
g->switch_point) {
168 if(
s->sample_rate_index == 8)
173 if (
s->sample_rate_index <= 2)
191 static inline int l1_unscale(
int n,
int mant,
int scale_factor)
235 m = (m + ((1U << e) >> 1)) >> e;
245 for (
i = 0;
i < 15;
i++) {
248 norm = ((INT64_C(1) << n) *
FRAC_ONE) / ((1 << n) - 1);
252 ff_dlog(
NULL,
"%d: norm=%x s=%"PRIx32
" %"PRIx32
" %"PRIx32
"\n",
i,
263 for (
i = 0;
i < 16;
i++) {
267 for (j = 0; j < 2; j++) {
268 e = -(j + 1) * ((
i + 1) >> 1);
278 RENAME(ff_mpa_synth_init)();
317 #define C3 FIXHR(0.86602540378443864676/2)
318 #define C4 FIXHR(0.70710678118654752439/2) //0.5 / cos(pi*(9)/36)
319 #define C5 FIXHR(0.51763809020504152469/2) //0.5 / cos(pi*(5)/36)
320 #define C6 FIXHR(1.93185165257813657349/4) //0.5 / cos(pi*(15)/36)
329 in1 = in[1*3] + in[0*3];
330 in2 = in[2*3] + in[1*3];
331 in3 = in[3*3] + in[2*3];
332 in4 = in[4*3] + in[3*3];
333 in5 = in[5*3] + in[4*3];
369 int sec_byte_len = sec_len >> 3;
370 int sec_rem_bits = sec_len & 7;
373 uint32_t crc_val =
av_crc(crc_tab, UINT16_MAX, &buf[2], 2);
374 crc_val =
av_crc(crc_tab, crc_val, &buf[6], sec_byte_len);
377 ((buf[6 + sec_byte_len] & (0xFF00 >> sec_rem_bits)) << 24) +
378 ((
s->crc << 16) >> sec_rem_bits));
380 crc_val =
av_crc(crc_tab, crc_val, tmp_buf, 3);
394 int bound,
i, v, n, ch, j, mant;
404 bound = (
s->mode_ext + 1) * 4;
410 for (ch = 0; ch <
s->nb_channels; ch++) {
419 for (ch = 0; ch <
s->nb_channels; ch++) {
420 if (allocation[ch][
i])
425 if (allocation[0][
i]) {
432 for (j = 0; j < 12; j++) {
434 for (ch = 0; ch <
s->nb_channels; ch++) {
435 n = allocation[ch][
i];
442 s->sb_samples[ch][j][
i] = v;
446 n = allocation[0][
i];
450 s->sb_samples[0][j][
i] = v;
452 s->sb_samples[1][j][
i] = v;
454 s->sb_samples[0][j][
i] = 0;
455 s->sb_samples[1][j][
i] = 0;
475 s->sample_rate,
s->lsf);
480 bound = (
s->mode_ext + 1) * 4;
494 for (ch = 0; ch <
s->nb_channels; ch++)
496 j += 1 << bit_alloc_bits;
503 j += 1 << bit_alloc_bits;
507 for (
i = 0;
i < sblimit;
i++) {
508 for (ch = 0; ch <
s->nb_channels; ch++) {
519 for (
i = 0;
i < sblimit;
i++) {
520 for (ch = 0; ch <
s->nb_channels; ch++) {
522 sf = scale_factors[ch][
i];
523 switch (scale_code[ch][
i]) {
551 for (k = 0; k < 3; k++) {
552 for (l = 0; l < 12; l += 3) {
556 for (ch = 0; ch <
s->nb_channels; ch++) {
559 scale = scale_factors[ch][
i][k];
569 s->sb_samples[ch][k * 12 + l + 0][
i] =
571 s->sb_samples[ch][k * 12 + l + 1][
i] =
573 s->sb_samples[ch][k * 12 + l + 2][
i] =
576 for (m = 0; m < 3; m++) {
579 s->sb_samples[ch][k * 12 + l + m][
i] = v;
583 s->sb_samples[ch][k * 12 + l + 0][
i] = 0;
584 s->sb_samples[ch][k * 12 + l + 1][
i] = 0;
585 s->sb_samples[ch][k * 12 + l + 2][
i] = 0;
589 j += 1 << bit_alloc_bits;
596 int mant, scale0, scale1;
597 scale0 = scale_factors[0][
i][k];
598 scale1 = scale_factors[1][
i][k];
607 s->sb_samples[0][k * 12 + l + 0][
i] =
609 s->sb_samples[1][k * 12 + l + 0][
i] =
613 s->sb_samples[0][k * 12 + l + 1][
i] =
615 s->sb_samples[1][k * 12 + l + 1][
i] =
617 s->sb_samples[0][k * 12 + l + 2][
i] =
619 s->sb_samples[1][k * 12 + l + 2][
i] =
622 for (m = 0; m < 3; m++) {
624 s->sb_samples[0][k * 12 + l + m][
i] =
626 s->sb_samples[1][k * 12 + l + m][
i] =
631 s->sb_samples[0][k * 12 + l + 0][
i] = 0;
632 s->sb_samples[0][k * 12 + l + 1][
i] = 0;
633 s->sb_samples[0][k * 12 + l + 2][
i] = 0;
634 s->sb_samples[1][k * 12 + l + 0][
i] = 0;
635 s->sb_samples[1][k * 12 + l + 1][
i] = 0;
636 s->sb_samples[1][k * 12 + l + 2][
i] = 0;
639 j += 1 << bit_alloc_bits;
643 for (ch = 0; ch <
s->nb_channels; ch++) {
644 s->sb_samples[ch][k * 12 + l + 0][
i] = 0;
645 s->sb_samples[ch][k * 12 + l + 1][
i] = 0;
646 s->sb_samples[ch][k * 12 + l + 2][
i] = 0;
654 #define SPLIT(dst,sf,n) \
656 int m = (sf * 171) >> 9; \
659 } else if (n == 4) { \
662 } else if (n == 5) { \
663 int m = (sf * 205) >> 10; \
666 } else if (n == 6) { \
667 int m = (sf * 171) >> 10; \
677 SPLIT(slen[3], sf, n3)
678 SPLIT(slen[2], sf, n2)
679 SPLIT(slen[1], sf, n1)
686 const uint8_t *bstab, *pretab;
691 gain =
g->global_gain - 210;
692 shift =
g->scalefac_scale + 1;
696 for (
i = 0;
i <
g->long_end;
i++) {
697 v0 = gain - ((
g->scale_factors[
i] + pretab[
i]) <<
shift) + 400;
699 for (j =
len; j > 0; j--)
703 if (
g->short_start < 13) {
705 gains[0] = gain - (
g->subblock_gain[0] << 3);
706 gains[1] = gain - (
g->subblock_gain[1] << 3);
707 gains[2] = gain - (
g->subblock_gain[2] << 3);
709 for (
i =
g->short_start;
i < 13;
i++) {
711 for (l = 0; l < 3; l++) {
712 v0 = gains[l] - (
g->scale_factors[k++] <<
shift) + 400;
713 for (j =
len; j > 0; j--)
723 if (
s->in_gb.buffer && *
pos >=
s->gb.size_in_bits -
s->extrasize * 8) {
725 s->in_gb.buffer =
NULL;
742 #define READ_FLIP_SIGN(dst,src) \
743 v = AV_RN32A(src) ^ (get_bits1(&s->gb) << 31); \
746 #define READ_FLIP_SIGN(dst,src) \
747 v = -get_bits1(&s->gb); \
748 *(dst) = (*(src) ^ v) - v;
752 int16_t *exponents,
int end_pos2)
756 int last_pos, bits_left;
758 int end_pos =
FFMIN(end_pos2,
s->gb.size_in_bits -
s->extrasize * 8);
762 for (
i = 0;
i < 3;
i++) {
763 int j, k, l, linbits;
764 j =
g->region_size[
i];
768 k =
g->table_select[
i];
774 memset(&
g->sb_hybrid[s_index], 0,
sizeof(*
g->sb_hybrid) * 2 * j);
793 g->sb_hybrid[s_index ] =
794 g->sb_hybrid[s_index + 1] = 0;
799 exponent= exponents[s_index];
801 ff_dlog(
s->avctx,
"region=%d n=%d y=%d exp=%d\n",
802 i,
g->region_size[
i] - j, y, exponent);
813 g->sb_hybrid[s_index] = v;
822 g->sb_hybrid[s_index + 1] = v;
835 g->sb_hybrid[s_index+!!y] = v;
837 g->sb_hybrid[s_index + !y] = 0;
846 while (s_index <= 572) {
849 if (
pos >= end_pos) {
850 if (
pos > end_pos2 && last_pos) {
867 ff_dlog(
s->avctx,
"t=%d code=%d\n",
g->count1table_select,
code);
868 g->sb_hybrid[s_index + 0] =
869 g->sb_hybrid[s_index + 1] =
870 g->sb_hybrid[s_index + 2] =
871 g->sb_hybrid[s_index + 3] = 0;
873 static const int idxtab[16] = { 3,3,2,2,1,1,1,1,0,0,0,0,0,0,0,0 };
875 int pos = s_index + idxtab[
code];
890 memset(&
g->sb_hybrid[s_index], 0,
sizeof(*
g->sb_hybrid) * (576 - s_index));
908 if (
g->block_type != 2)
911 if (
g->switch_point) {
912 if (
s->sample_rate_index != 8)
913 ptr =
g->sb_hybrid + 36;
915 ptr =
g->sb_hybrid + 72;
920 for (
i =
g->short_start;
i < 13;
i++) {
924 for (j =
len; j > 0; j--) {
931 memcpy(ptr1,
tmp,
len * 3 *
sizeof(*ptr1));
935 #define ISQRT2 FIXR(0.70710678118654752440)
940 int sf_max, sf,
len, non_zero_found;
944 int non_zero_found_short[3];
959 non_zero_found_short[0] = 0;
960 non_zero_found_short[1] = 0;
961 non_zero_found_short[2] = 0;
968 for (l = 2; l >= 0; l--) {
971 if (!non_zero_found_short[l]) {
973 for (j = 0; j <
len; j++) {
975 non_zero_found_short[l] = 1;
985 for (j = 0; j <
len; j++) {
995 for (j = 0; j <
len; j++) {
1006 non_zero_found = non_zero_found_short[0] |
1007 non_zero_found_short[1] |
1008 non_zero_found_short[2];
1015 if (!non_zero_found) {
1016 for (j = 0; j <
len; j++) {
1023 k = (
i == 21) ? 20 :
i;
1029 for (j = 0; j <
len; j++) {
1039 for (j = 0; j <
len; j++) {
1057 for (
i = 0;
i < 576;
i++) {
1060 tab0[
i] = tmp0 + tmp1;
1061 tab1[
i] = tmp0 - tmp1;
1077 #ifndef compute_antialias
1079 #define AA(j) do { \
1080 float tmp0 = ptr[-1-j]; \
1081 float tmp1 = ptr[ j]; \
1082 ptr[-1-j] = tmp0 * csa_table[j][0] - tmp1 * csa_table[j][1]; \
1083 ptr[ j] = tmp0 * csa_table[j][1] + tmp1 * csa_table[j][0]; \
1086 #define AA(j) do { \
1087 SUINT tmp0 = ptr[-1-j]; \
1088 SUINT tmp1 = ptr[ j]; \
1089 SUINT tmp2 = MULH(tmp0 + tmp1, csa_table[j][0]); \
1090 ptr[-1-j] = 4 * (tmp2 - MULH(tmp1, csa_table[j][2])); \
1091 ptr[ j] = 4 * (tmp2 + MULH(tmp0, csa_table[j][3])); \
1101 if (
g->block_type == 2) {
1102 if (!
g->switch_point)
1110 ptr =
g->sb_hybrid + 18;
1111 for (
i = n;
i > 0;
i--) {
1131 int i, j, mdct_long_end, sblimit;
1134 ptr =
g->sb_hybrid + 576;
1135 ptr1 =
g->sb_hybrid + 2 * 18;
1136 while (ptr >= ptr1) {
1140 if (p[0] | p[1] | p[2] | p[3] | p[4] | p[5])
1143 sblimit = ((ptr -
g->sb_hybrid) / 18) + 1;
1145 if (
g->block_type == 2) {
1147 if (
g->switch_point)
1152 mdct_long_end = sblimit;
1155 s->mpadsp.RENAME(imdct36_blocks)(sb_samples, mdct_buf,
g->sb_hybrid,
1156 mdct_long_end,
g->switch_point,
1159 buf = mdct_buf + 4*18*(mdct_long_end >> 2) + (mdct_long_end & 3);
1160 ptr =
g->sb_hybrid + 18 * mdct_long_end;
1162 for (j = mdct_long_end; j < sblimit; j++) {
1164 win =
RENAME(ff_mdct_win)[2 + (4 & -(j & 1))];
1165 out_ptr = sb_samples + j;
1167 for (
i = 0;
i < 6;
i++) {
1168 *out_ptr = buf[4*
i];
1172 for (
i = 0;
i < 6;
i++) {
1173 *out_ptr =
MULH3(out2[
i ],
win[
i ], 1) + buf[4*(
i + 6*1)];
1174 buf[4*(
i + 6*2)] =
MULH3(out2[
i + 6],
win[
i + 6], 1);
1178 for (
i = 0;
i < 6;
i++) {
1179 *out_ptr =
MULH3(out2[
i ],
win[
i ], 1) + buf[4*(
i + 6*2)];
1180 buf[4*(
i + 6*0)] =
MULH3(out2[
i + 6],
win[
i + 6], 1);
1184 for (
i = 0;
i < 6;
i++) {
1185 buf[4*(
i + 6*0)] =
MULH3(out2[
i ],
win[
i ], 1) + buf[4*(
i + 6*0)];
1186 buf[4*(
i + 6*1)] =
MULH3(out2[
i + 6],
win[
i + 6], 1);
1187 buf[4*(
i + 6*2)] = 0;
1190 buf += (j&3) != 3 ? 1 : (4*18-3);
1193 for (j = sblimit; j <
SBLIMIT; j++) {
1195 out_ptr = sb_samples + j;
1196 for (
i = 0;
i < 18;
i++) {
1197 *out_ptr = buf[4*
i];
1201 buf += (j&3) != 3 ? 1 : (4*18-3);
1208 int nb_granules, main_data_begin;
1209 int gr, ch, blocksplit_flag,
i, j, k, n, bits_pos;
1211 int16_t exponents[576];
1223 if (
s->nb_channels == 2)
1228 for (ch = 0; ch <
s->nb_channels; ch++) {
1229 s->granules[ch][0].scfsi = 0;
1230 s->granules[ch][1].scfsi =
get_bits(&
s->gb, 4);
1236 for (gr = 0; gr < nb_granules; gr++) {
1237 for (ch = 0; ch <
s->nb_channels; ch++) {
1238 ff_dlog(
s->avctx,
"gr=%d ch=%d: side_info\n", gr, ch);
1239 g = &
s->granules[ch][gr];
1242 if (
g->big_values > 288) {
1252 g->global_gain -= 2;
1258 if (blocksplit_flag) {
1260 if (
g->block_type == 0) {
1265 for (
i = 0;
i < 2;
i++)
1267 for (
i = 0;
i < 3;
i++)
1271 int region_address1, region_address2;
1273 g->switch_point = 0;
1274 for (
i = 0;
i < 3;
i++)
1279 ff_dlog(
s->avctx,
"region1=%d region2=%d\n",
1280 region_address1, region_address2);
1291 ff_dlog(
s->avctx,
"block_type=%d switch_point=%d\n",
1292 g->block_type,
g->switch_point);
1303 ff_dlog(
s->avctx,
"seekback:%d, lastbuf:%d\n",
1304 main_data_begin,
s->last_buf_size);
1306 memcpy(
s->last_buf +
s->last_buf_size, ptr,
s->extrasize);
1309 s->last_buf_size <<= 3;
1310 for (gr = 0; gr < nb_granules && (
s->last_buf_size >> 3) < main_data_begin; gr++) {
1311 for (ch = 0; ch <
s->nb_channels; ch++) {
1312 g = &
s->granules[ch][gr];
1313 s->last_buf_size +=
g->part2_3_length;
1314 memset(
g->sb_hybrid, 0,
sizeof(
g->sb_hybrid));
1318 skip =
s->last_buf_size - 8 * main_data_begin;
1319 if (skip >=
s->gb.size_in_bits -
s->extrasize * 8 &&
s->in_gb.buffer) {
1322 s->in_gb.buffer =
NULL;
1332 for (; gr < nb_granules; gr++) {
1333 for (ch = 0; ch <
s->nb_channels; ch++) {
1334 g = &
s->granules[ch][gr];
1339 int slen, slen1, slen2;
1344 ff_dlog(
s->avctx,
"slen1=%d slen2=%d\n", slen1, slen2);
1345 if (
g->block_type == 2) {
1346 n =
g->switch_point ? 17 : 18;
1349 for (
i = 0;
i < n;
i++)
1350 g->scale_factors[j++] =
get_bits(&
s->gb, slen1);
1352 for (
i = 0;
i < n;
i++)
1353 g->scale_factors[j++] = 0;
1356 for (
i = 0;
i < 18;
i++)
1357 g->scale_factors[j++] =
get_bits(&
s->gb, slen2);
1358 for (
i = 0;
i < 3;
i++)
1359 g->scale_factors[j++] = 0;
1361 for (
i = 0;
i < 21;
i++)
1362 g->scale_factors[j++] = 0;
1365 sc =
s->granules[ch][0].scale_factors;
1367 for (k = 0; k < 4; k++) {
1369 if ((
g->scfsi & (0x8 >> k)) == 0) {
1370 slen = (k < 2) ? slen1 : slen2;
1372 for (
i = 0;
i < n;
i++)
1373 g->scale_factors[j++] =
get_bits(&
s->gb, slen);
1375 for (
i = 0;
i < n;
i++)
1376 g->scale_factors[j++] = 0;
1380 for (
i = 0;
i < n;
i++) {
1381 g->scale_factors[j] = sc[j];
1386 g->scale_factors[j++] = 0;
1389 int tindex, tindex2, slen[4], sl, sf;
1392 if (
g->block_type == 2)
1393 tindex =
g->switch_point ? 2 : 1;
1397 sf =
g->scalefac_compress;
1404 }
else if (sf < 244) {
1416 }
else if (sf < 500) {
1427 for (k = 0; k < 4; k++) {
1431 for (
i = 0;
i < n;
i++)
1432 g->scale_factors[j++] =
get_bits(&
s->gb, sl);
1434 for (
i = 0;
i < n;
i++)
1435 g->scale_factors[j++] = 0;
1440 g->scale_factors[j] = 0;
1452 for (ch = 0; ch <
s->nb_channels; ch++) {
1453 g = &
s->granules[ch][gr];
1462 return nb_granules * 18;
1466 const uint8_t *buf,
int buf_size)
1468 int i, nb_frames, ch,
ret;
1472 if (
s->error_protection)
1477 s->avctx->frame_size = 384;
1481 s->avctx->frame_size = 1152;
1485 s->avctx->frame_size =
s->lsf ? 576 : 1152;
1490 if (
s->in_gb.buffer) {
1499 s->in_gb.buffer =
NULL;
1511 av_assert1(i <= buf_size - HEADER_SIZE && i >= 0);
1512 memcpy(
s->last_buf +
s->last_buf_size,
s->gb.buffer + buf_size -
HEADER_SIZE -
i,
i);
1513 s->last_buf_size +=
i;
1522 s->frame->nb_samples =
s->avctx->frame_size;
1529 for (ch = 0; ch <
s->nb_channels; ch++) {
1535 samples_ptr =
samples[0] + ch;
1536 sample_stride =
s->nb_channels;
1538 for (
i = 0;
i < nb_frames;
i++) {
1539 RENAME(ff_mpa_synth_filter)(&
s->mpadsp,
s->synth_buf[ch],
1540 &(
s->synth_buf_offset[ch]),
1541 RENAME(ff_mpa_synth_window),
1542 &
s->dither_state, samples_ptr,
1543 sample_stride,
s->sb_samples[ch][
i]);
1544 samples_ptr += 32 * sample_stride;
1548 return nb_frames * 32 *
sizeof(
OUT_INT) *
s->nb_channels;
1552 int *got_frame_ptr,
AVPacket *avpkt)
1554 const uint8_t *buf = avpkt->
data;
1555 int buf_size = avpkt->
size;
1561 while(buf_size && !*buf){
1573 return buf_size + skipped;
1579 }
else if (
ret == 1) {
1591 if (
s->frame_size <= 0) {
1594 }
else if (
s->frame_size < buf_size) {
1596 buf_size=
s->frame_size;
1619 return buf_size + skipped;
1624 memset(
ctx->synth_buf, 0,
sizeof(
ctx->synth_buf));
1625 memset(
ctx->mdct_buf, 0,
sizeof(
ctx->mdct_buf));
1626 ctx->last_buf_size = 0;
1627 ctx->dither_state = 0;
1635 #if CONFIG_MP3ADU_DECODER || CONFIG_MP3ADUFLOAT_DECODER
1637 int *got_frame_ptr,
AVPacket *avpkt)
1639 const uint8_t *buf = avpkt->
data;
1640 int buf_size = avpkt->
size;
1673 s->frame_size =
len;
1689 #if CONFIG_MP3ON4_DECODER || CONFIG_MP3ON4FLOAT_DECODER
1694 typedef struct MP3On4DecodeContext {
1697 const uint8_t *coff;
1699 } MP3On4DecodeContext;
1706 static const uint8_t mp3Frames[8] = { 0, 1, 1, 2, 3, 3, 4, 5 };
1709 static const uint8_t chan_offset[8][5] = {
1721 static const int16_t chan_layout[8] = {
1737 for (
i = 0;
i <
s->frames;
i++)
1767 s->syncword = 0xffe00000;
1769 s->syncword = 0xfff00000;
1778 if (!
s->mp3decctx[0])
1787 s->mp3decctx[0]->adu_mode = 1;
1792 for (
i = 1;
i <
s->frames;
i++) {
1794 if (!
s->mp3decctx[
i])
1796 s->mp3decctx[
i]->adu_mode = 1;
1797 s->mp3decctx[
i]->avctx = avctx;
1798 s->mp3decctx[
i]->mpadsp =
s->mp3decctx[0]->mpadsp;
1799 s->mp3decctx[
i]->butterflies_float =
s->mp3decctx[0]->butterflies_float;
1811 for (
i = 0;
i <
s->frames;
i++)
1817 int *got_frame_ptr,
AVPacket *avpkt)
1819 const uint8_t *buf = avpkt->
data;
1820 int buf_size = avpkt->
size;
1842 for (fr = 0; fr <
s->frames; fr++) {
1845 m =
s->mp3decctx[fr];
1866 ch += m->nb_channels;
1868 outptr[0] = out_samples[
s->coff[fr]];
1869 if (m->nb_channels > 1)
1870 outptr[1] = out_samples[
s->coff[fr] + 1];
1875 if (m->nb_channels > 1)
int frame_size
Number of samples per channel in an audio frame.
uint8_t scale_factors[40]
MPA_DECODE_HEADER uint8_t last_buf[LAST_BUF_SIZE]
static void compute_band_indexes(MPADecodeContext *s, GranuleDef *g)
static void skip_bits_long(GetBitContext *s, int n)
Skips the specified number of bits.
#define AV_LOG_WARNING
Something somehow does not look correct.
static int l3_unscale(int value, int exponent)
static void init_short_region(MPADecodeContext *s, GranuleDef *g)
int ff_mpa_l2_select_table(int bitrate, int nb_channels, int freq, int lsf)
static int get_bits_left(GetBitContext *gb)
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
int sample_rate
samples per second
GranuleDef granules[2][2]
static int l1_unscale(int n, int mant, int scale_factor)
#define AV_CH_LAYOUT_MONO
static void mp_flush(MPADecodeContext *ctx)
int err_recognition
Error recognition; may misdetect some more or less valid parts as errors.
static int get_bits_count(const GetBitContext *s)
av_cold void ff_mpadsp_init(MPADSPContext *s)
This structure describes decoded (raw) audio or video data.
int adu_mode
0 for standard mp3, 1 for adu formatted mp3
static const uint16_t table[]
#define AV_CHANNEL_LAYOUT_MONO
static int mp_decode_frame(MPADecodeContext *s, OUT_INT **samples, const uint8_t *buf, int buf_size)
static void compute_antialias(MPADecodeContext *s, GranuleDef *g)
static INTFLOAT is_table_lsf[2][2][16]
const int ff_mpa_quant_bits[17]
#define AV_CHANNEL_LAYOUT_STEREO
#define AV_EF_COMPLIANT
consider all spec non compliances as errors
#define AV_EF_BUFFER
detect improper bitstream length
int nb_channels
Number of channels in this layout.
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
void(* butterflies_float)(float *av_restrict v1, float *av_restrict v2, int len)
Calculate the sum and difference of two vectors of floats.
static float win(SuperEqualizerContext *s, float n, int N)
static av_cold void mpegaudio_tableinit(void)
static void skip_bits(GetBitContext *s, int n)
int8_t ff_table_4_3_exp[TABLE_4_3_SIZE]
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
static void exponents_from_scale_factors(MPADecodeContext *s, GranuleDef *g, int16_t *exponents)
static void reorder_block(MPADecodeContext *s, GranuleDef *g)
static int mp_decode_layer3(MPADecodeContext *s)
AVChannelLayout ch_layout
Audio channel layout.
if it could not because there are no more frames
int flags
AV_CODEC_FLAG_*.
static double val(void *priv, double ch)
static av_always_inline float scale(float x, float s)
#define AV_CH_LAYOUT_STEREO
const uint8_t ff_slen_table[2][16]
static int bit_alloc(AC3EncodeContext *s, int snr_offset)
Run the bit allocation with a given SNR offset.
#define AV_EF_BITSTREAM
detect bitstream specification deviations
static int ff_thread_once(char *control, void(*routine)(void))
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
const int ff_mpa_quant_steps[17]
static void compute_imdct(MPADecodeContext *s, GranuleDef *g, INTFLOAT *sb_samples, INTFLOAT *mdct_buf)
static void imdct12(INTFLOAT *out, SUINTFLOAT *in)
#define MODE_EXT_MS_STEREO
const uint8_t ff_mpa_huff_data[32][2]
int avpriv_mpeg4audio_get_config2(MPEG4AudioConfig *c, const uint8_t *buf, int size, int sync_extension, void *logctx)
Parse MPEG-4 systems extradata from a raw buffer to retrieve audio configuration.
void ff_mpegaudiodec_common_init_static(void)
#define av_assert0(cond)
assert() equivalent, that is always enabled.
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
static int64_t fsize(FILE *f)
const unsigned char *const ff_mpa_alloc_tables[5]
#define SPLIT(dst, sf, n)
static void compute_stereo(MPADecodeContext *s, GranuleDef *g0, GranuleDef *g1)
static int huffman_decode(MPADecodeContext *s, GranuleDef *g, int16_t *exponents, int end_pos2)
int64_t bit_rate
the average bitrate
void(* butterflies_float)(float *av_restrict v1, float *av_restrict v2, int len)
int sb_hybrid[SBLIMIT *18]
static unsigned int get_bits1(GetBitContext *s)
static int mp_decode_layer1(MPADecodeContext *s)
#define AV_CH_LAYOUT_5POINT1
#define AV_EF_EXPLODE
abort decoding on minor error detection
static av_always_inline int get_vlc2(GetBitContext *s, const VLCElem *table, int bits, int max_depth)
Parse a vlc code.
void av_channel_layout_uninit(AVChannelLayout *channel_layout)
Free any allocated data in the channel layout and reset the channel count to 0.
int ff_get_buffer(AVCodecContext *avctx, AVFrame *frame, int flags)
Get a buffer for a frame.
An AVChannelLayout holds information about the channel layout of audio data.
static av_always_inline void lsf_sf_expand(int *slen, int sf, int n1, int n2, int n3)
int16_t *const ff_division_tabs[4]
enum AVSampleFormat sample_fmt
audio sample format
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_RB32
#define READ_FLIP_SIGN(dst, src)
static const uint8_t header[24]
uint32_t free_format_next_header
const AVCRC * av_crc_get_table(AVCRCId crc_id)
Get an initialized standard CRC table.
enum AVSampleFormat request_sample_fmt
desired sample format
static av_cold void decode_init_static(void)
static int handle_crc(MPADecodeContext *s, int sec_len)
#define AV_LOG_INFO
Standard information.
static int32_t scale_factor_mult[15][3]
#define DECLARE_ALIGNED(n, t, v)
#define AV_CH_LAYOUT_5POINT0
static void switch_buffer(MPADecodeContext *s, int *pos, int *end_pos, int *end_pos2)
#define av_assert2(cond)
assert() equivalent, that does lie in speed critical code.
#define i(width, name, range_min, range_max)
and forward the test the status of outputs and forward it to the corresponding return FFERROR_NOT_READY If the filters stores internally one or a few frame for some it can consider them to be part of the FIFO and delay acknowledging a status change accordingly Example code
uint8_t * extradata
some codecs need / can use extradata like Huffman tables.
const int ff_mpa_sblimit_table[5]
static const int32_t is_table[2][16]
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
#define AV_CH_LAYOUT_7POINT1
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default value
MPA_INT synth_buf[MPA_MAX_CHANNELS][512 *2]
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
uint16_t ff_band_index_long[9][23]
static int mod(int a, int b)
Modulo operation with only positive remainders.
FF_ENABLE_DEPRECATION_WARNINGS int av_channel_layout_from_mask(AVChannelLayout *channel_layout, uint64_t mask)
Initialize a native channel layout from a bitmask indicating which channels are present.
static double bound(const double threshold, const double val)
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several the filter must be ready for frames arriving randomly on any input any filter with several inputs will most likely require some kind of queuing mechanism It is perfectly acceptable to have a limited queue and to drop frames when the inputs are too unbalanced request_frame For filters that do not use the this method is called when a frame is wanted on an output For a it should directly call filter_frame on the corresponding output For a if there are queued frames already one of these frames should be pushed If the filter should request a frame on one of its repeatedly until at least one frame has been pushed Return or at least make progress towards producing a frame
#define AV_CH_LAYOUT_SURROUND
#define AV_EF_CRCCHECK
Verify checksums embedded in the bitstream (could be of either encoded or decoded data,...
static const uint8_t * align_get_bits(GetBitContext *s)
uint32_t ff_table_4_3_value[TABLE_4_3_SIZE]
main external API structure.
int synth_buf_offset[MPA_MAX_CHANNELS]
uint32_t av_crc(const AVCRC *ctx, uint32_t crc, const uint8_t *buffer, size_t length)
Calculate the CRC of a block.
const uint8_t ff_mpa_pretab[2][22]
static void region_offset2size(GranuleDef *g)
Convert region offsets to region sizes and truncate size to big_values.
static void init_long_region(MPADecodeContext *s, GranuleDef *g, int ra1, int ra2)
#define MODE_EXT_I_STEREO
static int alloc_table(VLC *vlc, int size, int use_static)
static void flush(AVCodecContext *avctx)
Filter the word “frame” indicates either a video frame or a group of audio samples
static int l2_unscale_group(int steps, int mant, int scale_factor)
#define AV_EF_AGGRESSIVE
consider things that a sane encoder should not do as an error
static int shift(int a, int b)
int sb_samples[MPA_MAX_CHANNELS][36][SBLIMIT]
uint8_t count1table_select
const uint8_t ff_band_size_long[9][22]
uint16_t ff_scale_factor_modshift[64]
static av_always_inline int get_bitsz(GetBitContext *s, int n)
Read 0-25 bits.
#define AV_CODEC_FLAG_BITEXACT
Use only bitexact stuff (except (I)DCT).
#define avpriv_request_sample(...)
This structure stores compressed data.
av_cold AVFloatDSPContext * avpriv_float_dsp_alloc(int bit_exact)
Allocate a float DSP context.
const uint8_t ff_lsf_nsf_table[6][3][4]
static av_cold int decode_init(AVCodecContext *avctx)
#define AV_CH_LAYOUT_4POINT0
static const int32_t scale_factor_mult2[3][3]
const uint8_t ff_band_size_short[9][13]
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
INTFLOAT mdct_buf[MPA_MAX_CHANNELS][SBLIMIT *18]
static int decode_frame(AVCodecContext *avctx, AVFrame *frame, int *got_frame_ptr, AVPacket *avpkt)
#define MPA_MAX_CODED_FRAME_SIZE
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_WB32 unsigned int_TMPL AV_WB24 unsigned int_TMPL AV_RB16
static int mp_decode_layer2(MPADecodeContext *s)