]> git.sesse.net Git - ffmpeg/blob - libavcodec/dcadec.c
Fix a number of incorrect intmath.h #includes.
[ffmpeg] / libavcodec / dcadec.c
1 /*
2  * DCA compatible decoder
3  * Copyright (C) 2004 Gildas Bazin
4  * Copyright (C) 2004 Benjamin Zores
5  * Copyright (C) 2006 Benjamin Larsson
6  * Copyright (C) 2007 Konstantin Shishkov
7  *
8  * This file is part of Libav.
9  *
10  * Libav is free software; you can redistribute it and/or
11  * modify it under the terms of the GNU Lesser General Public
12  * License as published by the Free Software Foundation; either
13  * version 2.1 of the License, or (at your option) any later version.
14  *
15  * Libav is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
18  * Lesser General Public License for more details.
19  *
20  * You should have received a copy of the GNU Lesser General Public
21  * License along with Libav; if not, write to the Free Software
22  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
23  */
24
25 #include <math.h>
26 #include <stddef.h>
27 #include <stdio.h>
28
29 #include "libavutil/channel_layout.h"
30 #include "libavutil/common.h"
31 #include "libavutil/float_dsp.h"
32 #include "libavutil/internal.h"
33 #include "libavutil/intreadwrite.h"
34 #include "libavutil/mathematics.h"
35 #include "libavutil/samplefmt.h"
36 #include "avcodec.h"
37 #include "fft.h"
38 #include "get_bits.h"
39 #include "put_bits.h"
40 #include "dcadata.h"
41 #include "dcahuff.h"
42 #include "dca.h"
43 #include "dca_parser.h"
44 #include "mathops.h"
45 #include "synth_filter.h"
46 #include "dcadsp.h"
47 #include "fmtconvert.h"
48 #include "internal.h"
49
50 #if ARCH_ARM
51 #   include "arm/dca.h"
52 #endif
53
54 //#define TRACE
55
56 #define DCA_PRIM_CHANNELS_MAX  (7)
57 #define DCA_SUBBANDS          (32)
58 #define DCA_ABITS_MAX         (32)      /* Should be 28 */
59 #define DCA_SUBSUBFRAMES_MAX   (4)
60 #define DCA_SUBFRAMES_MAX     (16)
61 #define DCA_BLOCKS_MAX        (16)
62 #define DCA_LFE_MAX            (3)
63
64 enum DCAMode {
65     DCA_MONO = 0,
66     DCA_CHANNEL,
67     DCA_STEREO,
68     DCA_STEREO_SUMDIFF,
69     DCA_STEREO_TOTAL,
70     DCA_3F,
71     DCA_2F1R,
72     DCA_3F1R,
73     DCA_2F2R,
74     DCA_3F2R,
75     DCA_4F2R
76 };
77
78 /* these are unconfirmed but should be mostly correct */
79 enum DCAExSSSpeakerMask {
80     DCA_EXSS_FRONT_CENTER          = 0x0001,
81     DCA_EXSS_FRONT_LEFT_RIGHT      = 0x0002,
82     DCA_EXSS_SIDE_REAR_LEFT_RIGHT  = 0x0004,
83     DCA_EXSS_LFE                   = 0x0008,
84     DCA_EXSS_REAR_CENTER           = 0x0010,
85     DCA_EXSS_FRONT_HIGH_LEFT_RIGHT = 0x0020,
86     DCA_EXSS_REAR_LEFT_RIGHT       = 0x0040,
87     DCA_EXSS_FRONT_HIGH_CENTER     = 0x0080,
88     DCA_EXSS_OVERHEAD              = 0x0100,
89     DCA_EXSS_CENTER_LEFT_RIGHT     = 0x0200,
90     DCA_EXSS_WIDE_LEFT_RIGHT       = 0x0400,
91     DCA_EXSS_SIDE_LEFT_RIGHT       = 0x0800,
92     DCA_EXSS_LFE2                  = 0x1000,
93     DCA_EXSS_SIDE_HIGH_LEFT_RIGHT  = 0x2000,
94     DCA_EXSS_REAR_HIGH_CENTER      = 0x4000,
95     DCA_EXSS_REAR_HIGH_LEFT_RIGHT  = 0x8000,
96 };
97
98 enum DCAExtensionMask {
99     DCA_EXT_CORE       = 0x001, ///< core in core substream
100     DCA_EXT_XXCH       = 0x002, ///< XXCh channels extension in core substream
101     DCA_EXT_X96        = 0x004, ///< 96/24 extension in core substream
102     DCA_EXT_XCH        = 0x008, ///< XCh channel extension in core substream
103     DCA_EXT_EXSS_CORE  = 0x010, ///< core in ExSS (extension substream)
104     DCA_EXT_EXSS_XBR   = 0x020, ///< extended bitrate extension in ExSS
105     DCA_EXT_EXSS_XXCH  = 0x040, ///< XXCh channels extension in ExSS
106     DCA_EXT_EXSS_X96   = 0x080, ///< 96/24 extension in ExSS
107     DCA_EXT_EXSS_LBR   = 0x100, ///< low bitrate component in ExSS
108     DCA_EXT_EXSS_XLL   = 0x200, ///< lossless extension in ExSS
109 };
110
111 /* -1 are reserved or unknown */
112 static const int dca_ext_audio_descr_mask[] = {
113     DCA_EXT_XCH,
114     -1,
115     DCA_EXT_X96,
116     DCA_EXT_XCH | DCA_EXT_X96,
117     -1,
118     -1,
119     DCA_EXT_XXCH,
120     -1,
121 };
122
123 /* extensions that reside in core substream */
124 #define DCA_CORE_EXTS (DCA_EXT_XCH | DCA_EXT_XXCH | DCA_EXT_X96)
125
126 /* Tables for mapping dts channel configurations to libavcodec multichannel api.
127  * Some compromises have been made for special configurations. Most configurations
128  * are never used so complete accuracy is not needed.
129  *
130  * L = left, R = right, C = center, S = surround, F = front, R = rear, T = total, OV = overhead.
131  * S  -> side, when both rear and back are configured move one of them to the side channel
132  * OV -> center back
133  * All 2 channel configurations -> AV_CH_LAYOUT_STEREO
134  */
135 static const uint64_t dca_core_channel_layout[] = {
136     AV_CH_FRONT_CENTER,                                                     ///< 1, A
137     AV_CH_LAYOUT_STEREO,                                                    ///< 2, A + B (dual mono)
138     AV_CH_LAYOUT_STEREO,                                                    ///< 2, L + R (stereo)
139     AV_CH_LAYOUT_STEREO,                                                    ///< 2, (L + R) + (L - R) (sum-difference)
140     AV_CH_LAYOUT_STEREO,                                                    ///< 2, LT + RT (left and right total)
141     AV_CH_LAYOUT_STEREO | AV_CH_FRONT_CENTER,                               ///< 3, C + L + R
142     AV_CH_LAYOUT_STEREO | AV_CH_BACK_CENTER,                                ///< 3, L + R + S
143     AV_CH_LAYOUT_STEREO | AV_CH_FRONT_CENTER | AV_CH_BACK_CENTER,           ///< 4, C + L + R + S
144     AV_CH_LAYOUT_STEREO | AV_CH_SIDE_LEFT | AV_CH_SIDE_RIGHT,               ///< 4, L + R + SL + SR
145
146     AV_CH_LAYOUT_STEREO | AV_CH_FRONT_CENTER | AV_CH_SIDE_LEFT |
147     AV_CH_SIDE_RIGHT,                                                       ///< 5, C + L + R + SL + SR
148
149     AV_CH_LAYOUT_STEREO | AV_CH_SIDE_LEFT | AV_CH_SIDE_RIGHT |
150     AV_CH_FRONT_LEFT_OF_CENTER | AV_CH_FRONT_RIGHT_OF_CENTER,               ///< 6, CL + CR + L + R + SL + SR
151
152     AV_CH_LAYOUT_STEREO | AV_CH_BACK_LEFT | AV_CH_BACK_RIGHT |
153     AV_CH_FRONT_CENTER  | AV_CH_BACK_CENTER,                                ///< 6, C + L + R + LR + RR + OV
154
155     AV_CH_FRONT_CENTER | AV_CH_FRONT_RIGHT_OF_CENTER |
156     AV_CH_FRONT_LEFT_OF_CENTER | AV_CH_BACK_CENTER   |
157     AV_CH_BACK_LEFT | AV_CH_BACK_RIGHT,                                     ///< 6, CF + CR + LF + RF + LR + RR
158
159     AV_CH_FRONT_LEFT_OF_CENTER | AV_CH_FRONT_CENTER   |
160     AV_CH_FRONT_RIGHT_OF_CENTER | AV_CH_LAYOUT_STEREO |
161     AV_CH_SIDE_LEFT | AV_CH_SIDE_RIGHT,                                     ///< 7, CL + C + CR + L + R + SL + SR
162
163     AV_CH_FRONT_LEFT_OF_CENTER | AV_CH_FRONT_RIGHT_OF_CENTER |
164     AV_CH_LAYOUT_STEREO | AV_CH_SIDE_LEFT | AV_CH_SIDE_RIGHT |
165     AV_CH_BACK_LEFT | AV_CH_BACK_RIGHT,                                     ///< 8, CL + CR + L + R + SL1 + SL2 + SR1 + SR2
166
167     AV_CH_FRONT_LEFT_OF_CENTER | AV_CH_FRONT_CENTER   |
168     AV_CH_FRONT_RIGHT_OF_CENTER | AV_CH_LAYOUT_STEREO |
169     AV_CH_SIDE_LEFT | AV_CH_BACK_CENTER | AV_CH_SIDE_RIGHT,                 ///< 8, CL + C + CR + L + R + SL + S + SR
170 };
171
172 static const int8_t dca_lfe_index[] = {
173     1, 2, 2, 2, 2, 3, 2, 3, 2, 3, 2, 3, 1, 3, 2, 3
174 };
175
176 static const int8_t dca_channel_reorder_lfe[][9] = {
177     { 0, -1, -1, -1, -1, -1, -1, -1, -1},
178     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
179     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
180     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
181     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
182     { 2,  0,  1, -1, -1, -1, -1, -1, -1},
183     { 0,  1,  3, -1, -1, -1, -1, -1, -1},
184     { 2,  0,  1,  4, -1, -1, -1, -1, -1},
185     { 0,  1,  3,  4, -1, -1, -1, -1, -1},
186     { 2,  0,  1,  4,  5, -1, -1, -1, -1},
187     { 3,  4,  0,  1,  5,  6, -1, -1, -1},
188     { 2,  0,  1,  4,  5,  6, -1, -1, -1},
189     { 0,  6,  4,  5,  2,  3, -1, -1, -1},
190     { 4,  2,  5,  0,  1,  6,  7, -1, -1},
191     { 5,  6,  0,  1,  7,  3,  8,  4, -1},
192     { 4,  2,  5,  0,  1,  6,  8,  7, -1},
193 };
194
195 static const int8_t dca_channel_reorder_lfe_xch[][9] = {
196     { 0,  2, -1, -1, -1, -1, -1, -1, -1},
197     { 0,  1,  3, -1, -1, -1, -1, -1, -1},
198     { 0,  1,  3, -1, -1, -1, -1, -1, -1},
199     { 0,  1,  3, -1, -1, -1, -1, -1, -1},
200     { 0,  1,  3, -1, -1, -1, -1, -1, -1},
201     { 2,  0,  1,  4, -1, -1, -1, -1, -1},
202     { 0,  1,  3,  4, -1, -1, -1, -1, -1},
203     { 2,  0,  1,  4,  5, -1, -1, -1, -1},
204     { 0,  1,  4,  5,  3, -1, -1, -1, -1},
205     { 2,  0,  1,  5,  6,  4, -1, -1, -1},
206     { 3,  4,  0,  1,  6,  7,  5, -1, -1},
207     { 2,  0,  1,  4,  5,  6,  7, -1, -1},
208     { 0,  6,  4,  5,  2,  3,  7, -1, -1},
209     { 4,  2,  5,  0,  1,  7,  8,  6, -1},
210     { 5,  6,  0,  1,  8,  3,  9,  4,  7},
211     { 4,  2,  5,  0,  1,  6,  9,  8,  7},
212 };
213
214 static const int8_t dca_channel_reorder_nolfe[][9] = {
215     { 0, -1, -1, -1, -1, -1, -1, -1, -1},
216     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
217     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
218     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
219     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
220     { 2,  0,  1, -1, -1, -1, -1, -1, -1},
221     { 0,  1,  2, -1, -1, -1, -1, -1, -1},
222     { 2,  0,  1,  3, -1, -1, -1, -1, -1},
223     { 0,  1,  2,  3, -1, -1, -1, -1, -1},
224     { 2,  0,  1,  3,  4, -1, -1, -1, -1},
225     { 2,  3,  0,  1,  4,  5, -1, -1, -1},
226     { 2,  0,  1,  3,  4,  5, -1, -1, -1},
227     { 0,  5,  3,  4,  1,  2, -1, -1, -1},
228     { 3,  2,  4,  0,  1,  5,  6, -1, -1},
229     { 4,  5,  0,  1,  6,  2,  7,  3, -1},
230     { 3,  2,  4,  0,  1,  5,  7,  6, -1},
231 };
232
233 static const int8_t dca_channel_reorder_nolfe_xch[][9] = {
234     { 0,  1, -1, -1, -1, -1, -1, -1, -1},
235     { 0,  1,  2, -1, -1, -1, -1, -1, -1},
236     { 0,  1,  2, -1, -1, -1, -1, -1, -1},
237     { 0,  1,  2, -1, -1, -1, -1, -1, -1},
238     { 0,  1,  2, -1, -1, -1, -1, -1, -1},
239     { 2,  0,  1,  3, -1, -1, -1, -1, -1},
240     { 0,  1,  2,  3, -1, -1, -1, -1, -1},
241     { 2,  0,  1,  3,  4, -1, -1, -1, -1},
242     { 0,  1,  3,  4,  2, -1, -1, -1, -1},
243     { 2,  0,  1,  4,  5,  3, -1, -1, -1},
244     { 2,  3,  0,  1,  5,  6,  4, -1, -1},
245     { 2,  0,  1,  3,  4,  5,  6, -1, -1},
246     { 0,  5,  3,  4,  1,  2,  6, -1, -1},
247     { 3,  2,  4,  0,  1,  6,  7,  5, -1},
248     { 4,  5,  0,  1,  7,  2,  8,  3,  6},
249     { 3,  2,  4,  0,  1,  5,  8,  7,  6},
250 };
251
252 #define DCA_DOLBY                  101           /* FIXME */
253
254 #define DCA_CHANNEL_BITS             6
255 #define DCA_CHANNEL_MASK          0x3F
256
257 #define DCA_LFE                   0x80
258
259 #define HEADER_SIZE                 14
260
261 #define DCA_MAX_FRAME_SIZE       16384
262 #define DCA_MAX_EXSS_HEADER_SIZE  4096
263
264 #define DCA_BUFFER_PADDING_SIZE   1024
265
266 /** Bit allocation */
267 typedef struct {
268     int offset;                 ///< code values offset
269     int maxbits[8];             ///< max bits in VLC
270     int wrap;                   ///< wrap for get_vlc2()
271     VLC vlc[8];                 ///< actual codes
272 } BitAlloc;
273
274 static BitAlloc dca_bitalloc_index;    ///< indexes for samples VLC select
275 static BitAlloc dca_tmode;             ///< transition mode VLCs
276 static BitAlloc dca_scalefactor;       ///< scalefactor VLCs
277 static BitAlloc dca_smpl_bitalloc[11]; ///< samples VLCs
278
279 static av_always_inline int get_bitalloc(GetBitContext *gb, BitAlloc *ba,
280                                          int idx)
281 {
282     return get_vlc2(gb, ba->vlc[idx].table, ba->vlc[idx].bits, ba->wrap) +
283            ba->offset;
284 }
285
286 typedef struct {
287     AVCodecContext *avctx;
288     /* Frame header */
289     int frame_type;             ///< type of the current frame
290     int samples_deficit;        ///< deficit sample count
291     int crc_present;            ///< crc is present in the bitstream
292     int sample_blocks;          ///< number of PCM sample blocks
293     int frame_size;             ///< primary frame byte size
294     int amode;                  ///< audio channels arrangement
295     int sample_rate;            ///< audio sampling rate
296     int bit_rate;               ///< transmission bit rate
297     int bit_rate_index;         ///< transmission bit rate index
298
299     int downmix;                ///< embedded downmix enabled
300     int dynrange;               ///< embedded dynamic range flag
301     int timestamp;              ///< embedded time stamp flag
302     int aux_data;               ///< auxiliary data flag
303     int hdcd;                   ///< source material is mastered in HDCD
304     int ext_descr;              ///< extension audio descriptor flag
305     int ext_coding;             ///< extended coding flag
306     int aspf;                   ///< audio sync word insertion flag
307     int lfe;                    ///< low frequency effects flag
308     int predictor_history;      ///< predictor history flag
309     int header_crc;             ///< header crc check bytes
310     int multirate_inter;        ///< multirate interpolator switch
311     int version;                ///< encoder software revision
312     int copy_history;           ///< copy history
313     int source_pcm_res;         ///< source pcm resolution
314     int front_sum;              ///< front sum/difference flag
315     int surround_sum;           ///< surround sum/difference flag
316     int dialog_norm;            ///< dialog normalisation parameter
317
318     /* Primary audio coding header */
319     int subframes;              ///< number of subframes
320     int total_channels;         ///< number of channels including extensions
321     int prim_channels;          ///< number of primary audio channels
322     int subband_activity[DCA_PRIM_CHANNELS_MAX];    ///< subband activity count
323     int vq_start_subband[DCA_PRIM_CHANNELS_MAX];    ///< high frequency vq start subband
324     int joint_intensity[DCA_PRIM_CHANNELS_MAX];     ///< joint intensity coding index
325     int transient_huffman[DCA_PRIM_CHANNELS_MAX];   ///< transient mode code book
326     int scalefactor_huffman[DCA_PRIM_CHANNELS_MAX]; ///< scale factor code book
327     int bitalloc_huffman[DCA_PRIM_CHANNELS_MAX];    ///< bit allocation quantizer select
328     int quant_index_huffman[DCA_PRIM_CHANNELS_MAX][DCA_ABITS_MAX]; ///< quantization index codebook select
329     float scalefactor_adj[DCA_PRIM_CHANNELS_MAX][DCA_ABITS_MAX];   ///< scale factor adjustment
330
331     /* Primary audio coding side information */
332     int subsubframes[DCA_SUBFRAMES_MAX];                         ///< number of subsubframes
333     int partial_samples[DCA_SUBFRAMES_MAX];                      ///< partial subsubframe samples count
334     int prediction_mode[DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS];    ///< prediction mode (ADPCM used or not)
335     int prediction_vq[DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS];      ///< prediction VQ coefs
336     int bitalloc[DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS];           ///< bit allocation index
337     int transition_mode[DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS];    ///< transition mode (transients)
338     int scale_factor[DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS][2];    ///< scale factors (2 if transient)
339     int joint_huff[DCA_PRIM_CHANNELS_MAX];                       ///< joint subband scale factors codebook
340     int joint_scale_factor[DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS]; ///< joint subband scale factors
341     int downmix_coef[DCA_PRIM_CHANNELS_MAX][2];                  ///< stereo downmix coefficients
342     int dynrange_coef;                                           ///< dynamic range coefficient
343
344     int high_freq_vq[DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS];       ///< VQ encoded high frequency subbands
345
346     float lfe_data[2 * DCA_LFE_MAX * (DCA_BLOCKS_MAX + 4)];      ///< Low frequency effect data
347     int lfe_scale_factor;
348
349     /* Subband samples history (for ADPCM) */
350     DECLARE_ALIGNED(16, float, subband_samples_hist)[DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS][4];
351     DECLARE_ALIGNED(32, float, subband_fir_hist)[DCA_PRIM_CHANNELS_MAX][512];
352     DECLARE_ALIGNED(32, float, subband_fir_noidea)[DCA_PRIM_CHANNELS_MAX][32];
353     int hist_index[DCA_PRIM_CHANNELS_MAX];
354     DECLARE_ALIGNED(32, float, raXin)[32];
355
356     int output;                 ///< type of output
357
358     DECLARE_ALIGNED(32, float, subband_samples)[DCA_BLOCKS_MAX][DCA_PRIM_CHANNELS_MAX][DCA_SUBBANDS][8];
359     float *samples_chanptr[DCA_PRIM_CHANNELS_MAX + 1];
360     float *extra_channels[DCA_PRIM_CHANNELS_MAX + 1];
361     uint8_t *extra_channels_buffer;
362     unsigned int extra_channels_buffer_size;
363
364     uint8_t dca_buffer[DCA_MAX_FRAME_SIZE + DCA_MAX_EXSS_HEADER_SIZE + DCA_BUFFER_PADDING_SIZE];
365     int dca_buffer_size;        ///< how much data is in the dca_buffer
366
367     const int8_t *channel_order_tab;  ///< channel reordering table, lfe and non lfe
368     GetBitContext gb;
369     /* Current position in DCA frame */
370     int current_subframe;
371     int current_subsubframe;
372
373     int core_ext_mask;          ///< present extensions in the core substream
374
375     /* XCh extension information */
376     int xch_present;            ///< XCh extension present and valid
377     int xch_base_channel;       ///< index of first (only) channel containing XCH data
378
379     /* ExSS header parser */
380     int static_fields;          ///< static fields present
381     int mix_metadata;           ///< mixing metadata present
382     int num_mix_configs;        ///< number of mix out configurations
383     int mix_config_num_ch[4];   ///< number of channels in each mix out configuration
384
385     int profile;
386
387     int debug_flag;             ///< used for suppressing repeated error messages output
388     AVFloatDSPContext fdsp;
389     FFTContext imdct;
390     SynthFilterContext synth;
391     DCADSPContext dcadsp;
392     FmtConvertContext fmt_conv;
393 } DCAContext;
394
395 static const uint16_t dca_vlc_offs[] = {
396         0,   512,   640,   768,  1282,  1794,  2436,  3080,  3770,  4454,  5364,
397      5372,  5380,  5388,  5392,  5396,  5412,  5420,  5428,  5460,  5492,  5508,
398      5572,  5604,  5668,  5796,  5860,  5892,  6412,  6668,  6796,  7308,  7564,
399      7820,  8076,  8620,  9132,  9388,  9910, 10166, 10680, 11196, 11726, 12240,
400     12752, 13298, 13810, 14326, 14840, 15500, 16022, 16540, 17158, 17678, 18264,
401     18796, 19352, 19926, 20468, 21472, 22398, 23014, 23622,
402 };
403
404 static av_cold void dca_init_vlcs(void)
405 {
406     static int vlcs_initialized = 0;
407     int i, j, c = 14;
408     static VLC_TYPE dca_table[23622][2];
409
410     if (vlcs_initialized)
411         return;
412
413     dca_bitalloc_index.offset = 1;
414     dca_bitalloc_index.wrap = 2;
415     for (i = 0; i < 5; i++) {
416         dca_bitalloc_index.vlc[i].table = &dca_table[dca_vlc_offs[i]];
417         dca_bitalloc_index.vlc[i].table_allocated = dca_vlc_offs[i + 1] - dca_vlc_offs[i];
418         init_vlc(&dca_bitalloc_index.vlc[i], bitalloc_12_vlc_bits[i], 12,
419                  bitalloc_12_bits[i], 1, 1,
420                  bitalloc_12_codes[i], 2, 2, INIT_VLC_USE_NEW_STATIC);
421     }
422     dca_scalefactor.offset = -64;
423     dca_scalefactor.wrap = 2;
424     for (i = 0; i < 5; i++) {
425         dca_scalefactor.vlc[i].table = &dca_table[dca_vlc_offs[i + 5]];
426         dca_scalefactor.vlc[i].table_allocated = dca_vlc_offs[i + 6] - dca_vlc_offs[i + 5];
427         init_vlc(&dca_scalefactor.vlc[i], SCALES_VLC_BITS, 129,
428                  scales_bits[i], 1, 1,
429                  scales_codes[i], 2, 2, INIT_VLC_USE_NEW_STATIC);
430     }
431     dca_tmode.offset = 0;
432     dca_tmode.wrap = 1;
433     for (i = 0; i < 4; i++) {
434         dca_tmode.vlc[i].table = &dca_table[dca_vlc_offs[i + 10]];
435         dca_tmode.vlc[i].table_allocated = dca_vlc_offs[i + 11] - dca_vlc_offs[i + 10];
436         init_vlc(&dca_tmode.vlc[i], tmode_vlc_bits[i], 4,
437                  tmode_bits[i], 1, 1,
438                  tmode_codes[i], 2, 2, INIT_VLC_USE_NEW_STATIC);
439     }
440
441     for (i = 0; i < 10; i++)
442         for (j = 0; j < 7; j++) {
443             if (!bitalloc_codes[i][j])
444                 break;
445             dca_smpl_bitalloc[i + 1].offset                 = bitalloc_offsets[i];
446             dca_smpl_bitalloc[i + 1].wrap                   = 1 + (j > 4);
447             dca_smpl_bitalloc[i + 1].vlc[j].table           = &dca_table[dca_vlc_offs[c]];
448             dca_smpl_bitalloc[i + 1].vlc[j].table_allocated = dca_vlc_offs[c + 1] - dca_vlc_offs[c];
449
450             init_vlc(&dca_smpl_bitalloc[i + 1].vlc[j], bitalloc_maxbits[i][j],
451                      bitalloc_sizes[i],
452                      bitalloc_bits[i][j], 1, 1,
453                      bitalloc_codes[i][j], 2, 2, INIT_VLC_USE_NEW_STATIC);
454             c++;
455         }
456     vlcs_initialized = 1;
457 }
458
459 static inline void get_array(GetBitContext *gb, int *dst, int len, int bits)
460 {
461     while (len--)
462         *dst++ = get_bits(gb, bits);
463 }
464
465 static int dca_parse_audio_coding_header(DCAContext *s, int base_channel)
466 {
467     int i, j;
468     static const float adj_table[4] = { 1.0, 1.1250, 1.2500, 1.4375 };
469     static const int bitlen[11] = { 0, 1, 2, 2, 2, 2, 3, 3, 3, 3, 3 };
470     static const int thr[11]    = { 0, 1, 3, 3, 3, 3, 7, 7, 7, 7, 7 };
471
472     s->total_channels = get_bits(&s->gb, 3) + 1 + base_channel;
473     s->prim_channels  = s->total_channels;
474
475     if (s->prim_channels > DCA_PRIM_CHANNELS_MAX)
476         s->prim_channels = DCA_PRIM_CHANNELS_MAX;
477
478
479     for (i = base_channel; i < s->prim_channels; i++) {
480         s->subband_activity[i] = get_bits(&s->gb, 5) + 2;
481         if (s->subband_activity[i] > DCA_SUBBANDS)
482             s->subband_activity[i] = DCA_SUBBANDS;
483     }
484     for (i = base_channel; i < s->prim_channels; i++) {
485         s->vq_start_subband[i] = get_bits(&s->gb, 5) + 1;
486         if (s->vq_start_subband[i] > DCA_SUBBANDS)
487             s->vq_start_subband[i] = DCA_SUBBANDS;
488     }
489     get_array(&s->gb, s->joint_intensity + base_channel,     s->prim_channels - base_channel, 3);
490     get_array(&s->gb, s->transient_huffman + base_channel,   s->prim_channels - base_channel, 2);
491     get_array(&s->gb, s->scalefactor_huffman + base_channel, s->prim_channels - base_channel, 3);
492     get_array(&s->gb, s->bitalloc_huffman + base_channel,    s->prim_channels - base_channel, 3);
493
494     /* Get codebooks quantization indexes */
495     if (!base_channel)
496         memset(s->quant_index_huffman, 0, sizeof(s->quant_index_huffman));
497     for (j = 1; j < 11; j++)
498         for (i = base_channel; i < s->prim_channels; i++)
499             s->quant_index_huffman[i][j] = get_bits(&s->gb, bitlen[j]);
500
501     /* Get scale factor adjustment */
502     for (j = 0; j < 11; j++)
503         for (i = base_channel; i < s->prim_channels; i++)
504             s->scalefactor_adj[i][j] = 1;
505
506     for (j = 1; j < 11; j++)
507         for (i = base_channel; i < s->prim_channels; i++)
508             if (s->quant_index_huffman[i][j] < thr[j])
509                 s->scalefactor_adj[i][j] = adj_table[get_bits(&s->gb, 2)];
510
511     if (s->crc_present) {
512         /* Audio header CRC check */
513         get_bits(&s->gb, 16);
514     }
515
516     s->current_subframe    = 0;
517     s->current_subsubframe = 0;
518
519 #ifdef TRACE
520     av_log(s->avctx, AV_LOG_DEBUG, "subframes: %i\n", s->subframes);
521     av_log(s->avctx, AV_LOG_DEBUG, "prim channels: %i\n", s->prim_channels);
522     for (i = base_channel; i < s->prim_channels; i++) {
523         av_log(s->avctx, AV_LOG_DEBUG, "subband activity: %i\n",
524                s->subband_activity[i]);
525         av_log(s->avctx, AV_LOG_DEBUG, "vq start subband: %i\n",
526                s->vq_start_subband[i]);
527         av_log(s->avctx, AV_LOG_DEBUG, "joint intensity: %i\n",
528                s->joint_intensity[i]);
529         av_log(s->avctx, AV_LOG_DEBUG, "transient mode codebook: %i\n",
530                s->transient_huffman[i]);
531         av_log(s->avctx, AV_LOG_DEBUG, "scale factor codebook: %i\n",
532                s->scalefactor_huffman[i]);
533         av_log(s->avctx, AV_LOG_DEBUG, "bit allocation quantizer: %i\n",
534                s->bitalloc_huffman[i]);
535         av_log(s->avctx, AV_LOG_DEBUG, "quant index huff:");
536         for (j = 0; j < 11; j++)
537             av_log(s->avctx, AV_LOG_DEBUG, " %i", s->quant_index_huffman[i][j]);
538         av_log(s->avctx, AV_LOG_DEBUG, "\n");
539         av_log(s->avctx, AV_LOG_DEBUG, "scalefac adj:");
540         for (j = 0; j < 11; j++)
541             av_log(s->avctx, AV_LOG_DEBUG, " %1.3f", s->scalefactor_adj[i][j]);
542         av_log(s->avctx, AV_LOG_DEBUG, "\n");
543     }
544 #endif
545
546     return 0;
547 }
548
549 static int dca_parse_frame_header(DCAContext *s)
550 {
551     init_get_bits(&s->gb, s->dca_buffer, s->dca_buffer_size * 8);
552
553     /* Sync code */
554     skip_bits_long(&s->gb, 32);
555
556     /* Frame header */
557     s->frame_type        = get_bits(&s->gb, 1);
558     s->samples_deficit   = get_bits(&s->gb, 5) + 1;
559     s->crc_present       = get_bits(&s->gb, 1);
560     s->sample_blocks     = get_bits(&s->gb, 7) + 1;
561     s->frame_size        = get_bits(&s->gb, 14) + 1;
562     if (s->frame_size < 95)
563         return AVERROR_INVALIDDATA;
564     s->amode             = get_bits(&s->gb, 6);
565     s->sample_rate       = avpriv_dca_sample_rates[get_bits(&s->gb, 4)];
566     if (!s->sample_rate)
567         return AVERROR_INVALIDDATA;
568     s->bit_rate_index    = get_bits(&s->gb, 5);
569     s->bit_rate          = dca_bit_rates[s->bit_rate_index];
570     if (!s->bit_rate)
571         return AVERROR_INVALIDDATA;
572
573     s->downmix           = get_bits(&s->gb, 1);
574     s->dynrange          = get_bits(&s->gb, 1);
575     s->timestamp         = get_bits(&s->gb, 1);
576     s->aux_data          = get_bits(&s->gb, 1);
577     s->hdcd              = get_bits(&s->gb, 1);
578     s->ext_descr         = get_bits(&s->gb, 3);
579     s->ext_coding        = get_bits(&s->gb, 1);
580     s->aspf              = get_bits(&s->gb, 1);
581     s->lfe               = get_bits(&s->gb, 2);
582     s->predictor_history = get_bits(&s->gb, 1);
583
584     /* TODO: check CRC */
585     if (s->crc_present)
586         s->header_crc    = get_bits(&s->gb, 16);
587
588     s->multirate_inter   = get_bits(&s->gb, 1);
589     s->version           = get_bits(&s->gb, 4);
590     s->copy_history      = get_bits(&s->gb, 2);
591     s->source_pcm_res    = get_bits(&s->gb, 3);
592     s->front_sum         = get_bits(&s->gb, 1);
593     s->surround_sum      = get_bits(&s->gb, 1);
594     s->dialog_norm       = get_bits(&s->gb, 4);
595
596     /* FIXME: channels mixing levels */
597     s->output = s->amode;
598     if (s->lfe)
599         s->output |= DCA_LFE;
600
601 #ifdef TRACE
602     av_log(s->avctx, AV_LOG_DEBUG, "frame type: %i\n", s->frame_type);
603     av_log(s->avctx, AV_LOG_DEBUG, "samples deficit: %i\n", s->samples_deficit);
604     av_log(s->avctx, AV_LOG_DEBUG, "crc present: %i\n", s->crc_present);
605     av_log(s->avctx, AV_LOG_DEBUG, "sample blocks: %i (%i samples)\n",
606            s->sample_blocks, s->sample_blocks * 32);
607     av_log(s->avctx, AV_LOG_DEBUG, "frame size: %i bytes\n", s->frame_size);
608     av_log(s->avctx, AV_LOG_DEBUG, "amode: %i (%i channels)\n",
609            s->amode, dca_channels[s->amode]);
610     av_log(s->avctx, AV_LOG_DEBUG, "sample rate: %i Hz\n",
611            s->sample_rate);
612     av_log(s->avctx, AV_LOG_DEBUG, "bit rate: %i bits/s\n",
613            s->bit_rate);
614     av_log(s->avctx, AV_LOG_DEBUG, "downmix: %i\n", s->downmix);
615     av_log(s->avctx, AV_LOG_DEBUG, "dynrange: %i\n", s->dynrange);
616     av_log(s->avctx, AV_LOG_DEBUG, "timestamp: %i\n", s->timestamp);
617     av_log(s->avctx, AV_LOG_DEBUG, "aux_data: %i\n", s->aux_data);
618     av_log(s->avctx, AV_LOG_DEBUG, "hdcd: %i\n", s->hdcd);
619     av_log(s->avctx, AV_LOG_DEBUG, "ext descr: %i\n", s->ext_descr);
620     av_log(s->avctx, AV_LOG_DEBUG, "ext coding: %i\n", s->ext_coding);
621     av_log(s->avctx, AV_LOG_DEBUG, "aspf: %i\n", s->aspf);
622     av_log(s->avctx, AV_LOG_DEBUG, "lfe: %i\n", s->lfe);
623     av_log(s->avctx, AV_LOG_DEBUG, "predictor history: %i\n",
624            s->predictor_history);
625     av_log(s->avctx, AV_LOG_DEBUG, "header crc: %i\n", s->header_crc);
626     av_log(s->avctx, AV_LOG_DEBUG, "multirate inter: %i\n",
627            s->multirate_inter);
628     av_log(s->avctx, AV_LOG_DEBUG, "version number: %i\n", s->version);
629     av_log(s->avctx, AV_LOG_DEBUG, "copy history: %i\n", s->copy_history);
630     av_log(s->avctx, AV_LOG_DEBUG,
631            "source pcm resolution: %i (%i bits/sample)\n",
632            s->source_pcm_res, dca_bits_per_sample[s->source_pcm_res]);
633     av_log(s->avctx, AV_LOG_DEBUG, "front sum: %i\n", s->front_sum);
634     av_log(s->avctx, AV_LOG_DEBUG, "surround sum: %i\n", s->surround_sum);
635     av_log(s->avctx, AV_LOG_DEBUG, "dialog norm: %i\n", s->dialog_norm);
636     av_log(s->avctx, AV_LOG_DEBUG, "\n");
637 #endif
638
639     /* Primary audio coding header */
640     s->subframes         = get_bits(&s->gb, 4) + 1;
641
642     return dca_parse_audio_coding_header(s, 0);
643 }
644
645
646 static inline int get_scale(GetBitContext *gb, int level, int value, int log2range)
647 {
648     if (level < 5) {
649         /* huffman encoded */
650         value += get_bitalloc(gb, &dca_scalefactor, level);
651         value = av_clip(value, 0, (1 << log2range) - 1);
652     } else if (level < 8) {
653         if (level + 1 > log2range) {
654             skip_bits(gb, level + 1 - log2range);
655             value = get_bits(gb, log2range);
656         } else {
657             value = get_bits(gb, level + 1);
658         }
659     }
660     return value;
661 }
662
663 static int dca_subframe_header(DCAContext *s, int base_channel, int block_index)
664 {
665     /* Primary audio coding side information */
666     int j, k;
667
668     if (get_bits_left(&s->gb) < 0)
669         return AVERROR_INVALIDDATA;
670
671     if (!base_channel) {
672         s->subsubframes[s->current_subframe]    = get_bits(&s->gb, 2) + 1;
673         s->partial_samples[s->current_subframe] = get_bits(&s->gb, 3);
674     }
675
676     for (j = base_channel; j < s->prim_channels; j++) {
677         for (k = 0; k < s->subband_activity[j]; k++)
678             s->prediction_mode[j][k] = get_bits(&s->gb, 1);
679     }
680
681     /* Get prediction codebook */
682     for (j = base_channel; j < s->prim_channels; j++) {
683         for (k = 0; k < s->subband_activity[j]; k++) {
684             if (s->prediction_mode[j][k] > 0) {
685                 /* (Prediction coefficient VQ address) */
686                 s->prediction_vq[j][k] = get_bits(&s->gb, 12);
687             }
688         }
689     }
690
691     /* Bit allocation index */
692     for (j = base_channel; j < s->prim_channels; j++) {
693         for (k = 0; k < s->vq_start_subband[j]; k++) {
694             if (s->bitalloc_huffman[j] == 6)
695                 s->bitalloc[j][k] = get_bits(&s->gb, 5);
696             else if (s->bitalloc_huffman[j] == 5)
697                 s->bitalloc[j][k] = get_bits(&s->gb, 4);
698             else if (s->bitalloc_huffman[j] == 7) {
699                 av_log(s->avctx, AV_LOG_ERROR,
700                        "Invalid bit allocation index\n");
701                 return AVERROR_INVALIDDATA;
702             } else {
703                 s->bitalloc[j][k] =
704                     get_bitalloc(&s->gb, &dca_bitalloc_index, s->bitalloc_huffman[j]);
705             }
706
707             if (s->bitalloc[j][k] > 26) {
708                 av_dlog(s->avctx, "bitalloc index [%i][%i] too big (%i)\n",
709                         j, k, s->bitalloc[j][k]);
710                 return AVERROR_INVALIDDATA;
711             }
712         }
713     }
714
715     /* Transition mode */
716     for (j = base_channel; j < s->prim_channels; j++) {
717         for (k = 0; k < s->subband_activity[j]; k++) {
718             s->transition_mode[j][k] = 0;
719             if (s->subsubframes[s->current_subframe] > 1 &&
720                 k < s->vq_start_subband[j] && s->bitalloc[j][k] > 0) {
721                 s->transition_mode[j][k] =
722                     get_bitalloc(&s->gb, &dca_tmode, s->transient_huffman[j]);
723             }
724         }
725     }
726
727     if (get_bits_left(&s->gb) < 0)
728         return AVERROR_INVALIDDATA;
729
730     for (j = base_channel; j < s->prim_channels; j++) {
731         const uint32_t *scale_table;
732         int scale_sum, log_size;
733
734         memset(s->scale_factor[j], 0,
735                s->subband_activity[j] * sizeof(s->scale_factor[0][0][0]) * 2);
736
737         if (s->scalefactor_huffman[j] == 6) {
738             scale_table = scale_factor_quant7;
739             log_size = 7;
740         } else {
741             scale_table = scale_factor_quant6;
742             log_size = 6;
743         }
744
745         /* When huffman coded, only the difference is encoded */
746         scale_sum = 0;
747
748         for (k = 0; k < s->subband_activity[j]; k++) {
749             if (k >= s->vq_start_subband[j] || s->bitalloc[j][k] > 0) {
750                 scale_sum = get_scale(&s->gb, s->scalefactor_huffman[j], scale_sum, log_size);
751                 s->scale_factor[j][k][0] = scale_table[scale_sum];
752             }
753
754             if (k < s->vq_start_subband[j] && s->transition_mode[j][k]) {
755                 /* Get second scale factor */
756                 scale_sum = get_scale(&s->gb, s->scalefactor_huffman[j], scale_sum, log_size);
757                 s->scale_factor[j][k][1] = scale_table[scale_sum];
758             }
759         }
760     }
761
762     /* Joint subband scale factor codebook select */
763     for (j = base_channel; j < s->prim_channels; j++) {
764         /* Transmitted only if joint subband coding enabled */
765         if (s->joint_intensity[j] > 0)
766             s->joint_huff[j] = get_bits(&s->gb, 3);
767     }
768
769     if (get_bits_left(&s->gb) < 0)
770         return AVERROR_INVALIDDATA;
771
772     /* Scale factors for joint subband coding */
773     for (j = base_channel; j < s->prim_channels; j++) {
774         int source_channel;
775
776         /* Transmitted only if joint subband coding enabled */
777         if (s->joint_intensity[j] > 0) {
778             int scale = 0;
779             source_channel = s->joint_intensity[j] - 1;
780
781             /* When huffman coded, only the difference is encoded
782              * (is this valid as well for joint scales ???) */
783
784             for (k = s->subband_activity[j]; k < s->subband_activity[source_channel]; k++) {
785                 scale = get_scale(&s->gb, s->joint_huff[j], 64 /* bias */, 7);
786                 s->joint_scale_factor[j][k] = scale;    /*joint_scale_table[scale]; */
787             }
788
789             if (!(s->debug_flag & 0x02)) {
790                 av_log(s->avctx, AV_LOG_DEBUG,
791                        "Joint stereo coding not supported\n");
792                 s->debug_flag |= 0x02;
793             }
794         }
795     }
796
797     /* Stereo downmix coefficients */
798     if (!base_channel && s->prim_channels > 2) {
799         if (s->downmix) {
800             for (j = base_channel; j < s->prim_channels; j++) {
801                 s->downmix_coef[j][0] = get_bits(&s->gb, 7);
802                 s->downmix_coef[j][1] = get_bits(&s->gb, 7);
803             }
804         } else {
805             int am = s->amode & DCA_CHANNEL_MASK;
806             if (am >= FF_ARRAY_ELEMS(dca_default_coeffs)) {
807                 av_log(s->avctx, AV_LOG_ERROR,
808                        "Invalid channel mode %d\n", am);
809                 return AVERROR_INVALIDDATA;
810             }
811             for (j = base_channel; j < s->prim_channels; j++) {
812                 s->downmix_coef[j][0] = dca_default_coeffs[am][j][0];
813                 s->downmix_coef[j][1] = dca_default_coeffs[am][j][1];
814             }
815         }
816     }
817
818     /* Dynamic range coefficient */
819     if (!base_channel && s->dynrange)
820         s->dynrange_coef = get_bits(&s->gb, 8);
821
822     /* Side information CRC check word */
823     if (s->crc_present) {
824         get_bits(&s->gb, 16);
825     }
826
827     /*
828      * Primary audio data arrays
829      */
830
831     /* VQ encoded high frequency subbands */
832     for (j = base_channel; j < s->prim_channels; j++)
833         for (k = s->vq_start_subband[j]; k < s->subband_activity[j]; k++)
834             /* 1 vector -> 32 samples */
835             s->high_freq_vq[j][k] = get_bits(&s->gb, 10);
836
837     /* Low frequency effect data */
838     if (!base_channel && s->lfe) {
839         /* LFE samples */
840         int lfe_samples = 2 * s->lfe * (4 + block_index);
841         int lfe_end_sample = 2 * s->lfe * (4 + block_index + s->subsubframes[s->current_subframe]);
842         float lfe_scale;
843
844         for (j = lfe_samples; j < lfe_end_sample; j++) {
845             /* Signed 8 bits int */
846             s->lfe_data[j] = get_sbits(&s->gb, 8);
847         }
848
849         /* Scale factor index */
850         skip_bits(&s->gb, 1);
851         s->lfe_scale_factor = scale_factor_quant7[get_bits(&s->gb, 7)];
852
853         /* Quantization step size * scale factor */
854         lfe_scale = 0.035 * s->lfe_scale_factor;
855
856         for (j = lfe_samples; j < lfe_end_sample; j++)
857             s->lfe_data[j] *= lfe_scale;
858     }
859
860 #ifdef TRACE
861     av_log(s->avctx, AV_LOG_DEBUG, "subsubframes: %i\n",
862            s->subsubframes[s->current_subframe]);
863     av_log(s->avctx, AV_LOG_DEBUG, "partial samples: %i\n",
864            s->partial_samples[s->current_subframe]);
865
866     for (j = base_channel; j < s->prim_channels; j++) {
867         av_log(s->avctx, AV_LOG_DEBUG, "prediction mode:");
868         for (k = 0; k < s->subband_activity[j]; k++)
869             av_log(s->avctx, AV_LOG_DEBUG, " %i", s->prediction_mode[j][k]);
870         av_log(s->avctx, AV_LOG_DEBUG, "\n");
871     }
872     for (j = base_channel; j < s->prim_channels; j++) {
873         for (k = 0; k < s->subband_activity[j]; k++)
874             av_log(s->avctx, AV_LOG_DEBUG,
875                    "prediction coefs: %f, %f, %f, %f\n",
876                    (float) adpcm_vb[s->prediction_vq[j][k]][0] / 8192,
877                    (float) adpcm_vb[s->prediction_vq[j][k]][1] / 8192,
878                    (float) adpcm_vb[s->prediction_vq[j][k]][2] / 8192,
879                    (float) adpcm_vb[s->prediction_vq[j][k]][3] / 8192);
880     }
881     for (j = base_channel; j < s->prim_channels; j++) {
882         av_log(s->avctx, AV_LOG_DEBUG, "bitalloc index: ");
883         for (k = 0; k < s->vq_start_subband[j]; k++)
884             av_log(s->avctx, AV_LOG_DEBUG, "%2.2i ", s->bitalloc[j][k]);
885         av_log(s->avctx, AV_LOG_DEBUG, "\n");
886     }
887     for (j = base_channel; j < s->prim_channels; j++) {
888         av_log(s->avctx, AV_LOG_DEBUG, "Transition mode:");
889         for (k = 0; k < s->subband_activity[j]; k++)
890             av_log(s->avctx, AV_LOG_DEBUG, " %i", s->transition_mode[j][k]);
891         av_log(s->avctx, AV_LOG_DEBUG, "\n");
892     }
893     for (j = base_channel; j < s->prim_channels; j++) {
894         av_log(s->avctx, AV_LOG_DEBUG, "Scale factor:");
895         for (k = 0; k < s->subband_activity[j]; k++) {
896             if (k >= s->vq_start_subband[j] || s->bitalloc[j][k] > 0)
897                 av_log(s->avctx, AV_LOG_DEBUG, " %i", s->scale_factor[j][k][0]);
898             if (k < s->vq_start_subband[j] && s->transition_mode[j][k])
899                 av_log(s->avctx, AV_LOG_DEBUG, " %i(t)", s->scale_factor[j][k][1]);
900         }
901         av_log(s->avctx, AV_LOG_DEBUG, "\n");
902     }
903     for (j = base_channel; j < s->prim_channels; j++) {
904         if (s->joint_intensity[j] > 0) {
905             int source_channel = s->joint_intensity[j] - 1;
906             av_log(s->avctx, AV_LOG_DEBUG, "Joint scale factor index:\n");
907             for (k = s->subband_activity[j]; k < s->subband_activity[source_channel]; k++)
908                 av_log(s->avctx, AV_LOG_DEBUG, " %i", s->joint_scale_factor[j][k]);
909             av_log(s->avctx, AV_LOG_DEBUG, "\n");
910         }
911     }
912     if (!base_channel && s->prim_channels > 2 && s->downmix) {
913         av_log(s->avctx, AV_LOG_DEBUG, "Downmix coeffs:\n");
914         for (j = 0; j < s->prim_channels; j++) {
915             av_log(s->avctx, AV_LOG_DEBUG, "Channel 0, %d = %f\n", j,
916                    dca_downmix_coeffs[s->downmix_coef[j][0]]);
917             av_log(s->avctx, AV_LOG_DEBUG, "Channel 1, %d = %f\n", j,
918                    dca_downmix_coeffs[s->downmix_coef[j][1]]);
919         }
920         av_log(s->avctx, AV_LOG_DEBUG, "\n");
921     }
922     for (j = base_channel; j < s->prim_channels; j++)
923         for (k = s->vq_start_subband[j]; k < s->subband_activity[j]; k++)
924             av_log(s->avctx, AV_LOG_DEBUG, "VQ index: %i\n", s->high_freq_vq[j][k]);
925     if (!base_channel && s->lfe) {
926         int lfe_samples = 2 * s->lfe * (4 + block_index);
927         int lfe_end_sample = 2 * s->lfe * (4 + block_index + s->subsubframes[s->current_subframe]);
928
929         av_log(s->avctx, AV_LOG_DEBUG, "LFE samples:\n");
930         for (j = lfe_samples; j < lfe_end_sample; j++)
931             av_log(s->avctx, AV_LOG_DEBUG, " %f", s->lfe_data[j]);
932         av_log(s->avctx, AV_LOG_DEBUG, "\n");
933     }
934 #endif
935
936     return 0;
937 }
938
939 static void qmf_32_subbands(DCAContext *s, int chans,
940                             float samples_in[32][8], float *samples_out,
941                             float scale)
942 {
943     const float *prCoeff;
944     int i;
945
946     int sb_act = s->subband_activity[chans];
947     int subindex;
948
949     scale *= sqrt(1 / 8.0);
950
951     /* Select filter */
952     if (!s->multirate_inter)    /* Non-perfect reconstruction */
953         prCoeff = fir_32bands_nonperfect;
954     else                        /* Perfect reconstruction */
955         prCoeff = fir_32bands_perfect;
956
957     for (i = sb_act; i < 32; i++)
958         s->raXin[i] = 0.0;
959
960     /* Reconstructed channel sample index */
961     for (subindex = 0; subindex < 8; subindex++) {
962         /* Load in one sample from each subband and clear inactive subbands */
963         for (i = 0; i < sb_act; i++) {
964             unsigned sign = (i - 1) & 2;
965             uint32_t v    = AV_RN32A(&samples_in[i][subindex]) ^ sign << 30;
966             AV_WN32A(&s->raXin[i], v);
967         }
968
969         s->synth.synth_filter_float(&s->imdct,
970                                     s->subband_fir_hist[chans],
971                                     &s->hist_index[chans],
972                                     s->subband_fir_noidea[chans], prCoeff,
973                                     samples_out, s->raXin, scale);
974         samples_out += 32;
975     }
976 }
977
978 static void lfe_interpolation_fir(DCAContext *s, int decimation_select,
979                                   int num_deci_sample, float *samples_in,
980                                   float *samples_out, float scale)
981 {
982     /* samples_in: An array holding decimated samples.
983      *   Samples in current subframe starts from samples_in[0],
984      *   while samples_in[-1], samples_in[-2], ..., stores samples
985      *   from last subframe as history.
986      *
987      * samples_out: An array holding interpolated samples
988      */
989
990     int decifactor;
991     const float *prCoeff;
992     int deciindex;
993
994     /* Select decimation filter */
995     if (decimation_select == 1) {
996         decifactor = 64;
997         prCoeff = lfe_fir_128;
998     } else {
999         decifactor = 32;
1000         prCoeff = lfe_fir_64;
1001     }
1002     /* Interpolation */
1003     for (deciindex = 0; deciindex < num_deci_sample; deciindex++) {
1004         s->dcadsp.lfe_fir(samples_out, samples_in, prCoeff, decifactor, scale);
1005         samples_in++;
1006         samples_out += 2 * decifactor;
1007     }
1008 }
1009
1010 /* downmixing routines */
1011 #define MIX_REAR1(samples, s1, rs, coef)            \
1012     samples[0][i] += samples[s1][i] * coef[rs][0];  \
1013     samples[1][i] += samples[s1][i] * coef[rs][1];
1014
1015 #define MIX_REAR2(samples, s1, s2, rs, coef)                                          \
1016     samples[0][i] += samples[s1][i] * coef[rs][0] + samples[s2][i] * coef[rs + 1][0]; \
1017     samples[1][i] += samples[s1][i] * coef[rs][1] + samples[s2][i] * coef[rs + 1][1];
1018
1019 #define MIX_FRONT3(samples, coef)                                      \
1020     t = samples[c][i];                                                 \
1021     u = samples[l][i];                                                 \
1022     v = samples[r][i];                                                 \
1023     samples[0][i] = t * coef[0][0] + u * coef[1][0] + v * coef[2][0];  \
1024     samples[1][i] = t * coef[0][1] + u * coef[1][1] + v * coef[2][1];
1025
1026 #define DOWNMIX_TO_STEREO(op1, op2)             \
1027     for (i = 0; i < 256; i++) {                 \
1028         op1                                     \
1029         op2                                     \
1030     }
1031
1032 static void dca_downmix(float **samples, int srcfmt,
1033                         int downmix_coef[DCA_PRIM_CHANNELS_MAX][2],
1034                         const int8_t *channel_mapping)
1035 {
1036     int c, l, r, sl, sr, s;
1037     int i;
1038     float t, u, v;
1039     float coef[DCA_PRIM_CHANNELS_MAX][2];
1040
1041     for (i = 0; i < DCA_PRIM_CHANNELS_MAX; i++) {
1042         coef[i][0] = dca_downmix_coeffs[downmix_coef[i][0]];
1043         coef[i][1] = dca_downmix_coeffs[downmix_coef[i][1]];
1044     }
1045
1046     switch (srcfmt) {
1047     case DCA_MONO:
1048     case DCA_CHANNEL:
1049     case DCA_STEREO_TOTAL:
1050     case DCA_STEREO_SUMDIFF:
1051     case DCA_4F2R:
1052         av_log(NULL, 0, "Not implemented!\n");
1053         break;
1054     case DCA_STEREO:
1055         break;
1056     case DCA_3F:
1057         c = channel_mapping[0];
1058         l = channel_mapping[1];
1059         r = channel_mapping[2];
1060         DOWNMIX_TO_STEREO(MIX_FRONT3(samples, coef), );
1061         break;
1062     case DCA_2F1R:
1063         s = channel_mapping[2];
1064         DOWNMIX_TO_STEREO(MIX_REAR1(samples, s, 2, coef), );
1065         break;
1066     case DCA_3F1R:
1067         c = channel_mapping[0];
1068         l = channel_mapping[1];
1069         r = channel_mapping[2];
1070         s = channel_mapping[3];
1071         DOWNMIX_TO_STEREO(MIX_FRONT3(samples, coef),
1072                           MIX_REAR1(samples, s, 3, coef));
1073         break;
1074     case DCA_2F2R:
1075         sl = channel_mapping[2];
1076         sr = channel_mapping[3];
1077         DOWNMIX_TO_STEREO(MIX_REAR2(samples, sl, sr, 2, coef), );
1078         break;
1079     case DCA_3F2R:
1080         c  = channel_mapping[0];
1081         l  = channel_mapping[1];
1082         r  = channel_mapping[2];
1083         sl = channel_mapping[3];
1084         sr = channel_mapping[4];
1085         DOWNMIX_TO_STEREO(MIX_FRONT3(samples, coef),
1086                           MIX_REAR2(samples, sl, sr, 3, coef));
1087         break;
1088     }
1089 }
1090
1091
1092 #ifndef decode_blockcodes
1093 /* Very compact version of the block code decoder that does not use table
1094  * look-up but is slightly slower */
1095 static int decode_blockcode(int code, int levels, int *values)
1096 {
1097     int i;
1098     int offset = (levels - 1) >> 1;
1099
1100     for (i = 0; i < 4; i++) {
1101         int div = FASTDIV(code, levels);
1102         values[i] = code - offset - div * levels;
1103         code = div;
1104     }
1105
1106     return code;
1107 }
1108
1109 static int decode_blockcodes(int code1, int code2, int levels, int *values)
1110 {
1111     return decode_blockcode(code1, levels, values) |
1112            decode_blockcode(code2, levels, values + 4);
1113 }
1114 #endif
1115
1116 static const uint8_t abits_sizes[7]  = { 7, 10, 12, 13, 15, 17, 19 };
1117 static const uint8_t abits_levels[7] = { 3,  5,  7,  9, 13, 17, 25 };
1118
1119 #ifndef int8x8_fmul_int32
1120 static inline void int8x8_fmul_int32(float *dst, const int8_t *src, int scale)
1121 {
1122     float fscale = scale / 16.0;
1123     int i;
1124     for (i = 0; i < 8; i++)
1125         dst[i] = src[i] * fscale;
1126 }
1127 #endif
1128
1129 static int dca_subsubframe(DCAContext *s, int base_channel, int block_index)
1130 {
1131     int k, l;
1132     int subsubframe = s->current_subsubframe;
1133
1134     const float *quant_step_table;
1135
1136     /* FIXME */
1137     float (*subband_samples)[DCA_SUBBANDS][8] = s->subband_samples[block_index];
1138     LOCAL_ALIGNED_16(int, block, [8]);
1139
1140     /*
1141      * Audio data
1142      */
1143
1144     /* Select quantization step size table */
1145     if (s->bit_rate_index == 0x1f)
1146         quant_step_table = lossless_quant_d;
1147     else
1148         quant_step_table = lossy_quant_d;
1149
1150     for (k = base_channel; k < s->prim_channels; k++) {
1151         if (get_bits_left(&s->gb) < 0)
1152             return AVERROR_INVALIDDATA;
1153
1154         for (l = 0; l < s->vq_start_subband[k]; l++) {
1155             int m;
1156
1157             /* Select the mid-tread linear quantizer */
1158             int abits = s->bitalloc[k][l];
1159
1160             float quant_step_size = quant_step_table[abits];
1161
1162             /*
1163              * Determine quantization index code book and its type
1164              */
1165
1166             /* Select quantization index code book */
1167             int sel = s->quant_index_huffman[k][abits];
1168
1169             /*
1170              * Extract bits from the bit stream
1171              */
1172             if (!abits) {
1173                 memset(subband_samples[k][l], 0, 8 * sizeof(subband_samples[0][0][0]));
1174             } else {
1175                 /* Deal with transients */
1176                 int sfi = s->transition_mode[k][l] && subsubframe >= s->transition_mode[k][l];
1177                 float rscale = quant_step_size * s->scale_factor[k][l][sfi] *
1178                                s->scalefactor_adj[k][sel];
1179
1180                 if (abits >= 11 || !dca_smpl_bitalloc[abits].vlc[sel].table) {
1181                     if (abits <= 7) {
1182                         /* Block code */
1183                         int block_code1, block_code2, size, levels, err;
1184
1185                         size   = abits_sizes[abits - 1];
1186                         levels = abits_levels[abits - 1];
1187
1188                         block_code1 = get_bits(&s->gb, size);
1189                         block_code2 = get_bits(&s->gb, size);
1190                         err = decode_blockcodes(block_code1, block_code2,
1191                                                 levels, block);
1192                         if (err) {
1193                             av_log(s->avctx, AV_LOG_ERROR,
1194                                    "ERROR: block code look-up failed\n");
1195                             return AVERROR_INVALIDDATA;
1196                         }
1197                     } else {
1198                         /* no coding */
1199                         for (m = 0; m < 8; m++)
1200                             block[m] = get_sbits(&s->gb, abits - 3);
1201                     }
1202                 } else {
1203                     /* Huffman coded */
1204                     for (m = 0; m < 8; m++)
1205                         block[m] = get_bitalloc(&s->gb,
1206                                                 &dca_smpl_bitalloc[abits], sel);
1207                 }
1208
1209                 s->fmt_conv.int32_to_float_fmul_scalar(subband_samples[k][l],
1210                                                        block, rscale, 8);
1211             }
1212
1213             /*
1214              * Inverse ADPCM if in prediction mode
1215              */
1216             if (s->prediction_mode[k][l]) {
1217                 int n;
1218                 for (m = 0; m < 8; m++) {
1219                     for (n = 1; n <= 4; n++)
1220                         if (m >= n)
1221                             subband_samples[k][l][m] +=
1222                                 (adpcm_vb[s->prediction_vq[k][l]][n - 1] *
1223                                  subband_samples[k][l][m - n] / 8192);
1224                         else if (s->predictor_history)
1225                             subband_samples[k][l][m] +=
1226                                 (adpcm_vb[s->prediction_vq[k][l]][n - 1] *
1227                                  s->subband_samples_hist[k][l][m - n + 4] / 8192);
1228                 }
1229             }
1230         }
1231
1232         /*
1233          * Decode VQ encoded high frequencies
1234          */
1235         for (l = s->vq_start_subband[k]; l < s->subband_activity[k]; l++) {
1236             /* 1 vector -> 32 samples but we only need the 8 samples
1237              * for this subsubframe. */
1238             int hfvq = s->high_freq_vq[k][l];
1239
1240             if (!s->debug_flag & 0x01) {
1241                 av_log(s->avctx, AV_LOG_DEBUG,
1242                        "Stream with high frequencies VQ coding\n");
1243                 s->debug_flag |= 0x01;
1244             }
1245
1246             int8x8_fmul_int32(subband_samples[k][l],
1247                               &high_freq_vq[hfvq][subsubframe * 8],
1248                               s->scale_factor[k][l][0]);
1249         }
1250     }
1251
1252     /* Check for DSYNC after subsubframe */
1253     if (s->aspf || subsubframe == s->subsubframes[s->current_subframe] - 1) {
1254         if (0xFFFF == get_bits(&s->gb, 16)) {   /* 0xFFFF */
1255 #ifdef TRACE
1256             av_log(s->avctx, AV_LOG_DEBUG, "Got subframe DSYNC\n");
1257 #endif
1258         } else {
1259             av_log(s->avctx, AV_LOG_ERROR, "Didn't get subframe DSYNC\n");
1260         }
1261     }
1262
1263     /* Backup predictor history for adpcm */
1264     for (k = base_channel; k < s->prim_channels; k++)
1265         for (l = 0; l < s->vq_start_subband[k]; l++)
1266             memcpy(s->subband_samples_hist[k][l],
1267                    &subband_samples[k][l][4],
1268                    4 * sizeof(subband_samples[0][0][0]));
1269
1270     return 0;
1271 }
1272
1273 static int dca_filter_channels(DCAContext *s, int block_index)
1274 {
1275     float (*subband_samples)[DCA_SUBBANDS][8] = s->subband_samples[block_index];
1276     int k;
1277
1278     /* 32 subbands QMF */
1279     for (k = 0; k < s->prim_channels; k++) {
1280 /*        static float pcm_to_double[8] = { 32768.0, 32768.0, 524288.0, 524288.0,
1281                                             0, 8388608.0, 8388608.0 };*/
1282         if (s->channel_order_tab[k] >= 0)
1283             qmf_32_subbands(s, k, subband_samples[k],
1284                             s->samples_chanptr[s->channel_order_tab[k]],
1285                             M_SQRT1_2 / 32768.0 /* pcm_to_double[s->source_pcm_res] */);
1286     }
1287
1288     /* Down mixing */
1289     if (s->avctx->request_channels == 2 && s->prim_channels > 2) {
1290         dca_downmix(s->samples_chanptr, s->amode, s->downmix_coef, s->channel_order_tab);
1291     }
1292
1293     /* Generate LFE samples for this subsubframe FIXME!!! */
1294     if (s->output & DCA_LFE) {
1295         lfe_interpolation_fir(s, s->lfe, 2 * s->lfe,
1296                               s->lfe_data + 2 * s->lfe * (block_index + 4),
1297                               s->samples_chanptr[dca_lfe_index[s->amode]],
1298                               1.0 / (256.0 * 32768.0));
1299         /* Outputs 20bits pcm samples */
1300     }
1301
1302     return 0;
1303 }
1304
1305
1306 static int dca_subframe_footer(DCAContext *s, int base_channel)
1307 {
1308     int aux_data_count = 0, i;
1309
1310     /*
1311      * Unpack optional information
1312      */
1313
1314     /* presumably optional information only appears in the core? */
1315     if (!base_channel) {
1316         if (s->timestamp)
1317             skip_bits_long(&s->gb, 32);
1318
1319         if (s->aux_data)
1320             aux_data_count = get_bits(&s->gb, 6);
1321
1322         for (i = 0; i < aux_data_count; i++)
1323             get_bits(&s->gb, 8);
1324
1325         if (s->crc_present && (s->downmix || s->dynrange))
1326             get_bits(&s->gb, 16);
1327     }
1328
1329     return 0;
1330 }
1331
1332 /**
1333  * Decode a dca frame block
1334  *
1335  * @param s     pointer to the DCAContext
1336  */
1337
1338 static int dca_decode_block(DCAContext *s, int base_channel, int block_index)
1339 {
1340     int ret;
1341
1342     /* Sanity check */
1343     if (s->current_subframe >= s->subframes) {
1344         av_log(s->avctx, AV_LOG_DEBUG, "check failed: %i>%i",
1345                s->current_subframe, s->subframes);
1346         return AVERROR_INVALIDDATA;
1347     }
1348
1349     if (!s->current_subsubframe) {
1350 #ifdef TRACE
1351         av_log(s->avctx, AV_LOG_DEBUG, "DSYNC dca_subframe_header\n");
1352 #endif
1353         /* Read subframe header */
1354         if ((ret = dca_subframe_header(s, base_channel, block_index)))
1355             return ret;
1356     }
1357
1358     /* Read subsubframe */
1359 #ifdef TRACE
1360     av_log(s->avctx, AV_LOG_DEBUG, "DSYNC dca_subsubframe\n");
1361 #endif
1362     if ((ret = dca_subsubframe(s, base_channel, block_index)))
1363         return ret;
1364
1365     /* Update state */
1366     s->current_subsubframe++;
1367     if (s->current_subsubframe >= s->subsubframes[s->current_subframe]) {
1368         s->current_subsubframe = 0;
1369         s->current_subframe++;
1370     }
1371     if (s->current_subframe >= s->subframes) {
1372 #ifdef TRACE
1373         av_log(s->avctx, AV_LOG_DEBUG, "DSYNC dca_subframe_footer\n");
1374 #endif
1375         /* Read subframe footer */
1376         if ((ret = dca_subframe_footer(s, base_channel)))
1377             return ret;
1378     }
1379
1380     return 0;
1381 }
1382
1383 /**
1384  * Return the number of channels in an ExSS speaker mask (HD)
1385  */
1386 static int dca_exss_mask2count(int mask)
1387 {
1388     /* count bits that mean speaker pairs twice */
1389     return av_popcount(mask) +
1390            av_popcount(mask & (DCA_EXSS_CENTER_LEFT_RIGHT      |
1391                                DCA_EXSS_FRONT_LEFT_RIGHT       |
1392                                DCA_EXSS_FRONT_HIGH_LEFT_RIGHT  |
1393                                DCA_EXSS_WIDE_LEFT_RIGHT        |
1394                                DCA_EXSS_SIDE_LEFT_RIGHT        |
1395                                DCA_EXSS_SIDE_HIGH_LEFT_RIGHT   |
1396                                DCA_EXSS_SIDE_REAR_LEFT_RIGHT   |
1397                                DCA_EXSS_REAR_LEFT_RIGHT        |
1398                                DCA_EXSS_REAR_HIGH_LEFT_RIGHT));
1399 }
1400
1401 /**
1402  * Skip mixing coefficients of a single mix out configuration (HD)
1403  */
1404 static void dca_exss_skip_mix_coeffs(GetBitContext *gb, int channels, int out_ch)
1405 {
1406     int i;
1407
1408     for (i = 0; i < channels; i++) {
1409         int mix_map_mask = get_bits(gb, out_ch);
1410         int num_coeffs = av_popcount(mix_map_mask);
1411         skip_bits_long(gb, num_coeffs * 6);
1412     }
1413 }
1414
1415 /**
1416  * Parse extension substream asset header (HD)
1417  */
1418 static int dca_exss_parse_asset_header(DCAContext *s)
1419 {
1420     int header_pos = get_bits_count(&s->gb);
1421     int header_size;
1422     int channels;
1423     int embedded_stereo = 0;
1424     int embedded_6ch    = 0;
1425     int drc_code_present;
1426     int extensions_mask;
1427     int i, j;
1428
1429     if (get_bits_left(&s->gb) < 16)
1430         return -1;
1431
1432     /* We will parse just enough to get to the extensions bitmask with which
1433      * we can set the profile value. */
1434
1435     header_size = get_bits(&s->gb, 9) + 1;
1436     skip_bits(&s->gb, 3); // asset index
1437
1438     if (s->static_fields) {
1439         if (get_bits1(&s->gb))
1440             skip_bits(&s->gb, 4); // asset type descriptor
1441         if (get_bits1(&s->gb))
1442             skip_bits_long(&s->gb, 24); // language descriptor
1443
1444         if (get_bits1(&s->gb)) {
1445             /* How can one fit 1024 bytes of text here if the maximum value
1446              * for the asset header size field above was 512 bytes? */
1447             int text_length = get_bits(&s->gb, 10) + 1;
1448             if (get_bits_left(&s->gb) < text_length * 8)
1449                 return -1;
1450             skip_bits_long(&s->gb, text_length * 8); // info text
1451         }
1452
1453         skip_bits(&s->gb, 5); // bit resolution - 1
1454         skip_bits(&s->gb, 4); // max sample rate code
1455         channels = get_bits(&s->gb, 8) + 1;
1456
1457         if (get_bits1(&s->gb)) { // 1-to-1 channels to speakers
1458             int spkr_remap_sets;
1459             int spkr_mask_size = 16;
1460             int num_spkrs[7];
1461
1462             if (channels > 2)
1463                 embedded_stereo = get_bits1(&s->gb);
1464             if (channels > 6)
1465                 embedded_6ch = get_bits1(&s->gb);
1466
1467             if (get_bits1(&s->gb)) {
1468                 spkr_mask_size = (get_bits(&s->gb, 2) + 1) << 2;
1469                 skip_bits(&s->gb, spkr_mask_size); // spkr activity mask
1470             }
1471
1472             spkr_remap_sets = get_bits(&s->gb, 3);
1473
1474             for (i = 0; i < spkr_remap_sets; i++) {
1475                 /* std layout mask for each remap set */
1476                 num_spkrs[i] = dca_exss_mask2count(get_bits(&s->gb, spkr_mask_size));
1477             }
1478
1479             for (i = 0; i < spkr_remap_sets; i++) {
1480                 int num_dec_ch_remaps = get_bits(&s->gb, 5) + 1;
1481                 if (get_bits_left(&s->gb) < 0)
1482                     return -1;
1483
1484                 for (j = 0; j < num_spkrs[i]; j++) {
1485                     int remap_dec_ch_mask = get_bits_long(&s->gb, num_dec_ch_remaps);
1486                     int num_dec_ch = av_popcount(remap_dec_ch_mask);
1487                     skip_bits_long(&s->gb, num_dec_ch * 5); // remap codes
1488                 }
1489             }
1490
1491         } else {
1492             skip_bits(&s->gb, 3); // representation type
1493         }
1494     }
1495
1496     drc_code_present = get_bits1(&s->gb);
1497     if (drc_code_present)
1498         get_bits(&s->gb, 8); // drc code
1499
1500     if (get_bits1(&s->gb))
1501         skip_bits(&s->gb, 5); // dialog normalization code
1502
1503     if (drc_code_present && embedded_stereo)
1504         get_bits(&s->gb, 8); // drc stereo code
1505
1506     if (s->mix_metadata && get_bits1(&s->gb)) {
1507         skip_bits(&s->gb, 1); // external mix
1508         skip_bits(&s->gb, 6); // post mix gain code
1509
1510         if (get_bits(&s->gb, 2) != 3) // mixer drc code
1511             skip_bits(&s->gb, 3); // drc limit
1512         else
1513             skip_bits(&s->gb, 8); // custom drc code
1514
1515         if (get_bits1(&s->gb)) // channel specific scaling
1516             for (i = 0; i < s->num_mix_configs; i++)
1517                 skip_bits_long(&s->gb, s->mix_config_num_ch[i] * 6); // scale codes
1518         else
1519             skip_bits_long(&s->gb, s->num_mix_configs * 6); // scale codes
1520
1521         for (i = 0; i < s->num_mix_configs; i++) {
1522             if (get_bits_left(&s->gb) < 0)
1523                 return -1;
1524             dca_exss_skip_mix_coeffs(&s->gb, channels, s->mix_config_num_ch[i]);
1525             if (embedded_6ch)
1526                 dca_exss_skip_mix_coeffs(&s->gb, 6, s->mix_config_num_ch[i]);
1527             if (embedded_stereo)
1528                 dca_exss_skip_mix_coeffs(&s->gb, 2, s->mix_config_num_ch[i]);
1529         }
1530     }
1531
1532     switch (get_bits(&s->gb, 2)) {
1533     case 0: extensions_mask = get_bits(&s->gb, 12); break;
1534     case 1: extensions_mask = DCA_EXT_EXSS_XLL;     break;
1535     case 2: extensions_mask = DCA_EXT_EXSS_LBR;     break;
1536     case 3: extensions_mask = 0; /* aux coding */   break;
1537     }
1538
1539     /* not parsed further, we were only interested in the extensions mask */
1540
1541     if (get_bits_left(&s->gb) < 0)
1542         return -1;
1543
1544     if (get_bits_count(&s->gb) - header_pos > header_size * 8) {
1545         av_log(s->avctx, AV_LOG_WARNING, "Asset header size mismatch.\n");
1546         return -1;
1547     }
1548     skip_bits_long(&s->gb, header_pos + header_size * 8 - get_bits_count(&s->gb));
1549
1550     if (extensions_mask & DCA_EXT_EXSS_XLL)
1551         s->profile = FF_PROFILE_DTS_HD_MA;
1552     else if (extensions_mask & (DCA_EXT_EXSS_XBR | DCA_EXT_EXSS_X96 |
1553                                 DCA_EXT_EXSS_XXCH))
1554         s->profile = FF_PROFILE_DTS_HD_HRA;
1555
1556     if (!(extensions_mask & DCA_EXT_CORE))
1557         av_log(s->avctx, AV_LOG_WARNING, "DTS core detection mismatch.\n");
1558     if ((extensions_mask & DCA_CORE_EXTS) != s->core_ext_mask)
1559         av_log(s->avctx, AV_LOG_WARNING,
1560                "DTS extensions detection mismatch (%d, %d)\n",
1561                extensions_mask & DCA_CORE_EXTS, s->core_ext_mask);
1562
1563     return 0;
1564 }
1565
1566 /**
1567  * Parse extension substream header (HD)
1568  */
1569 static void dca_exss_parse_header(DCAContext *s)
1570 {
1571     int ss_index;
1572     int blownup;
1573     int num_audiop = 1;
1574     int num_assets = 1;
1575     int active_ss_mask[8];
1576     int i, j;
1577
1578     if (get_bits_left(&s->gb) < 52)
1579         return;
1580
1581     skip_bits(&s->gb, 8); // user data
1582     ss_index = get_bits(&s->gb, 2);
1583
1584     blownup = get_bits1(&s->gb);
1585     skip_bits(&s->gb,  8 + 4 * blownup); // header_size
1586     skip_bits(&s->gb, 16 + 4 * blownup); // hd_size
1587
1588     s->static_fields = get_bits1(&s->gb);
1589     if (s->static_fields) {
1590         skip_bits(&s->gb, 2); // reference clock code
1591         skip_bits(&s->gb, 3); // frame duration code
1592
1593         if (get_bits1(&s->gb))
1594             skip_bits_long(&s->gb, 36); // timestamp
1595
1596         /* a single stream can contain multiple audio assets that can be
1597          * combined to form multiple audio presentations */
1598
1599         num_audiop = get_bits(&s->gb, 3) + 1;
1600         if (num_audiop > 1) {
1601             av_log_ask_for_sample(s->avctx, "Multiple DTS-HD audio presentations.");
1602             /* ignore such streams for now */
1603             return;
1604         }
1605
1606         num_assets = get_bits(&s->gb, 3) + 1;
1607         if (num_assets > 1) {
1608             av_log_ask_for_sample(s->avctx, "Multiple DTS-HD audio assets.");
1609             /* ignore such streams for now */
1610             return;
1611         }
1612
1613         for (i = 0; i < num_audiop; i++)
1614             active_ss_mask[i] = get_bits(&s->gb, ss_index + 1);
1615
1616         for (i = 0; i < num_audiop; i++)
1617             for (j = 0; j <= ss_index; j++)
1618                 if (active_ss_mask[i] & (1 << j))
1619                     skip_bits(&s->gb, 8); // active asset mask
1620
1621         s->mix_metadata = get_bits1(&s->gb);
1622         if (s->mix_metadata) {
1623             int mix_out_mask_size;
1624
1625             skip_bits(&s->gb, 2); // adjustment level
1626             mix_out_mask_size  = (get_bits(&s->gb, 2) + 1) << 2;
1627             s->num_mix_configs =  get_bits(&s->gb, 2) + 1;
1628
1629             for (i = 0; i < s->num_mix_configs; i++) {
1630                 int mix_out_mask        = get_bits(&s->gb, mix_out_mask_size);
1631                 s->mix_config_num_ch[i] = dca_exss_mask2count(mix_out_mask);
1632             }
1633         }
1634     }
1635
1636     for (i = 0; i < num_assets; i++)
1637         skip_bits_long(&s->gb, 16 + 4 * blownup);  // asset size
1638
1639     for (i = 0; i < num_assets; i++) {
1640         if (dca_exss_parse_asset_header(s))
1641             return;
1642     }
1643
1644     /* not parsed further, we were only interested in the extensions mask
1645      * from the asset header */
1646 }
1647
1648 /**
1649  * Main frame decoding function
1650  * FIXME add arguments
1651  */
1652 static int dca_decode_frame(AVCodecContext *avctx, void *data,
1653                             int *got_frame_ptr, AVPacket *avpkt)
1654 {
1655     AVFrame *frame     = data;
1656     const uint8_t *buf = avpkt->data;
1657     int buf_size = avpkt->size;
1658
1659     int lfe_samples;
1660     int num_core_channels = 0;
1661     int i, ret;
1662     float  **samples_flt;
1663     DCAContext *s = avctx->priv_data;
1664     int channels, full_channels;
1665     int core_ss_end;
1666
1667
1668     s->xch_present = 0;
1669
1670     s->dca_buffer_size = ff_dca_convert_bitstream(buf, buf_size, s->dca_buffer,
1671                                                   DCA_MAX_FRAME_SIZE + DCA_MAX_EXSS_HEADER_SIZE);
1672     if (s->dca_buffer_size == AVERROR_INVALIDDATA) {
1673         av_log(avctx, AV_LOG_ERROR, "Not a valid DCA frame\n");
1674         return AVERROR_INVALIDDATA;
1675     }
1676
1677     init_get_bits(&s->gb, s->dca_buffer, s->dca_buffer_size * 8);
1678     if ((ret = dca_parse_frame_header(s)) < 0) {
1679         //seems like the frame is corrupt, try with the next one
1680         return ret;
1681     }
1682     //set AVCodec values with parsed data
1683     avctx->sample_rate = s->sample_rate;
1684     avctx->bit_rate    = s->bit_rate;
1685
1686     s->profile = FF_PROFILE_DTS;
1687
1688     for (i = 0; i < (s->sample_blocks / 8); i++) {
1689         if ((ret = dca_decode_block(s, 0, i))) {
1690             av_log(avctx, AV_LOG_ERROR, "error decoding block\n");
1691             return ret;
1692         }
1693     }
1694
1695     /* record number of core channels incase less than max channels are requested */
1696     num_core_channels = s->prim_channels;
1697
1698     if (s->ext_coding)
1699         s->core_ext_mask = dca_ext_audio_descr_mask[s->ext_descr];
1700     else
1701         s->core_ext_mask = 0;
1702
1703     core_ss_end = FFMIN(s->frame_size, s->dca_buffer_size) * 8;
1704
1705     /* only scan for extensions if ext_descr was unknown or indicated a
1706      * supported XCh extension */
1707     if (s->core_ext_mask < 0 || s->core_ext_mask & DCA_EXT_XCH) {
1708
1709         /* if ext_descr was unknown, clear s->core_ext_mask so that the
1710          * extensions scan can fill it up */
1711         s->core_ext_mask = FFMAX(s->core_ext_mask, 0);
1712
1713         /* extensions start at 32-bit boundaries into bitstream */
1714         skip_bits_long(&s->gb, (-get_bits_count(&s->gb)) & 31);
1715
1716         while (core_ss_end - get_bits_count(&s->gb) >= 32) {
1717             uint32_t bits = get_bits_long(&s->gb, 32);
1718
1719             switch (bits) {
1720             case 0x5a5a5a5a: {
1721                 int ext_amode, xch_fsize;
1722
1723                 s->xch_base_channel = s->prim_channels;
1724
1725                 /* validate sync word using XCHFSIZE field */
1726                 xch_fsize = show_bits(&s->gb, 10);
1727                 if ((s->frame_size != (get_bits_count(&s->gb) >> 3) - 4 + xch_fsize) &&
1728                     (s->frame_size != (get_bits_count(&s->gb) >> 3) - 4 + xch_fsize + 1))
1729                     continue;
1730
1731                 /* skip length-to-end-of-frame field for the moment */
1732                 skip_bits(&s->gb, 10);
1733
1734                 s->core_ext_mask |= DCA_EXT_XCH;
1735
1736                 /* extension amode(number of channels in extension) should be 1 */
1737                 /* AFAIK XCh is not used for more channels */
1738                 if ((ext_amode = get_bits(&s->gb, 4)) != 1) {
1739                     av_log(avctx, AV_LOG_ERROR, "XCh extension amode %d not"
1740                            " supported!\n", ext_amode);
1741                     continue;
1742                 }
1743
1744                 /* much like core primary audio coding header */
1745                 dca_parse_audio_coding_header(s, s->xch_base_channel);
1746
1747                 for (i = 0; i < (s->sample_blocks / 8); i++)
1748                     if ((ret = dca_decode_block(s, s->xch_base_channel, i))) {
1749                         av_log(avctx, AV_LOG_ERROR, "error decoding XCh extension\n");
1750                         continue;
1751                     }
1752
1753                 s->xch_present = 1;
1754                 break;
1755             }
1756             case 0x47004a03:
1757                 /* XXCh: extended channels */
1758                 /* usually found either in core or HD part in DTS-HD HRA streams,
1759                  * but not in DTS-ES which contains XCh extensions instead */
1760                 s->core_ext_mask |= DCA_EXT_XXCH;
1761                 break;
1762
1763             case 0x1d95f262: {
1764                 int fsize96 = show_bits(&s->gb, 12) + 1;
1765                 if (s->frame_size != (get_bits_count(&s->gb) >> 3) - 4 + fsize96)
1766                     continue;
1767
1768                 av_log(avctx, AV_LOG_DEBUG, "X96 extension found at %d bits\n",
1769                        get_bits_count(&s->gb));
1770                 skip_bits(&s->gb, 12);
1771                 av_log(avctx, AV_LOG_DEBUG, "FSIZE96 = %d bytes\n", fsize96);
1772                 av_log(avctx, AV_LOG_DEBUG, "REVNO = %d\n", get_bits(&s->gb, 4));
1773
1774                 s->core_ext_mask |= DCA_EXT_X96;
1775                 break;
1776             }
1777             }
1778
1779             skip_bits_long(&s->gb, (-get_bits_count(&s->gb)) & 31);
1780         }
1781     } else {
1782         /* no supported extensions, skip the rest of the core substream */
1783         skip_bits_long(&s->gb, core_ss_end - get_bits_count(&s->gb));
1784     }
1785
1786     if (s->core_ext_mask & DCA_EXT_X96)
1787         s->profile = FF_PROFILE_DTS_96_24;
1788     else if (s->core_ext_mask & (DCA_EXT_XCH | DCA_EXT_XXCH))
1789         s->profile = FF_PROFILE_DTS_ES;
1790
1791     /* check for ExSS (HD part) */
1792     if (s->dca_buffer_size - s->frame_size > 32 &&
1793         get_bits_long(&s->gb, 32) == DCA_HD_MARKER)
1794         dca_exss_parse_header(s);
1795
1796     avctx->profile = s->profile;
1797
1798     full_channels = channels = s->prim_channels + !!s->lfe;
1799
1800     if (s->amode < 16) {
1801         avctx->channel_layout = dca_core_channel_layout[s->amode];
1802
1803         if (s->xch_present && (!avctx->request_channels ||
1804                                avctx->request_channels > num_core_channels + !!s->lfe)) {
1805             avctx->channel_layout |= AV_CH_BACK_CENTER;
1806             if (s->lfe) {
1807                 avctx->channel_layout |= AV_CH_LOW_FREQUENCY;
1808                 s->channel_order_tab = dca_channel_reorder_lfe_xch[s->amode];
1809             } else {
1810                 s->channel_order_tab = dca_channel_reorder_nolfe_xch[s->amode];
1811             }
1812         } else {
1813             channels = num_core_channels + !!s->lfe;
1814             s->xch_present = 0; /* disable further xch processing */
1815             if (s->lfe) {
1816                 avctx->channel_layout |= AV_CH_LOW_FREQUENCY;
1817                 s->channel_order_tab = dca_channel_reorder_lfe[s->amode];
1818             } else
1819                 s->channel_order_tab = dca_channel_reorder_nolfe[s->amode];
1820         }
1821
1822         if (channels > !!s->lfe &&
1823             s->channel_order_tab[channels - 1 - !!s->lfe] < 0)
1824             return AVERROR_INVALIDDATA;
1825
1826         if (avctx->request_channels == 2 && s->prim_channels > 2) {
1827             channels = 2;
1828             s->output = DCA_STEREO;
1829             avctx->channel_layout = AV_CH_LAYOUT_STEREO;
1830         }
1831     } else {
1832         av_log(avctx, AV_LOG_ERROR, "Non standard configuration %d !\n", s->amode);
1833         return AVERROR_INVALIDDATA;
1834     }
1835     avctx->channels = channels;
1836
1837     /* get output buffer */
1838     frame->nb_samples = 256 * (s->sample_blocks / 8);
1839     if ((ret = ff_get_buffer(avctx, frame)) < 0) {
1840         av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
1841         return ret;
1842     }
1843     samples_flt = (float **)frame->extended_data;
1844
1845     /* allocate buffer for extra channels if downmixing */
1846     if (avctx->channels < full_channels) {
1847         ret = av_samples_get_buffer_size(NULL, full_channels - channels,
1848                                          frame->nb_samples,
1849                                          avctx->sample_fmt, 0);
1850         if (ret < 0)
1851             return ret;
1852
1853         av_fast_malloc(&s->extra_channels_buffer,
1854                        &s->extra_channels_buffer_size, ret);
1855         if (!s->extra_channels_buffer)
1856             return AVERROR(ENOMEM);
1857
1858         ret = av_samples_fill_arrays((uint8_t **)s->extra_channels, NULL,
1859                                      s->extra_channels_buffer,
1860                                      full_channels - channels,
1861                                      frame->nb_samples, avctx->sample_fmt, 0);
1862         if (ret < 0)
1863             return ret;
1864     }
1865
1866     /* filter to get final output */
1867     for (i = 0; i < (s->sample_blocks / 8); i++) {
1868         int ch;
1869
1870         for (ch = 0; ch < channels; ch++)
1871             s->samples_chanptr[ch] = samples_flt[ch] + i * 256;
1872         for (; ch < full_channels; ch++)
1873             s->samples_chanptr[ch] = s->extra_channels[ch - channels] + i * 256;
1874
1875         dca_filter_channels(s, i);
1876
1877         /* If this was marked as a DTS-ES stream we need to subtract back- */
1878         /* channel from SL & SR to remove matrixed back-channel signal */
1879         if ((s->source_pcm_res & 1) && s->xch_present) {
1880             float *back_chan = s->samples_chanptr[s->channel_order_tab[s->xch_base_channel]];
1881             float *lt_chan   = s->samples_chanptr[s->channel_order_tab[s->xch_base_channel - 2]];
1882             float *rt_chan   = s->samples_chanptr[s->channel_order_tab[s->xch_base_channel - 1]];
1883             s->fdsp.vector_fmac_scalar(lt_chan, back_chan, -M_SQRT1_2, 256);
1884             s->fdsp.vector_fmac_scalar(rt_chan, back_chan, -M_SQRT1_2, 256);
1885         }
1886     }
1887
1888     /* update lfe history */
1889     lfe_samples = 2 * s->lfe * (s->sample_blocks / 8);
1890     for (i = 0; i < 2 * s->lfe * 4; i++)
1891         s->lfe_data[i] = s->lfe_data[i + lfe_samples];
1892
1893     *got_frame_ptr = 1;
1894
1895     return buf_size;
1896 }
1897
1898
1899
1900 /**
1901  * DCA initialization
1902  *
1903  * @param avctx     pointer to the AVCodecContext
1904  */
1905
1906 static av_cold int dca_decode_init(AVCodecContext *avctx)
1907 {
1908     DCAContext *s = avctx->priv_data;
1909
1910     s->avctx = avctx;
1911     dca_init_vlcs();
1912
1913     avpriv_float_dsp_init(&s->fdsp, avctx->flags & CODEC_FLAG_BITEXACT);
1914     ff_mdct_init(&s->imdct, 6, 1, 1.0);
1915     ff_synth_filter_init(&s->synth);
1916     ff_dcadsp_init(&s->dcadsp);
1917     ff_fmt_convert_init(&s->fmt_conv, avctx);
1918
1919     avctx->sample_fmt = AV_SAMPLE_FMT_FLTP;
1920
1921     /* allow downmixing to stereo */
1922     if (avctx->channels > 0 && avctx->request_channels < avctx->channels &&
1923         avctx->request_channels == 2) {
1924         avctx->channels = avctx->request_channels;
1925     }
1926
1927     return 0;
1928 }
1929
1930 static av_cold int dca_decode_end(AVCodecContext *avctx)
1931 {
1932     DCAContext *s = avctx->priv_data;
1933     ff_mdct_end(&s->imdct);
1934     av_freep(&s->extra_channels_buffer);
1935     return 0;
1936 }
1937
1938 static const AVProfile profiles[] = {
1939     { FF_PROFILE_DTS,        "DTS"        },
1940     { FF_PROFILE_DTS_ES,     "DTS-ES"     },
1941     { FF_PROFILE_DTS_96_24,  "DTS 96/24"  },
1942     { FF_PROFILE_DTS_HD_HRA, "DTS-HD HRA" },
1943     { FF_PROFILE_DTS_HD_MA,  "DTS-HD MA"  },
1944     { FF_PROFILE_UNKNOWN },
1945 };
1946
1947 AVCodec ff_dca_decoder = {
1948     .name            = "dca",
1949     .type            = AVMEDIA_TYPE_AUDIO,
1950     .id              = AV_CODEC_ID_DTS,
1951     .priv_data_size  = sizeof(DCAContext),
1952     .init            = dca_decode_init,
1953     .decode          = dca_decode_frame,
1954     .close           = dca_decode_end,
1955     .long_name       = NULL_IF_CONFIG_SMALL("DCA (DTS Coherent Acoustics)"),
1956     .capabilities    = CODEC_CAP_CHANNEL_CONF | CODEC_CAP_DR1,
1957     .sample_fmts     = (const enum AVSampleFormat[]) { AV_SAMPLE_FMT_FLTP,
1958                                                        AV_SAMPLE_FMT_NONE },
1959     .profiles        = NULL_IF_CONFIG_SMALL(profiles),
1960 };