27 #include "config_components.h"
68 5, 6, 7, 8, 9, 10, 11, 12, 14, 16
92 3.162275, 2.818382, 2.511886, 2.238719, 1.995261, 1.778278, 1.584893,
93 1.412536, 1.258924, 1.122018, 1.000000, 0.891251, 0.794328, 0.707946,
94 0.630957, 0.562341, 0.501187, 0.446683, 0.398107, 0.354813, 0.316227,
95 0.281838, 0.251188, 0.223872, 0.199526, 0.177828, 0.158489, 0.141253,
96 0.125892, 0.112201, 0.100000, 0.089125
104 { { 2, 7 }, { 7, 2 }, },
106 { { 2, 7 }, { 7, 2 }, },
107 { { 2, 7 }, { 5, 5 }, { 7, 2 }, },
108 { { 2, 7 }, { 7, 2 }, { 6, 6 }, },
109 { { 2, 7 }, { 5, 5 }, { 7, 2 }, { 8, 8 }, },
110 { { 2, 7 }, { 7, 2 }, { 6, 7 }, { 7, 6 }, },
111 { { 2, 7 }, { 5, 5 }, { 7, 2 }, { 6, 7 }, { 7, 6 }, },
122 return ((
code - (levels >> 1)) * (1 << 24)) / levels;
134 for (
i = 0;
i < 128;
i++) {
142 for (
i = 0;
i < 32;
i++) {
148 for (
i = 0;
i < 128;
i++) {
160 for (
i = 0;
i < 7;
i++) {
164 for (
i = 0;
i < 15;
i++) {
172 for (
i = 0;
i < 256;
i++) {
173 int v = (
i >> 5) - ((
i >> 7) << 3) - 5;
179 for (
i = 0;
i < 256;
i++) {
180 int v = (
i >> 4) - ((
i >> 7) << 4) - 4;
223 #if FF_API_OLD_CHANNEL_LAYOUT
225 if (avctx->request_channel_layout) {
243 s->xcfptr[
i] =
s->transform_coeffs[
i];
244 s->dlyptr[
i] =
s->delay[
i];
263 i = !
s->channel_mode;
265 s->dialog_normalization[(!
s->channel_mode)-
i] = -
get_bits(gbc, 5);
266 if (
s->dialog_normalization[(!
s->channel_mode)-
i] == 0) {
267 s->dialog_normalization[(!
s->channel_mode)-
i] = -31;
269 if (
s->target_level != 0) {
270 s->level_gain[(!
s->channel_mode)-
i] =
powf(2.0
f,
271 (
float)(
s->target_level -
272 s->dialog_normalization[(!
s->channel_mode)-
i])/6.0f);
274 if (
s->compression_exists[(!
s->channel_mode)-
i] =
get_bits1(gbc)) {
275 s->heavy_dynamic_range[(!
s->channel_mode)-
i] =
287 if (
s->bitstream_id != 6) {
295 s->center_mix_level_ltrt =
get_bits(gbc, 3);
301 s->dolby_surround_ex_mode =
get_bits(gbc, 2);
302 s->dolby_headphone_mode =
get_bits(gbc, 2);
331 s->bit_alloc_params.sr_code = hdr.
sr_code;
336 s->bit_alloc_params.sr_shift = hdr.
sr_shift;
340 s->fbw_channels =
s->channels -
s->lfe_on;
341 s->lfe_ch =
s->fbw_channels + 1;
346 s->center_mix_level_ltrt = 4;
348 s->surround_mix_level_ltrt = 4;
349 s->lfe_mix_level_exists = 0;
358 s->start_freq[
s->lfe_ch] = 0;
359 s->end_freq[
s->lfe_ch] = 7;
360 s->num_exp_groups[
s->lfe_ch] = 2;
361 s->channel_in_cpl[
s->lfe_ch] = 0;
364 if (
s->bitstream_id <= 10) {
366 s->snr_offset_strategy = 2;
367 s->block_switch_syntax = 1;
368 s->dither_flag_syntax = 1;
369 s->bit_allocation_syntax = 1;
370 s->fast_gain_syntax = 0;
371 s->first_cpl_leak = 0;
374 memset(
s->channel_uses_aht, 0,
sizeof(
s->channel_uses_aht));
376 }
else if (CONFIG_EAC3_DECODER) {
397 if (!
s->downmix_coeffs[0]) {
399 sizeof(**
s->downmix_coeffs));
400 if (!
s->downmix_coeffs[0])
405 for (
i = 0;
i <
s->fbw_channels;
i++) {
409 if (
s->channel_mode > 1 &&
s->channel_mode & 1) {
410 downmix_coeffs[0][1] = downmix_coeffs[1][1] = cmix;
413 int nf =
s->channel_mode - 2;
414 downmix_coeffs[0][nf] = downmix_coeffs[1][nf] = smix *
LEVEL_MINUS_3DB;
417 int nf =
s->channel_mode - 4;
418 downmix_coeffs[0][nf] = downmix_coeffs[1][nf+1] = smix;
423 for (
i = 0;
i <
s->fbw_channels;
i++) {
424 norm0 += downmix_coeffs[0][
i];
425 norm1 += downmix_coeffs[1][
i];
427 norm0 = 1.0f / norm0;
428 norm1 = 1.0f / norm1;
429 for (
i = 0;
i <
s->fbw_channels;
i++) {
430 downmix_coeffs[0][
i] *= norm0;
431 downmix_coeffs[1][
i] *= norm1;
435 for (
i = 0;
i <
s->fbw_channels;
i++)
436 downmix_coeffs[0][
i] = (downmix_coeffs[0][
i] +
439 for (
i = 0;
i <
s->fbw_channels;
i++) {
440 s->downmix_coeffs[0][
i] =
FIXR12(downmix_coeffs[0][
i]);
441 s->downmix_coeffs[1][
i] =
FIXR12(downmix_coeffs[1][
i]);
453 uint8_t absexp, int8_t *dexps)
455 int i, j, grp, group_size;
460 group_size = exp_strategy + (exp_strategy ==
EXP_D45);
461 for (grp = 0,
i = 0; grp < ngrps; grp++) {
474 for (
i = 0, j = 0;
i < ngrps * 3;
i++) {
475 prevexp += dexp[
i] - 2;
480 switch (group_size) {
481 case 4: dexps[j++] = prevexp;
482 dexps[j++] = prevexp;
483 case 2: dexps[j++] = prevexp;
484 case 1: dexps[j++] = prevexp;
500 for (band = 0; band <
s->num_cpl_bands; band++) {
501 int band_start = bin;
502 int band_end = bin +
s->cpl_band_sizes[band];
503 for (ch = 1; ch <=
s->fbw_channels; ch++) {
504 if (
s->channel_in_cpl[ch]) {
505 int cpl_coord =
s->cpl_coords[ch][band] << 5;
506 for (bin = band_start; bin < band_end; bin++) {
507 s->fixed_coeffs[ch][bin] =
508 MULH(
s->fixed_coeffs[
CPL_CH][bin] * (1 << 4), cpl_coord);
510 if (ch == 2 &&
s->phase_flags[band]) {
511 for (bin = band_start; bin < band_end; bin++)
512 s->fixed_coeffs[2][bin] = -
s->fixed_coeffs[2][bin];
538 int start_freq =
s->start_freq[ch_index];
539 int end_freq =
s->end_freq[ch_index];
540 uint8_t *baps =
s->bap[ch_index];
541 int8_t *exps =
s->dexps[ch_index];
542 int32_t *coeffs =
s->fixed_coeffs[ch_index];
543 int dither = (ch_index ==
CPL_CH) ||
s->dither_flag[ch_index];
547 for (freq = start_freq; freq < end_freq; freq++) {
548 int bap = baps[freq];
554 mantissa = (((
av_lfg_get(&
s->dith_state)>>8)*181)>>8) - 5931008;
608 coeffs[freq] = mantissa >> exps[freq];
620 for (ch = 1; ch <=
s->fbw_channels; ch++) {
621 if (!
s->dither_flag[ch] &&
s->channel_in_cpl[ch]) {
624 s->fixed_coeffs[ch][
i] = 0;
633 if (!
s->channel_uses_aht[ch]) {
639 if (CONFIG_EAC3_DECODER && !
blk)
641 for (bin =
s->start_freq[ch]; bin < s->end_freq[ch]; bin++) {
642 s->fixed_coeffs[ch][bin] =
s->pre_mantissa[ch][bin][
blk] >>
s->dexps[ch][bin];
658 for (ch = 1; ch <=
s->channels; ch++) {
663 if (
s->channel_in_cpl[ch]) {
671 end =
s->end_freq[ch];
674 s->fixed_coeffs[ch][end] = 0;
691 end =
FFMIN(
s->end_freq[1],
s->end_freq[2]);
693 for (bnd = 0; bnd <
s->num_rematrixing_bands; bnd++) {
694 if (
s->rematrixing_flags[bnd]) {
697 int tmp0 =
s->fixed_coeffs[1][
i];
698 s->fixed_coeffs[1][
i] +=
s->fixed_coeffs[2][
i];
699 s->fixed_coeffs[2][
i] = tmp0 -
s->fixed_coeffs[2][
i];
714 for (ch = 1; ch <=
channels; ch++) {
715 if (
s->block_switch[ch]) {
718 for (
i = 0;
i < 128;
i++)
719 x[
i] =
s->transform_coeffs[ch][2 *
i];
720 s->imdct_256.imdct_half(&
s->imdct_256,
s->tmp_output, x);
722 s->fdsp->vector_fmul_window_scaled(
s->outptr[ch - 1],
s->delay[ch - 1 +
offset],
723 s->tmp_output,
s->window, 128, 8);
725 s->fdsp->vector_fmul_window(
s->outptr[ch - 1],
s->delay[ch - 1 +
offset],
726 s->tmp_output,
s->window, 128);
728 for (
i = 0;
i < 128;
i++)
729 x[
i] =
s->transform_coeffs[ch][2 *
i + 1];
730 s->imdct_256.imdct_half(&
s->imdct_256,
s->delay[ch - 1 +
offset], x);
732 s->imdct_512.imdct_half(&
s->imdct_512,
s->tmp_output,
s->transform_coeffs[ch]);
734 s->fdsp->vector_fmul_window_scaled(
s->outptr[ch - 1],
s->delay[ch - 1 +
offset],
735 s->tmp_output,
s->window, 128, 8);
737 s->fdsp->vector_fmul_window(
s->outptr[ch - 1],
s->delay[ch - 1 +
offset],
738 s->tmp_output,
s->window, 128);
750 int channel_data_size =
sizeof(
s->delay[0]);
751 switch (
s->channel_mode) {
755 memcpy(
s->delay[1],
s->delay[0], channel_data_size);
758 memset(
s->delay[3], 0, channel_data_size);
760 memset(
s->delay[2], 0, channel_data_size);
763 memset(
s->delay[4], 0, channel_data_size);
765 memset(
s->delay[3], 0, channel_data_size);
767 memcpy(
s->delay[2],
s->delay[1], channel_data_size);
768 memset(
s->delay[1], 0, channel_data_size);
791 int ecpl,
int start_subband,
int end_subband,
792 const uint8_t *default_band_struct,
793 int *num_bands, uint8_t *band_sizes,
794 uint8_t *band_struct,
int band_struct_size)
796 int subbnd, bnd, n_subbands, n_bands=0;
799 n_subbands = end_subband - start_subband;
802 memcpy(band_struct, default_band_struct, band_struct_size);
804 av_assert0(band_struct_size >= start_subband + n_subbands);
806 band_struct += start_subband + 1;
810 for (subbnd = 0; subbnd < n_subbands - 1; subbnd++) {
818 if (num_bands || band_sizes ) {
819 n_bands = n_subbands;
820 bnd_sz[0] = ecpl ? 6 : 12;
821 for (bnd = 0, subbnd = 1; subbnd < n_subbands; subbnd++) {
822 int subbnd_size = (ecpl && subbnd < 4) ? 6 : 12;
823 if (band_struct[subbnd - 1]) {
825 bnd_sz[bnd] += subbnd_size;
827 bnd_sz[++bnd] = subbnd_size;
834 *num_bands = n_bands;
836 memcpy(band_sizes, bnd_sz, n_bands);
842 int fbw_channels =
s->fbw_channels;
843 int dst_start_freq, dst_end_freq, src_start_freq,
844 start_subband, end_subband, ch;
848 s->channel_uses_spx[1] = 1;
850 for (ch = 1; ch <= fbw_channels; ch++)
857 start_subband =
get_bits(bc, 3) + 2;
858 if (start_subband > 7)
859 start_subband += start_subband - 7;
865 end_subband += end_subband - 7;
866 dst_start_freq = dst_start_freq * 12 + 25;
867 src_start_freq = start_subband * 12 + 25;
868 dst_end_freq = end_subband * 12 + 25;
871 if (start_subband >= end_subband) {
873 "range (%d >= %d)\n", start_subband, end_subband);
876 if (dst_start_freq >= src_start_freq) {
878 "copy start bin (%d >= %d)\n", dst_start_freq, src_start_freq);
882 s->spx_dst_start_freq = dst_start_freq;
883 s->spx_src_start_freq = src_start_freq;
885 s->spx_dst_end_freq = dst_end_freq;
888 start_subband, end_subband,
892 s->spx_band_struct,
sizeof(
s->spx_band_struct));
899 int fbw_channels =
s->fbw_channels;
902 for (ch = 1; ch <= fbw_channels; ch++) {
903 if (
s->channel_uses_spx[ch]) {
904 if (
s->first_spx_coords[ch] ||
get_bits1(bc)) {
906 int bin, master_spx_coord;
908 s->first_spx_coords[ch] = 0;
910 master_spx_coord =
get_bits(bc, 2) * 3;
912 bin =
s->spx_src_start_freq;
913 for (bnd = 0; bnd <
s->num_spx_bands; bnd++) {
914 int bandsize =
s->spx_band_sizes[bnd];
915 int spx_coord_exp, spx_coord_mant;
919 int64_t accu = ((bin << 23) + (bandsize << 22))
920 * (int64_t)
s->spx_dst_end_freq;
921 nratio = (
int)(accu >> 32);
922 nratio -= spx_blend << 18;
927 }
else if (nratio > 0x7fffff) {
932 accu = (int64_t)nblend * 1859775393;
933 nblend = (
int)((accu + (1<<29)) >> 30);
940 nratio = ((
float)((bin + (bandsize >> 1))) /
s->spx_dst_end_freq) - spx_blend;
942 nblend =
sqrtf(3.0
f * nratio);
944 sblend =
sqrtf(1.0
f - nratio);
951 if (spx_coord_exp == 15) spx_coord_mant <<= 1;
952 else spx_coord_mant += 4;
953 spx_coord_mant <<= (25 - spx_coord_exp - master_spx_coord);
957 accu = (int64_t)nblend * spx_coord_mant;
958 s->spx_noise_blend[ch][bnd] = (
int)((accu + (1<<22)) >> 23);
959 accu = (int64_t)sblend * spx_coord_mant;
960 s->spx_signal_blend[ch][bnd] = (
int)((accu + (1<<22)) >> 23);
962 spx_coord = spx_coord_mant * (1.0f / (1 << 23));
963 s->spx_noise_blend [ch][bnd] = nblend * spx_coord;
964 s->spx_signal_blend[ch][bnd] = sblend * spx_coord;
969 s->first_spx_coords[ch] = 1;
975 uint8_t *bit_alloc_stages)
978 int fbw_channels =
s->fbw_channels;
979 int channel_mode =
s->channel_mode;
985 if (
s->cpl_in_use[
blk]) {
987 int cpl_start_subband, cpl_end_subband;
1003 s->channel_in_cpl[1] = 1;
1004 s->channel_in_cpl[2] = 1;
1006 for (ch = 1; ch <= fbw_channels; ch++)
1015 cpl_start_subband =
get_bits(bc, 4);
1016 cpl_end_subband =
s->spx_in_use ? (
s->spx_src_start_freq - 37) / 12 :
1018 if (cpl_start_subband >= cpl_end_subband) {
1020 cpl_start_subband, cpl_end_subband);
1023 s->start_freq[
CPL_CH] = cpl_start_subband * 12 + 37;
1024 s->end_freq[
CPL_CH] = cpl_end_subband * 12 + 37;
1029 &
s->num_cpl_bands,
s->cpl_band_sizes,
1030 s->cpl_band_struct,
sizeof(
s->cpl_band_struct));
1033 for (ch = 1; ch <= fbw_channels; ch++) {
1034 s->channel_in_cpl[ch] = 0;
1035 s->first_cpl_coords[ch] = 1;
1037 s->first_cpl_leak =
s->eac3;
1038 s->phase_flags_in_use = 0;
1047 int fbw_channels =
s->fbw_channels;
1049 int cpl_coords_exist = 0;
1051 for (ch = 1; ch <= fbw_channels; ch++) {
1052 if (
s->channel_in_cpl[ch]) {
1053 if ((
s->eac3 &&
s->first_cpl_coords[ch]) ||
get_bits1(bc)) {
1054 int master_cpl_coord, cpl_coord_exp, cpl_coord_mant;
1055 s->first_cpl_coords[ch] = 0;
1056 cpl_coords_exist = 1;
1057 master_cpl_coord = 3 *
get_bits(bc, 2);
1058 for (bnd = 0; bnd <
s->num_cpl_bands; bnd++) {
1061 if (cpl_coord_exp == 15)
1062 s->cpl_coords[ch][bnd] = cpl_coord_mant << 22;
1064 s->cpl_coords[ch][bnd] = (cpl_coord_mant + 16) << 21;
1065 s->cpl_coords[ch][bnd] >>= (cpl_coord_exp + master_cpl_coord);
1069 "be present in block 0\n");
1074 s->first_cpl_coords[ch] = 1;
1079 for (bnd = 0; bnd <
s->num_cpl_bands; bnd++) {
1080 s->phase_flags[bnd] =
s->phase_flags_in_use ?
get_bits1(bc) : 0;
1092 int fbw_channels =
s->fbw_channels;
1093 int channel_mode =
s->channel_mode;
1094 int i, bnd, seg, ch,
ret;
1095 int different_transforms;
1102 different_transforms = 0;
1103 if (
s->block_switch_syntax) {
1104 for (ch = 1; ch <= fbw_channels; ch++) {
1106 if (ch > 1 &&
s->block_switch[ch] !=
s->block_switch[1])
1107 different_transforms = 1;
1112 if (
s->dither_flag_syntax) {
1113 for (ch = 1; ch <= fbw_channels; ch++) {
1119 i = !
s->channel_mode;
1126 if (range_bits <= 127 || s->drc_scale <= 1.0)
1129 s->dynamic_range[
i] = range;
1130 }
else if (
blk == 0) {
1138 if (
s->spx_in_use) {
1143 if (!
s->eac3 || !
s->spx_in_use) {
1145 for (ch = 1; ch <= fbw_channels; ch++) {
1146 s->channel_uses_spx[ch] = 0;
1147 s->first_spx_coords[ch] = 1;
1159 }
else if (!
s->eac3) {
1162 "be present in block 0\n");
1165 s->cpl_in_use[
blk] =
s->cpl_in_use[
blk-1];
1168 cpl_in_use =
s->cpl_in_use[
blk];
1179 s->num_rematrixing_bands = 4;
1180 if (cpl_in_use &&
s->start_freq[
CPL_CH] <= 61) {
1181 s->num_rematrixing_bands -= 1 + (
s->start_freq[
CPL_CH] == 37);
1182 }
else if (
s->spx_in_use &&
s->spx_src_start_freq <= 61) {
1183 s->num_rematrixing_bands--;
1185 for (bnd = 0; bnd <
s->num_rematrixing_bands; bnd++)
1189 "new rematrixing strategy not present in block 0\n");
1190 s->num_rematrixing_bands = 0;
1195 for (ch = !cpl_in_use; ch <=
s->channels; ch++) {
1197 s->exp_strategy[
blk][ch] =
get_bits(gbc, 2 - (ch ==
s->lfe_ch));
1199 bit_alloc_stages[ch] = 3;
1203 for (ch = 1; ch <= fbw_channels; ch++) {
1204 s->start_freq[ch] = 0;
1207 int prev =
s->end_freq[ch];
1208 if (
s->channel_in_cpl[ch])
1209 s->end_freq[ch] =
s->start_freq[
CPL_CH];
1210 else if (
s->channel_uses_spx[ch])
1211 s->end_freq[ch] =
s->spx_src_start_freq;
1213 int bandwidth_code =
get_bits(gbc, 6);
1214 if (bandwidth_code > 60) {
1218 s->end_freq[ch] = bandwidth_code * 3 + 73;
1220 group_size = 3 << (
s->exp_strategy[
blk][ch] - 1);
1221 s->num_exp_groups[ch] = (
s->end_freq[ch] + group_size-4) / group_size;
1222 if (
blk > 0 &&
s->end_freq[ch] != prev)
1232 for (ch = !cpl_in_use; ch <=
s->channels; ch++) {
1234 s->dexps[ch][0] =
get_bits(gbc, 4) << !ch;
1236 s->num_exp_groups[ch],
s->dexps[ch][0],
1237 &
s->dexps[ch][
s->start_freq[ch]+!!ch])) {
1240 if (ch !=
CPL_CH && ch !=
s->lfe_ch)
1246 if (
s->bit_allocation_syntax) {
1253 for (ch = !cpl_in_use; ch <=
s->channels; ch++)
1254 bit_alloc_stages[ch] =
FFMAX(bit_alloc_stages[ch], 2);
1257 "be present in block 0\n");
1263 if (!
s->eac3 || !
blk) {
1264 if (
s->snr_offset_strategy &&
get_bits1(gbc)) {
1267 csnr = (
get_bits(gbc, 6) - 15) << 4;
1268 for (
i = ch = !cpl_in_use; ch <=
s->channels; ch++) {
1270 if (ch ==
i ||
s->snr_offset_strategy == 2)
1271 snr = (csnr +
get_bits(gbc, 4)) << 2;
1273 if (
blk &&
s->snr_offset[ch] != snr) {
1274 bit_alloc_stages[ch] =
FFMAX(bit_alloc_stages[ch], 1);
1276 s->snr_offset[ch] = snr;
1280 int prev =
s->fast_gain[ch];
1283 if (
blk && prev !=
s->fast_gain[ch])
1284 bit_alloc_stages[ch] =
FFMAX(bit_alloc_stages[ch], 2);
1287 }
else if (!
s->eac3 && !
blk) {
1295 for (ch = !cpl_in_use; ch <=
s->channels; ch++) {
1296 int prev =
s->fast_gain[ch];
1299 if (
blk && prev !=
s->fast_gain[ch])
1300 bit_alloc_stages[ch] =
FFMAX(bit_alloc_stages[ch], 2);
1302 }
else if (
s->eac3 && !
blk) {
1303 for (ch = !cpl_in_use; ch <=
s->channels; ch++)
1319 if (
blk && (fl !=
s->bit_alloc_params.cpl_fast_leak ||
1320 sl !=
s->bit_alloc_params.cpl_slow_leak)) {
1323 s->bit_alloc_params.cpl_fast_leak = fl;
1324 s->bit_alloc_params.cpl_slow_leak = sl;
1325 }
else if (!
s->eac3 && !
blk) {
1327 "be present in block 0\n");
1330 s->first_cpl_leak = 0;
1336 for (ch = !cpl_in_use; ch <= fbw_channels; ch++) {
1342 bit_alloc_stages[ch] =
FFMAX(bit_alloc_stages[ch], 2);
1345 for (ch = !cpl_in_use; ch <= fbw_channels; ch++) {
1347 s->dba_nsegs[ch] =
get_bits(gbc, 3) + 1;
1348 for (seg = 0; seg <
s->dba_nsegs[ch]; seg++) {
1349 s->dba_offsets[ch][seg] =
get_bits(gbc, 5);
1350 s->dba_lengths[ch][seg] =
get_bits(gbc, 4);
1351 s->dba_values[ch][seg] =
get_bits(gbc, 3);
1354 bit_alloc_stages[ch] =
FFMAX(bit_alloc_stages[ch], 2);
1357 }
else if (
blk == 0) {
1358 for (ch = 0; ch <=
s->channels; ch++) {
1364 for (ch = !cpl_in_use; ch <=
s->channels; ch++) {
1365 if (bit_alloc_stages[ch] > 2) {
1368 s->start_freq[ch],
s->end_freq[ch],
1369 s->psd[ch],
s->band_psd[ch]);
1371 if (bit_alloc_stages[ch] > 1) {
1375 s->start_freq[ch],
s->end_freq[ch],
1376 s->fast_gain[ch], (ch ==
s->lfe_ch),
1377 s->dba_mode[ch],
s->dba_nsegs[ch],
1378 s->dba_offsets[ch],
s->dba_lengths[ch],
1379 s->dba_values[ch],
s->mask[ch])) {
1384 if (bit_alloc_stages[ch] > 0) {
1386 const uint8_t *
bap_tab =
s->channel_uses_aht[ch] ?
1388 s->ac3dsp.bit_alloc_calc_bap(
s->mask[ch],
s->psd[ch],
1389 s->start_freq[ch],
s->end_freq[ch],
1391 s->bit_alloc_params.floor,
1413 for (ch = 1; ch <=
s->channels; ch++) {
1414 int audio_channel = 0;
1417 audio_channel = 2-ch;
1418 if (
s->heavy_compression &&
s->compression_exists[audio_channel])
1419 gain =
s->heavy_dynamic_range[audio_channel];
1421 gain =
s->dynamic_range[audio_channel];
1424 scale_coefs(
s->transform_coeffs[ch],
s->fixed_coeffs[ch], gain, 256);
1426 if (
s->target_level != 0)
1427 gain = gain *
s->level_gain[audio_channel];
1428 gain *= 1.0 / 4194304.0f;
1429 s->fmt_conv.int32_to_float_fmul_scalar(
s->transform_coeffs[ch],
1430 s->fixed_coeffs[ch], gain, 256);
1435 if (CONFIG_EAC3_DECODER &&
s->spx_in_use) {
1442 downmix_output =
s->channels !=
s->out_channels &&
1443 !((
s->output_mode & AC3_OUTPUT_LFEON) &&
1444 s->fbw_channels ==
s->out_channels);
1445 if (different_transforms) {
1455 if (downmix_output) {
1458 s->out_channels,
s->fbw_channels, 256);
1461 s->out_channels,
s->fbw_channels, 256);
1465 if (downmix_output) {
1467 s->out_channels,
s->fbw_channels, 256);
1470 if (downmix_output && !
s->downmixed) {
1473 s->out_channels,
s->fbw_channels, 128);
1486 int *got_frame_ptr,
AVPacket *avpkt)
1488 const uint8_t *buf = avpkt->
data;
1489 int buf_size, full_buf_size = avpkt->
size;
1493 int skip = 0, got_independent_frame = 0;
1494 const uint8_t *channel_map;
1501 s->superframe_size = 0;
1503 buf_size = full_buf_size;
1504 for (
i = 1;
i < buf_size;
i += 2) {
1505 if (buf[
i] == 0x77 || buf[
i] == 0x0B) {
1506 if ((buf[
i] ^ buf[
i-1]) == (0x77 ^ 0x0B)) {
1509 }
else if ((buf[
i] ^ buf[
i+1]) == (0x77 ^ 0x0B)) {
1523 if (buf_size >= 2 &&
AV_RB16(buf) == 0x770B) {
1525 int cnt =
FFMIN(buf_size, AC3_FRAME_BUFFER_SIZE) >> 1;
1526 s->bdsp.bswap16_buf((uint16_t *)
s->input_buffer,
1527 (
const uint16_t *) buf, cnt);
1529 memcpy(
s->input_buffer, buf,
FFMIN(buf_size, AC3_FRAME_BUFFER_SIZE));
1534 if (
s->consistent_noise_generation)
1537 buf =
s->input_buffer;
1563 if (
s->substreamid) {
1565 "unsupported substream %d: skipping frame\n",
1582 if (
s->frame_size > buf_size) {
1588 s->frame_size - 2)) {
1600 return FFMIN(full_buf_size,
s->frame_size);
1604 if (!err || (
s->channels &&
s->out_channels !=
s->channels)) {
1605 s->out_channels =
s->channels;
1606 s->output_mode =
s->channel_mode;
1608 s->output_mode |= AC3_OUTPUT_LFEON;
1609 if (
s->channels > 1 &&
1611 s->out_channels = 1;
1613 }
else if (
s->channels > 2 &&
1615 s->out_channels = 2;
1619 s->loro_center_mix_level =
gain_levels[
s-> center_mix_level];
1620 s->loro_surround_mix_level =
gain_levels[
s->surround_mix_level];
1624 if (
s->channels !=
s->out_channels && !((
s->output_mode & AC3_OUTPUT_LFEON) &&
1625 s->fbw_channels ==
s->out_channels)) {
1631 }
else if (!
s->channels) {
1637 if (
s->output_mode & AC3_OUTPUT_LFEON)
1645 if (
s->bitstream_mode == 0x7 &&
s->channels > 1)
1653 s->outptr[ch] =
s->output[ch +
offset];
1655 for (ch = 0; ch <
s->channels; ch++) {
1656 if (ch < s->out_channels)
1657 s->outptr[channel_map[ch]] =
s->output_buffer[ch +
offset];
1665 for (ch = 0; ch <
s->out_channels; ch++)
1667 for (ch = 0; ch <
s->out_channels; ch++)
1668 output[ch] =
s->outptr[channel_map[ch]];
1669 for (ch = 0; ch <
s->out_channels; ch++) {
1670 if (!ch || channel_map[ch])
1676 for (ch = 0; ch <
s->out_channels; ch++)
1680 if (buf_size >
s->frame_size) {
1684 if (buf_size -
s->frame_size <= 16) {
1685 skip = buf_size -
s->frame_size;
1700 buf +=
s->frame_size;
1701 buf_size -=
s->frame_size;
1702 s->prev_output_mode =
s->output_mode;
1703 s->prev_bit_rate =
s->bit_rate;
1704 got_independent_frame = 1;
1705 goto dependent_frame;
1716 avctx->
bit_rate =
s->bit_rate +
s->prev_bit_rate;
1720 extended_channel_map[ch] = ch;
1725 uint64_t channel_layout;
1728 if (
s->prev_output_mode & AC3_OUTPUT_LFEON)
1731 channel_layout = ich_layout;
1732 for (ch = 0; ch < 16; ch++) {
1753 if (extend >= channel_map_size)
1756 extended_channel_map[
index] =
offset + channel_map[extend++];
1760 for (
i = 0;
i < 64;
i++) {
1765 if (extend >= channel_map_size)
1768 extended_channel_map[
index] =
offset + channel_map[extend++];
1782 int map = extended_channel_map[ch];
1785 s->output_buffer[
map],
1797 s->channel_mode == (
s->output_mode & ~AC3_OUTPUT_LFEON)) {
1803 s->channel_mode == (
s->output_mode & ~AC3_OUTPUT_LFEON)) {
1804 switch (
s->dolby_surround_ex_mode) {
1820 switch (
s->preferred_downmix) {
1838 if (
s->lfe_mix_level_exists)
1847 if (!
s->superframe_size)
1848 return FFMIN(full_buf_size,
s->frame_size + skip);
1850 return FFMIN(full_buf_size,
s->superframe_size + skip);
1867 #define OFFSET(x) offsetof(AC3DecodeContext, x)
1868 #define PAR (AV_OPT_FLAG_DECODING_PARAM | AV_OPT_FLAG_AUDIO_PARAM)