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 }
|