annotate ffmpeg/libavcodec/eac3dec.c @ 13:844d341cf643 tip

Back up before ISMIR
author Yading Song <yading.song@eecs.qmul.ac.uk>
date Thu, 31 Oct 2013 13:17:06 +0000
parents 6840f77b83aa
children
rev   line source
yading@10 1 /*
yading@10 2 * E-AC-3 decoder
yading@10 3 * Copyright (c) 2007 Bartlomiej Wolowiec <bartek.wolowiec@gmail.com>
yading@10 4 * Copyright (c) 2008 Justin Ruggles
yading@10 5 *
yading@10 6 * This file is part of FFmpeg.
yading@10 7 *
yading@10 8 * FFmpeg is free software; you can redistribute it and/or
yading@10 9 * modify it under the terms of the GNU Lesser General Public
yading@10 10 * License as published by the Free Software Foundation; either
yading@10 11 * version 2.1 of the License, or (at your option) any later version.
yading@10 12 *
yading@10 13 * FFmpeg is distributed in the hope that it will be useful,
yading@10 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
yading@10 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
yading@10 16 * Lesser General Public License for more details.
yading@10 17 *
yading@10 18 * You should have received a copy of the GNU Lesser General Public
yading@10 19 * License along with FFmpeg; if not, write to the Free Software
yading@10 20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
yading@10 21 */
yading@10 22
yading@10 23 /*
yading@10 24 * There are several features of E-AC-3 that this decoder does not yet support.
yading@10 25 *
yading@10 26 * Enhanced Coupling
yading@10 27 * No known samples exist. If any ever surface, this feature should not be
yading@10 28 * too difficult to implement.
yading@10 29 *
yading@10 30 * Reduced Sample Rates
yading@10 31 * No known samples exist. The spec also does not give clear information
yading@10 32 * on how this is to be implemented.
yading@10 33 *
yading@10 34 * Dependent Streams
yading@10 35 * Only the independent stream is currently decoded. Any dependent
yading@10 36 * streams are skipped. We have only come across two examples of this, and
yading@10 37 * they are both just test streams, one for HD-DVD and the other for
yading@10 38 * Blu-ray.
yading@10 39 *
yading@10 40 * Transient Pre-noise Processing
yading@10 41 * This is side information which a decoder should use to reduce artifacts
yading@10 42 * caused by transients. There are samples which are known to have this
yading@10 43 * information, but this decoder currently ignores it.
yading@10 44 */
yading@10 45
yading@10 46
yading@10 47 #include "avcodec.h"
yading@10 48 #include "internal.h"
yading@10 49 #include "aac_ac3_parser.h"
yading@10 50 #include "ac3.h"
yading@10 51 #include "ac3_parser.h"
yading@10 52 #include "ac3dec.h"
yading@10 53 #include "ac3dec_data.h"
yading@10 54 #include "eac3_data.h"
yading@10 55
yading@10 56 /** gain adaptive quantization mode */
yading@10 57 typedef enum {
yading@10 58 EAC3_GAQ_NO =0,
yading@10 59 EAC3_GAQ_12,
yading@10 60 EAC3_GAQ_14,
yading@10 61 EAC3_GAQ_124
yading@10 62 } EAC3GaqMode;
yading@10 63
yading@10 64 #define EAC3_SR_CODE_REDUCED 3
yading@10 65
yading@10 66 void ff_eac3_apply_spectral_extension(AC3DecodeContext *s)
yading@10 67 {
yading@10 68 int bin, bnd, ch, i;
yading@10 69 uint8_t wrapflag[SPX_MAX_BANDS]={1,0,}, num_copy_sections, copy_sizes[SPX_MAX_BANDS];
yading@10 70 float rms_energy[SPX_MAX_BANDS];
yading@10 71
yading@10 72 /* Set copy index mapping table. Set wrap flags to apply a notch filter at
yading@10 73 wrap points later on. */
yading@10 74 bin = s->spx_dst_start_freq;
yading@10 75 num_copy_sections = 0;
yading@10 76 for (bnd = 0; bnd < s->num_spx_bands; bnd++) {
yading@10 77 int copysize;
yading@10 78 int bandsize = s->spx_band_sizes[bnd];
yading@10 79 if (bin + bandsize > s->spx_src_start_freq) {
yading@10 80 copy_sizes[num_copy_sections++] = bin - s->spx_dst_start_freq;
yading@10 81 bin = s->spx_dst_start_freq;
yading@10 82 wrapflag[bnd] = 1;
yading@10 83 }
yading@10 84 for (i = 0; i < bandsize; i += copysize) {
yading@10 85 if (bin == s->spx_src_start_freq) {
yading@10 86 copy_sizes[num_copy_sections++] = bin - s->spx_dst_start_freq;
yading@10 87 bin = s->spx_dst_start_freq;
yading@10 88 }
yading@10 89 copysize = FFMIN(bandsize - i, s->spx_src_start_freq - bin);
yading@10 90 bin += copysize;
yading@10 91 }
yading@10 92 }
yading@10 93 copy_sizes[num_copy_sections++] = bin - s->spx_dst_start_freq;
yading@10 94
yading@10 95 for (ch = 1; ch <= s->fbw_channels; ch++) {
yading@10 96 if (!s->channel_uses_spx[ch])
yading@10 97 continue;
yading@10 98
yading@10 99 /* Copy coeffs from normal bands to extension bands */
yading@10 100 bin = s->spx_src_start_freq;
yading@10 101 for (i = 0; i < num_copy_sections; i++) {
yading@10 102 memcpy(&s->transform_coeffs[ch][bin],
yading@10 103 &s->transform_coeffs[ch][s->spx_dst_start_freq],
yading@10 104 copy_sizes[i]*sizeof(float));
yading@10 105 bin += copy_sizes[i];
yading@10 106 }
yading@10 107
yading@10 108 /* Calculate RMS energy for each SPX band. */
yading@10 109 bin = s->spx_src_start_freq;
yading@10 110 for (bnd = 0; bnd < s->num_spx_bands; bnd++) {
yading@10 111 int bandsize = s->spx_band_sizes[bnd];
yading@10 112 float accum = 0.0f;
yading@10 113 for (i = 0; i < bandsize; i++) {
yading@10 114 float coeff = s->transform_coeffs[ch][bin++];
yading@10 115 accum += coeff * coeff;
yading@10 116 }
yading@10 117 rms_energy[bnd] = sqrtf(accum / bandsize);
yading@10 118 }
yading@10 119
yading@10 120 /* Apply a notch filter at transitions between normal and extension
yading@10 121 bands and at all wrap points. */
yading@10 122 if (s->spx_atten_code[ch] >= 0) {
yading@10 123 const float *atten_tab = ff_eac3_spx_atten_tab[s->spx_atten_code[ch]];
yading@10 124 bin = s->spx_src_start_freq - 2;
yading@10 125 for (bnd = 0; bnd < s->num_spx_bands; bnd++) {
yading@10 126 if (wrapflag[bnd]) {
yading@10 127 float *coeffs = &s->transform_coeffs[ch][bin];
yading@10 128 coeffs[0] *= atten_tab[0];
yading@10 129 coeffs[1] *= atten_tab[1];
yading@10 130 coeffs[2] *= atten_tab[2];
yading@10 131 coeffs[3] *= atten_tab[1];
yading@10 132 coeffs[4] *= atten_tab[0];
yading@10 133 }
yading@10 134 bin += s->spx_band_sizes[bnd];
yading@10 135 }
yading@10 136 }
yading@10 137
yading@10 138 /* Apply noise-blended coefficient scaling based on previously
yading@10 139 calculated RMS energy, blending factors, and SPX coordinates for
yading@10 140 each band. */
yading@10 141 bin = s->spx_src_start_freq;
yading@10 142 for (bnd = 0; bnd < s->num_spx_bands; bnd++) {
yading@10 143 float nscale = s->spx_noise_blend[ch][bnd] * rms_energy[bnd] * (1.0f / INT32_MIN);
yading@10 144 float sscale = s->spx_signal_blend[ch][bnd];
yading@10 145 for (i = 0; i < s->spx_band_sizes[bnd]; i++) {
yading@10 146 float noise = nscale * (int32_t)av_lfg_get(&s->dith_state);
yading@10 147 s->transform_coeffs[ch][bin] *= sscale;
yading@10 148 s->transform_coeffs[ch][bin++] += noise;
yading@10 149 }
yading@10 150 }
yading@10 151 }
yading@10 152 }
yading@10 153
yading@10 154
yading@10 155 /** lrint(M_SQRT2*cos(2*M_PI/12)*(1<<23)) */
yading@10 156 #define COEFF_0 10273905LL
yading@10 157
yading@10 158 /** lrint(M_SQRT2*cos(0*M_PI/12)*(1<<23)) = lrint(M_SQRT2*(1<<23)) */
yading@10 159 #define COEFF_1 11863283LL
yading@10 160
yading@10 161 /** lrint(M_SQRT2*cos(5*M_PI/12)*(1<<23)) */
yading@10 162 #define COEFF_2 3070444LL
yading@10 163
yading@10 164 /**
yading@10 165 * Calculate 6-point IDCT of the pre-mantissas.
yading@10 166 * All calculations are 24-bit fixed-point.
yading@10 167 */
yading@10 168 static void idct6(int pre_mant[6])
yading@10 169 {
yading@10 170 int tmp;
yading@10 171 int even0, even1, even2, odd0, odd1, odd2;
yading@10 172
yading@10 173 odd1 = pre_mant[1] - pre_mant[3] - pre_mant[5];
yading@10 174
yading@10 175 even2 = ( pre_mant[2] * COEFF_0) >> 23;
yading@10 176 tmp = ( pre_mant[4] * COEFF_1) >> 23;
yading@10 177 odd0 = ((pre_mant[1] + pre_mant[5]) * COEFF_2) >> 23;
yading@10 178
yading@10 179 even0 = pre_mant[0] + (tmp >> 1);
yading@10 180 even1 = pre_mant[0] - tmp;
yading@10 181
yading@10 182 tmp = even0;
yading@10 183 even0 = tmp + even2;
yading@10 184 even2 = tmp - even2;
yading@10 185
yading@10 186 tmp = odd0;
yading@10 187 odd0 = tmp + pre_mant[1] + pre_mant[3];
yading@10 188 odd2 = tmp + pre_mant[5] - pre_mant[3];
yading@10 189
yading@10 190 pre_mant[0] = even0 + odd0;
yading@10 191 pre_mant[1] = even1 + odd1;
yading@10 192 pre_mant[2] = even2 + odd2;
yading@10 193 pre_mant[3] = even2 - odd2;
yading@10 194 pre_mant[4] = even1 - odd1;
yading@10 195 pre_mant[5] = even0 - odd0;
yading@10 196 }
yading@10 197
yading@10 198 void ff_eac3_decode_transform_coeffs_aht_ch(AC3DecodeContext *s, int ch)
yading@10 199 {
yading@10 200 int bin, blk, gs;
yading@10 201 int end_bap, gaq_mode;
yading@10 202 GetBitContext *gbc = &s->gbc;
yading@10 203 int gaq_gain[AC3_MAX_COEFS];
yading@10 204
yading@10 205 gaq_mode = get_bits(gbc, 2);
yading@10 206 end_bap = (gaq_mode < 2) ? 12 : 17;
yading@10 207
yading@10 208 /* if GAQ gain is used, decode gain codes for bins with hebap between
yading@10 209 8 and end_bap */
yading@10 210 gs = 0;
yading@10 211 if (gaq_mode == EAC3_GAQ_12 || gaq_mode == EAC3_GAQ_14) {
yading@10 212 /* read 1-bit GAQ gain codes */
yading@10 213 for (bin = s->start_freq[ch]; bin < s->end_freq[ch]; bin++) {
yading@10 214 if (s->bap[ch][bin] > 7 && s->bap[ch][bin] < end_bap)
yading@10 215 gaq_gain[gs++] = get_bits1(gbc) << (gaq_mode-1);
yading@10 216 }
yading@10 217 } else if (gaq_mode == EAC3_GAQ_124) {
yading@10 218 /* read 1.67-bit GAQ gain codes (3 codes in 5 bits) */
yading@10 219 int gc = 2;
yading@10 220 for (bin = s->start_freq[ch]; bin < s->end_freq[ch]; bin++) {
yading@10 221 if (s->bap[ch][bin] > 7 && s->bap[ch][bin] < 17) {
yading@10 222 if (gc++ == 2) {
yading@10 223 int group_code = get_bits(gbc, 5);
yading@10 224 if (group_code > 26) {
yading@10 225 av_log(s->avctx, AV_LOG_WARNING, "GAQ gain group code out-of-range\n");
yading@10 226 group_code = 26;
yading@10 227 }
yading@10 228 gaq_gain[gs++] = ff_ac3_ungroup_3_in_5_bits_tab[group_code][0];
yading@10 229 gaq_gain[gs++] = ff_ac3_ungroup_3_in_5_bits_tab[group_code][1];
yading@10 230 gaq_gain[gs++] = ff_ac3_ungroup_3_in_5_bits_tab[group_code][2];
yading@10 231 gc = 0;
yading@10 232 }
yading@10 233 }
yading@10 234 }
yading@10 235 }
yading@10 236
yading@10 237 gs=0;
yading@10 238 for (bin = s->start_freq[ch]; bin < s->end_freq[ch]; bin++) {
yading@10 239 int hebap = s->bap[ch][bin];
yading@10 240 int bits = ff_eac3_bits_vs_hebap[hebap];
yading@10 241 if (!hebap) {
yading@10 242 /* zero-mantissa dithering */
yading@10 243 for (blk = 0; blk < 6; blk++) {
yading@10 244 s->pre_mantissa[ch][bin][blk] = (av_lfg_get(&s->dith_state) & 0x7FFFFF) - 0x400000;
yading@10 245 }
yading@10 246 } else if (hebap < 8) {
yading@10 247 /* Vector Quantization */
yading@10 248 int v = get_bits(gbc, bits);
yading@10 249 for (blk = 0; blk < 6; blk++) {
yading@10 250 s->pre_mantissa[ch][bin][blk] = ff_eac3_mantissa_vq[hebap][v][blk] << 8;
yading@10 251 }
yading@10 252 } else {
yading@10 253 /* Gain Adaptive Quantization */
yading@10 254 int gbits, log_gain;
yading@10 255 if (gaq_mode != EAC3_GAQ_NO && hebap < end_bap) {
yading@10 256 log_gain = gaq_gain[gs++];
yading@10 257 } else {
yading@10 258 log_gain = 0;
yading@10 259 }
yading@10 260 gbits = bits - log_gain;
yading@10 261
yading@10 262 for (blk = 0; blk < 6; blk++) {
yading@10 263 int mant = get_sbits(gbc, gbits);
yading@10 264 if (log_gain && mant == -(1 << (gbits-1))) {
yading@10 265 /* large mantissa */
yading@10 266 int b;
yading@10 267 int mbits = bits - (2 - log_gain);
yading@10 268 mant = get_sbits(gbc, mbits);
yading@10 269 mant <<= (23 - (mbits - 1));
yading@10 270 /* remap mantissa value to correct for asymmetric quantization */
yading@10 271 if (mant >= 0)
yading@10 272 b = 1 << (23 - log_gain);
yading@10 273 else
yading@10 274 b = ff_eac3_gaq_remap_2_4_b[hebap-8][log_gain-1] << 8;
yading@10 275 mant += ((ff_eac3_gaq_remap_2_4_a[hebap-8][log_gain-1] * (int64_t)mant) >> 15) + b;
yading@10 276 } else {
yading@10 277 /* small mantissa, no GAQ, or Gk=1 */
yading@10 278 mant <<= 24 - bits;
yading@10 279 if (!log_gain) {
yading@10 280 /* remap mantissa value for no GAQ or Gk=1 */
yading@10 281 mant += (ff_eac3_gaq_remap_1[hebap-8] * (int64_t)mant) >> 15;
yading@10 282 }
yading@10 283 }
yading@10 284 s->pre_mantissa[ch][bin][blk] = mant;
yading@10 285 }
yading@10 286 }
yading@10 287 idct6(s->pre_mantissa[ch][bin]);
yading@10 288 }
yading@10 289 }
yading@10 290
yading@10 291 int ff_eac3_parse_header(AC3DecodeContext *s)
yading@10 292 {
yading@10 293 int i, blk, ch;
yading@10 294 int ac3_exponent_strategy, parse_aht_info, parse_spx_atten_data;
yading@10 295 int parse_transient_proc_info;
yading@10 296 int num_cpl_blocks;
yading@10 297 GetBitContext *gbc = &s->gbc;
yading@10 298
yading@10 299 /* An E-AC-3 stream can have multiple independent streams which the
yading@10 300 application can select from. each independent stream can also contain
yading@10 301 dependent streams which are used to add or replace channels. */
yading@10 302 if (s->frame_type == EAC3_FRAME_TYPE_DEPENDENT) {
yading@10 303 avpriv_request_sample(s->avctx, "Dependent substream decoding");
yading@10 304 return AAC_AC3_PARSE_ERROR_FRAME_TYPE;
yading@10 305 } else if (s->frame_type == EAC3_FRAME_TYPE_RESERVED) {
yading@10 306 av_log(s->avctx, AV_LOG_ERROR, "Reserved frame type\n");
yading@10 307 return AAC_AC3_PARSE_ERROR_FRAME_TYPE;
yading@10 308 }
yading@10 309
yading@10 310 /* The substream id indicates which substream this frame belongs to. each
yading@10 311 independent stream has its own substream id, and the dependent streams
yading@10 312 associated to an independent stream have matching substream id's. */
yading@10 313 if (s->substreamid) {
yading@10 314 /* only decode substream with id=0. skip any additional substreams. */
yading@10 315 avpriv_request_sample(s->avctx, "Additional substreams");
yading@10 316 return AAC_AC3_PARSE_ERROR_FRAME_TYPE;
yading@10 317 }
yading@10 318
yading@10 319 if (s->bit_alloc_params.sr_code == EAC3_SR_CODE_REDUCED) {
yading@10 320 /* The E-AC-3 specification does not tell how to handle reduced sample
yading@10 321 rates in bit allocation. The best assumption would be that it is
yading@10 322 handled like AC-3 DolbyNet, but we cannot be sure until we have a
yading@10 323 sample which utilizes this feature. */
yading@10 324 avpriv_request_sample(s->avctx, "Reduced sampling rate");
yading@10 325 return AVERROR_PATCHWELCOME;
yading@10 326 }
yading@10 327 skip_bits(gbc, 5); // skip bitstream id
yading@10 328
yading@10 329 /* volume control params */
yading@10 330 for (i = 0; i < (s->channel_mode ? 1 : 2); i++) {
yading@10 331 skip_bits(gbc, 5); // skip dialog normalization
yading@10 332 if (get_bits1(gbc)) {
yading@10 333 skip_bits(gbc, 8); // skip compression gain word
yading@10 334 }
yading@10 335 }
yading@10 336
yading@10 337 /* dependent stream channel map */
yading@10 338 if (s->frame_type == EAC3_FRAME_TYPE_DEPENDENT) {
yading@10 339 if (get_bits1(gbc)) {
yading@10 340 skip_bits(gbc, 16); // skip custom channel map
yading@10 341 }
yading@10 342 }
yading@10 343
yading@10 344 /* mixing metadata */
yading@10 345 if (get_bits1(gbc)) {
yading@10 346 /* center and surround mix levels */
yading@10 347 if (s->channel_mode > AC3_CHMODE_STEREO) {
yading@10 348 skip_bits(gbc, 2); // skip preferred stereo downmix mode
yading@10 349 if (s->channel_mode & 1) {
yading@10 350 /* if three front channels exist */
yading@10 351 skip_bits(gbc, 3); //skip Lt/Rt center mix level
yading@10 352 s->center_mix_level = get_bits(gbc, 3);
yading@10 353 }
yading@10 354 if (s->channel_mode & 4) {
yading@10 355 /* if a surround channel exists */
yading@10 356 skip_bits(gbc, 3); //skip Lt/Rt surround mix level
yading@10 357 s->surround_mix_level = get_bits(gbc, 3);
yading@10 358 }
yading@10 359 }
yading@10 360
yading@10 361 /* lfe mix level */
yading@10 362 if (s->lfe_on && get_bits1(gbc)) {
yading@10 363 // TODO: use LFE mix level
yading@10 364 skip_bits(gbc, 5); // skip LFE mix level code
yading@10 365 }
yading@10 366
yading@10 367 /* info for mixing with other streams and substreams */
yading@10 368 if (s->frame_type == EAC3_FRAME_TYPE_INDEPENDENT) {
yading@10 369 for (i = 0; i < (s->channel_mode ? 1 : 2); i++) {
yading@10 370 // TODO: apply program scale factor
yading@10 371 if (get_bits1(gbc)) {
yading@10 372 skip_bits(gbc, 6); // skip program scale factor
yading@10 373 }
yading@10 374 }
yading@10 375 if (get_bits1(gbc)) {
yading@10 376 skip_bits(gbc, 6); // skip external program scale factor
yading@10 377 }
yading@10 378 /* skip mixing parameter data */
yading@10 379 switch(get_bits(gbc, 2)) {
yading@10 380 case 1: skip_bits(gbc, 5); break;
yading@10 381 case 2: skip_bits(gbc, 12); break;
yading@10 382 case 3: {
yading@10 383 int mix_data_size = (get_bits(gbc, 5) + 2) << 3;
yading@10 384 skip_bits_long(gbc, mix_data_size);
yading@10 385 break;
yading@10 386 }
yading@10 387 }
yading@10 388 /* skip pan information for mono or dual mono source */
yading@10 389 if (s->channel_mode < AC3_CHMODE_STEREO) {
yading@10 390 for (i = 0; i < (s->channel_mode ? 1 : 2); i++) {
yading@10 391 if (get_bits1(gbc)) {
yading@10 392 /* note: this is not in the ATSC A/52B specification
yading@10 393 reference: ETSI TS 102 366 V1.1.1
yading@10 394 section: E.1.3.1.25 */
yading@10 395 skip_bits(gbc, 8); // skip pan mean direction index
yading@10 396 skip_bits(gbc, 6); // skip reserved paninfo bits
yading@10 397 }
yading@10 398 }
yading@10 399 }
yading@10 400 /* skip mixing configuration information */
yading@10 401 if (get_bits1(gbc)) {
yading@10 402 for (blk = 0; blk < s->num_blocks; blk++) {
yading@10 403 if (s->num_blocks == 1 || get_bits1(gbc)) {
yading@10 404 skip_bits(gbc, 5);
yading@10 405 }
yading@10 406 }
yading@10 407 }
yading@10 408 }
yading@10 409 }
yading@10 410
yading@10 411 /* informational metadata */
yading@10 412 if (get_bits1(gbc)) {
yading@10 413 s->bitstream_mode = get_bits(gbc, 3);
yading@10 414 skip_bits(gbc, 2); // skip copyright bit and original bitstream bit
yading@10 415 if (s->channel_mode == AC3_CHMODE_STEREO) {
yading@10 416 skip_bits(gbc, 4); // skip Dolby surround and headphone mode
yading@10 417 }
yading@10 418 if (s->channel_mode >= AC3_CHMODE_2F2R) {
yading@10 419 skip_bits(gbc, 2); // skip Dolby surround EX mode
yading@10 420 }
yading@10 421 for (i = 0; i < (s->channel_mode ? 1 : 2); i++) {
yading@10 422 if (get_bits1(gbc)) {
yading@10 423 skip_bits(gbc, 8); // skip mix level, room type, and A/D converter type
yading@10 424 }
yading@10 425 }
yading@10 426 if (s->bit_alloc_params.sr_code != EAC3_SR_CODE_REDUCED) {
yading@10 427 skip_bits1(gbc); // skip source sample rate code
yading@10 428 }
yading@10 429 }
yading@10 430
yading@10 431 /* converter synchronization flag
yading@10 432 If frames are less than six blocks, this bit should be turned on
yading@10 433 once every 6 blocks to indicate the start of a frame set.
yading@10 434 reference: RFC 4598, Section 2.1.3 Frame Sets */
yading@10 435 if (s->frame_type == EAC3_FRAME_TYPE_INDEPENDENT && s->num_blocks != 6) {
yading@10 436 skip_bits1(gbc); // skip converter synchronization flag
yading@10 437 }
yading@10 438
yading@10 439 /* original frame size code if this stream was converted from AC-3 */
yading@10 440 if (s->frame_type == EAC3_FRAME_TYPE_AC3_CONVERT &&
yading@10 441 (s->num_blocks == 6 || get_bits1(gbc))) {
yading@10 442 skip_bits(gbc, 6); // skip frame size code
yading@10 443 }
yading@10 444
yading@10 445 /* additional bitstream info */
yading@10 446 if (get_bits1(gbc)) {
yading@10 447 int addbsil = get_bits(gbc, 6);
yading@10 448 for (i = 0; i < addbsil + 1; i++) {
yading@10 449 skip_bits(gbc, 8); // skip additional bit stream info
yading@10 450 }
yading@10 451 }
yading@10 452
yading@10 453 /* audio frame syntax flags, strategy data, and per-frame data */
yading@10 454
yading@10 455 if (s->num_blocks == 6) {
yading@10 456 ac3_exponent_strategy = get_bits1(gbc);
yading@10 457 parse_aht_info = get_bits1(gbc);
yading@10 458 } else {
yading@10 459 /* less than 6 blocks, so use AC-3-style exponent strategy syntax, and
yading@10 460 do not use AHT */
yading@10 461 ac3_exponent_strategy = 1;
yading@10 462 parse_aht_info = 0;
yading@10 463 }
yading@10 464
yading@10 465 s->snr_offset_strategy = get_bits(gbc, 2);
yading@10 466 parse_transient_proc_info = get_bits1(gbc);
yading@10 467
yading@10 468 s->block_switch_syntax = get_bits1(gbc);
yading@10 469 if (!s->block_switch_syntax)
yading@10 470 memset(s->block_switch, 0, sizeof(s->block_switch));
yading@10 471
yading@10 472 s->dither_flag_syntax = get_bits1(gbc);
yading@10 473 if (!s->dither_flag_syntax) {
yading@10 474 for (ch = 1; ch <= s->fbw_channels; ch++)
yading@10 475 s->dither_flag[ch] = 1;
yading@10 476 }
yading@10 477 s->dither_flag[CPL_CH] = s->dither_flag[s->lfe_ch] = 0;
yading@10 478
yading@10 479 s->bit_allocation_syntax = get_bits1(gbc);
yading@10 480 if (!s->bit_allocation_syntax) {
yading@10 481 /* set default bit allocation parameters */
yading@10 482 s->bit_alloc_params.slow_decay = ff_ac3_slow_decay_tab[2];
yading@10 483 s->bit_alloc_params.fast_decay = ff_ac3_fast_decay_tab[1];
yading@10 484 s->bit_alloc_params.slow_gain = ff_ac3_slow_gain_tab [1];
yading@10 485 s->bit_alloc_params.db_per_bit = ff_ac3_db_per_bit_tab[2];
yading@10 486 s->bit_alloc_params.floor = ff_ac3_floor_tab [7];
yading@10 487 }
yading@10 488
yading@10 489 s->fast_gain_syntax = get_bits1(gbc);
yading@10 490 s->dba_syntax = get_bits1(gbc);
yading@10 491 s->skip_syntax = get_bits1(gbc);
yading@10 492 parse_spx_atten_data = get_bits1(gbc);
yading@10 493
yading@10 494 /* coupling strategy occurrence and coupling use per block */
yading@10 495 num_cpl_blocks = 0;
yading@10 496 if (s->channel_mode > 1) {
yading@10 497 for (blk = 0; blk < s->num_blocks; blk++) {
yading@10 498 s->cpl_strategy_exists[blk] = (!blk || get_bits1(gbc));
yading@10 499 if (s->cpl_strategy_exists[blk]) {
yading@10 500 s->cpl_in_use[blk] = get_bits1(gbc);
yading@10 501 } else {
yading@10 502 s->cpl_in_use[blk] = s->cpl_in_use[blk-1];
yading@10 503 }
yading@10 504 num_cpl_blocks += s->cpl_in_use[blk];
yading@10 505 }
yading@10 506 } else {
yading@10 507 memset(s->cpl_in_use, 0, sizeof(s->cpl_in_use));
yading@10 508 }
yading@10 509
yading@10 510 /* exponent strategy data */
yading@10 511 if (ac3_exponent_strategy) {
yading@10 512 /* AC-3-style exponent strategy syntax */
yading@10 513 for (blk = 0; blk < s->num_blocks; blk++) {
yading@10 514 for (ch = !s->cpl_in_use[blk]; ch <= s->fbw_channels; ch++) {
yading@10 515 s->exp_strategy[blk][ch] = get_bits(gbc, 2);
yading@10 516 }
yading@10 517 }
yading@10 518 } else {
yading@10 519 /* LUT-based exponent strategy syntax */
yading@10 520 for (ch = !((s->channel_mode > 1) && num_cpl_blocks); ch <= s->fbw_channels; ch++) {
yading@10 521 int frmchexpstr = get_bits(gbc, 5);
yading@10 522 for (blk = 0; blk < 6; blk++) {
yading@10 523 s->exp_strategy[blk][ch] = ff_eac3_frm_expstr[frmchexpstr][blk];
yading@10 524 }
yading@10 525 }
yading@10 526 }
yading@10 527 /* LFE exponent strategy */
yading@10 528 if (s->lfe_on) {
yading@10 529 for (blk = 0; blk < s->num_blocks; blk++) {
yading@10 530 s->exp_strategy[blk][s->lfe_ch] = get_bits1(gbc);
yading@10 531 }
yading@10 532 }
yading@10 533 /* original exponent strategies if this stream was converted from AC-3 */
yading@10 534 if (s->frame_type == EAC3_FRAME_TYPE_INDEPENDENT &&
yading@10 535 (s->num_blocks == 6 || get_bits1(gbc))) {
yading@10 536 skip_bits(gbc, 5 * s->fbw_channels); // skip converter channel exponent strategy
yading@10 537 }
yading@10 538
yading@10 539 /* determine which channels use AHT */
yading@10 540 if (parse_aht_info) {
yading@10 541 /* For AHT to be used, all non-zero blocks must reuse exponents from
yading@10 542 the first block. Furthermore, for AHT to be used in the coupling
yading@10 543 channel, all blocks must use coupling and use the same coupling
yading@10 544 strategy. */
yading@10 545 s->channel_uses_aht[CPL_CH]=0;
yading@10 546 for (ch = (num_cpl_blocks != 6); ch <= s->channels; ch++) {
yading@10 547 int use_aht = 1;
yading@10 548 for (blk = 1; blk < 6; blk++) {
yading@10 549 if ((s->exp_strategy[blk][ch] != EXP_REUSE) ||
yading@10 550 (!ch && s->cpl_strategy_exists[blk])) {
yading@10 551 use_aht = 0;
yading@10 552 break;
yading@10 553 }
yading@10 554 }
yading@10 555 s->channel_uses_aht[ch] = use_aht && get_bits1(gbc);
yading@10 556 }
yading@10 557 } else {
yading@10 558 memset(s->channel_uses_aht, 0, sizeof(s->channel_uses_aht));
yading@10 559 }
yading@10 560
yading@10 561 /* per-frame SNR offset */
yading@10 562 if (!s->snr_offset_strategy) {
yading@10 563 int csnroffst = (get_bits(gbc, 6) - 15) << 4;
yading@10 564 int snroffst = (csnroffst + get_bits(gbc, 4)) << 2;
yading@10 565 for (ch = 0; ch <= s->channels; ch++)
yading@10 566 s->snr_offset[ch] = snroffst;
yading@10 567 }
yading@10 568
yading@10 569 /* transient pre-noise processing data */
yading@10 570 if (parse_transient_proc_info) {
yading@10 571 for (ch = 1; ch <= s->fbw_channels; ch++) {
yading@10 572 if (get_bits1(gbc)) { // channel in transient processing
yading@10 573 skip_bits(gbc, 10); // skip transient processing location
yading@10 574 skip_bits(gbc, 8); // skip transient processing length
yading@10 575 }
yading@10 576 }
yading@10 577 }
yading@10 578
yading@10 579 /* spectral extension attenuation data */
yading@10 580 for (ch = 1; ch <= s->fbw_channels; ch++) {
yading@10 581 if (parse_spx_atten_data && get_bits1(gbc)) {
yading@10 582 s->spx_atten_code[ch] = get_bits(gbc, 5);
yading@10 583 } else {
yading@10 584 s->spx_atten_code[ch] = -1;
yading@10 585 }
yading@10 586 }
yading@10 587
yading@10 588 /* block start information */
yading@10 589 if (s->num_blocks > 1 && get_bits1(gbc)) {
yading@10 590 /* reference: Section E2.3.2.27
yading@10 591 nblkstrtbits = (numblks - 1) * (4 + ceiling(log2(words_per_frame)))
yading@10 592 The spec does not say what this data is or what it's used for.
yading@10 593 It is likely the offset of each block within the frame. */
yading@10 594 int block_start_bits = (s->num_blocks-1) * (4 + av_log2(s->frame_size-2));
yading@10 595 skip_bits_long(gbc, block_start_bits);
yading@10 596 avpriv_request_sample(s->avctx, "Block start info");
yading@10 597 }
yading@10 598
yading@10 599 /* syntax state initialization */
yading@10 600 for (ch = 1; ch <= s->fbw_channels; ch++) {
yading@10 601 s->first_spx_coords[ch] = 1;
yading@10 602 s->first_cpl_coords[ch] = 1;
yading@10 603 }
yading@10 604 s->first_cpl_leak = 1;
yading@10 605
yading@10 606 return 0;
yading@10 607 }