annotate atrac3.c @ 10483:afad312b9989 libavcodec

Implement AMR gain function that is used by both AMR and SIPR. Based on AMR SoC code by Robert Swain and Colin McQuillan.
author vitor
date Sat, 31 Oct 2009 02:02:30 +0000
parents 77eea98ffac3
children 34a65026fa06
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1 /*
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
2 * Atrac 3 compatible decoder
6844
94dc0de175d9 Update copyright and text
banan
parents: 6843
diff changeset
3 * Copyright (c) 2006-2008 Maxim Poliakovski
94dc0de175d9 Update copyright and text
banan
parents: 6843
diff changeset
4 * Copyright (c) 2006-2008 Benjamin Larsson
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
5 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
6 * This file is part of FFmpeg.
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
7 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
8 * FFmpeg is free software; you can redistribute it and/or
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
9 * modify it under the terms of the GNU Lesser General Public
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
10 * License as published by the Free Software Foundation; either
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
11 * version 2.1 of the License, or (at your option) any later version.
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
12 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
13 * FFmpeg is distributed in the hope that it will be useful,
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
16 * Lesser General Public License for more details.
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
17 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
18 * You should have received a copy of the GNU Lesser General Public
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
19 * License along with FFmpeg; if not, write to the Free Software
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
21 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
22
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
23 /**
8718
e9d9d946f213 Use full internal pathname in doxygen @file directives.
diego
parents: 7987
diff changeset
24 * @file libavcodec/atrac3.c
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
25 * Atrac 3 compatible decoder.
6844
94dc0de175d9 Update copyright and text
banan
parents: 6843
diff changeset
26 * This decoder handles Sony's ATRAC3 data.
94dc0de175d9 Update copyright and text
banan
parents: 6843
diff changeset
27 *
94dc0de175d9 Update copyright and text
banan
parents: 6843
diff changeset
28 * Container formats used to store atrac 3 data:
94dc0de175d9 Update copyright and text
banan
parents: 6843
diff changeset
29 * RealMedia (.rm), RIFF WAV (.wav, .at3), Sony OpenMG (.oma, .aa3).
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
30 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
31 * To use this decoder, a calling application must supply the extradata
6844
94dc0de175d9 Update copyright and text
banan
parents: 6843
diff changeset
32 * bytes provided in the containers above.
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
33 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
34
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
35 #include <math.h>
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
36 #include <stddef.h>
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
37 #include <stdio.h>
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
38
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
39 #include "avcodec.h"
9428
0dce4fe6e6f3 Rename bitstream.h to get_bits.h.
stefano
parents: 9355
diff changeset
40 #include "get_bits.h"
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
41 #include "dsputil.h"
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
42 #include "bytestream.h"
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
43
10150
29cedcc646fe Split out common routines needed in the atrac1 decoder from atrac3.c to atrac.c.
banan
parents: 9667
diff changeset
44 #include "atrac.h"
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
45 #include "atrac3data.h"
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
46
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
47 #define JOINT_STEREO 0x12
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
48 #define STEREO 0x2
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
49
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
50
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
51 /* These structures are needed to store the parsed gain control data. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
52 typedef struct {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
53 int num_gain_data;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
54 int levcode[8];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
55 int loccode[8];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
56 } gain_info;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
57
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
58 typedef struct {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
59 gain_info gBlock[4];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
60 } gain_block;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
61
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
62 typedef struct {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
63 int pos;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
64 int numCoefs;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
65 float coef[8];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
66 } tonal_component;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
67
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
68 typedef struct {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
69 int bandsCoded;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
70 int numComponents;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
71 tonal_component components[64];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
72 float prevFrame[1024];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
73 int gcBlkSwitch;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
74 gain_block gainBlock[2];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
75
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
76 DECLARE_ALIGNED_16(float, spectrum[1024]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
77 DECLARE_ALIGNED_16(float, IMDCT_buf[1024]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
78
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
79 float delayBuf1[46]; ///<qmf delay buffers
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
80 float delayBuf2[46];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
81 float delayBuf3[46];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
82 } channel_unit;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
83
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
84 typedef struct {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
85 GetBitContext gb;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
86 //@{
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
87 /** stream data */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
88 int channels;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
89 int codingMode;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
90 int bit_rate;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
91 int sample_rate;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
92 int samples_per_channel;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
93 int samples_per_frame;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
94
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
95 int bits_per_frame;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
96 int bytes_per_frame;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
97 int pBs;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
98 channel_unit* pUnits;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
99 //@}
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
100 //@{
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
101 /** joint-stereo related variables */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
102 int matrix_coeff_index_prev[4];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
103 int matrix_coeff_index_now[4];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
104 int matrix_coeff_index_next[4];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
105 int weighting_delay[6];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
106 //@}
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
107 //@{
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
108 /** data buffers */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
109 float outSamples[2048];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
110 uint8_t* decoded_bytes_buffer;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
111 float tempBuf[1070];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
112 //@}
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
113 //@{
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
114 /** extradata */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
115 int atrac3version;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
116 int delay;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
117 int scrambled_stream;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
118 int frame_factor;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
119 //@}
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
120 } ATRAC3Context;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
121
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
122 static DECLARE_ALIGNED_16(float,mdct_window[512]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
123 static VLC spectral_coeff_tab[7];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
124 static float gain_tab1[16];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
125 static float gain_tab2[31];
10199
38ab367d4231 Merge FFTContext and MDCTContext
mru
parents: 10156
diff changeset
126 static FFTContext mdct_ctx;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
127 static DSPContext dsp;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
128
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
129
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
130 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
131 * Regular 512 points IMDCT without overlapping, with the exception of the swapping of odd bands
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
132 * caused by the reverse spectra of the QMF.
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
133 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
134 * @param pInput float input
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
135 * @param pOutput float output
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
136 * @param odd_band 1 if the band is an odd band
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
137 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
138
7546
97383e012cb9 remove mdct tmp buffer
lorenm
parents: 7451
diff changeset
139 static void IMLT(float *pInput, float *pOutput, int odd_band)
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
140 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
141 int i;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
142
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
143 if (odd_band) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
144 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
145 * Reverse the odd bands before IMDCT, this is an effect of the QMF transform
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
146 * or it gives better compression to do it this way.
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
147 * FIXME: It should be possible to handle this in ff_imdct_calc
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
148 * for that to happen a modification of the prerotation step of
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
149 * all SIMD code and C code is needed.
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
150 * Or fix the functions before so they generate a pre reversed spectrum.
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
151 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
152
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
153 for (i=0; i<128; i++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
154 FFSWAP(float, pInput[i], pInput[255-i]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
155 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
156
7547
8226017a65ae mdct wrapper function to match fft
lorenm
parents: 7546
diff changeset
157 ff_imdct_calc(&mdct_ctx,pOutput,pInput);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
158
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
159 /* Perform windowing on the output. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
160 dsp.vector_fmul(pOutput,mdct_window,512);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
161
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
162 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
163
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
164
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
165 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
166 * Atrac 3 indata descrambling, only used for data coming from the rm container
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
167 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
168 * @param in pointer to 8 bit array of indata
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
169 * @param bits amount of bits
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
170 * @param out pointer to 8 bit array of outdata
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
171 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
172
6228
michael
parents: 5523
diff changeset
173 static int decode_bytes(const uint8_t* inbuffer, uint8_t* out, int bytes){
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
174 int i, off;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
175 uint32_t c;
6228
michael
parents: 5523
diff changeset
176 const uint32_t* buf;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
177 uint32_t* obuf = (uint32_t*) out;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
178
9183
7b62479a31ec use intptr_t to cast pointers to int in codecs maintained by benjamin larsson
ramiro
parents: 9007
diff changeset
179 off = (intptr_t)inbuffer & 3;
6228
michael
parents: 5523
diff changeset
180 buf = (const uint32_t*) (inbuffer - off);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
181 c = be2me_32((0x537F6103 >> (off*8)) | (0x537F6103 << (32-(off*8))));
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
182 bytes += 3 + off;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
183 for (i = 0; i < bytes/4; i++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
184 obuf[i] = c ^ buf[i];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
185
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
186 if (off)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
187 av_log(NULL,AV_LOG_DEBUG,"Offset of %d not handled, post sample on ffmpeg-dev.\n",off);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
188
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
189 return off;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
190 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
191
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
192
9007
043574c5c153 Add missing av_cold in static init/close functions.
stefano
parents: 8718
diff changeset
193 static av_cold void init_atrac3_transforms(ATRAC3Context *q) {
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
194 float enc_window[256];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
195 int i;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
196
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
197 /* Generate the mdct window, for details see
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
198 * http://wiki.multimedia.cx/index.php?title=RealAudio_atrc#Windows */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
199 for (i=0 ; i<256; i++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
200 enc_window[i] = (sin(((i + 0.5) / 256.0 - 0.5) * M_PI) + 1.0) * 0.5;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
201
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
202 if (!mdct_window[0])
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
203 for (i=0 ; i<256; i++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
204 mdct_window[i] = enc_window[i]/(enc_window[i]*enc_window[i] + enc_window[255-i]*enc_window[255-i]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
205 mdct_window[511-i] = mdct_window[i];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
206 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
207
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
208 /* Initialize the MDCT transform. */
9658
67a20f0eb42c Support for getting (i)MDCT output multiplied by a constant scaling factor.
serge
parents: 9428
diff changeset
209 ff_mdct_init(&mdct_ctx, 9, 1, 1.0);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
210 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
211
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
212 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
213 * Atrac3 uninit, free all allocated memory
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
214 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
215
9007
043574c5c153 Add missing av_cold in static init/close functions.
stefano
parents: 8718
diff changeset
216 static av_cold int atrac3_decode_close(AVCodecContext *avctx)
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
217 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
218 ATRAC3Context *q = avctx->priv_data;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
219
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
220 av_free(q->pUnits);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
221 av_free(q->decoded_bytes_buffer);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
222
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
223 return 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
224 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
225
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
226 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
227 / * Mantissa decoding
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
228 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
229 * @param gb the GetBit context
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
230 * @param selector what table is the output values coded with
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
231 * @param codingFlag constant length coding or variable length coding
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
232 * @param mantissas mantissa output table
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
233 * @param numCodes amount of values to get
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
234 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
235
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
236 static void readQuantSpectralCoeffs (GetBitContext *gb, int selector, int codingFlag, int* mantissas, int numCodes)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
237 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
238 int numBits, cnt, code, huffSymb;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
239
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
240 if (selector == 1)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
241 numCodes /= 2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
242
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
243 if (codingFlag != 0) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
244 /* constant length coding (CLC) */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
245 numBits = CLCLengthTab[selector];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
246
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
247 if (selector > 1) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
248 for (cnt = 0; cnt < numCodes; cnt++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
249 if (numBits)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
250 code = get_sbits(gb, numBits);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
251 else
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
252 code = 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
253 mantissas[cnt] = code;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
254 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
255 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
256 for (cnt = 0; cnt < numCodes; cnt++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
257 if (numBits)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
258 code = get_bits(gb, numBits); //numBits is always 4 in this case
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
259 else
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
260 code = 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
261 mantissas[cnt*2] = seTab_0[code >> 2];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
262 mantissas[cnt*2+1] = seTab_0[code & 3];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
263 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
264 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
265 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
266 /* variable length coding (VLC) */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
267 if (selector != 1) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
268 for (cnt = 0; cnt < numCodes; cnt++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
269 huffSymb = get_vlc2(gb, spectral_coeff_tab[selector-1].table, spectral_coeff_tab[selector-1].bits, 3);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
270 huffSymb += 1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
271 code = huffSymb >> 1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
272 if (huffSymb & 1)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
273 code = -code;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
274 mantissas[cnt] = code;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
275 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
276 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
277 for (cnt = 0; cnt < numCodes; cnt++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
278 huffSymb = get_vlc2(gb, spectral_coeff_tab[selector-1].table, spectral_coeff_tab[selector-1].bits, 3);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
279 mantissas[cnt*2] = decTable1[huffSymb*2];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
280 mantissas[cnt*2+1] = decTable1[huffSymb*2+1];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
281 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
282 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
283 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
284 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
285
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
286 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
287 * Restore the quantized band spectrum coefficients
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
288 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
289 * @param gb the GetBit context
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
290 * @param pOut decoded band spectrum
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
291 * @return outSubbands subband counter, fix for broken specification/files
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
292 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
293
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
294 static int decodeSpectrum (GetBitContext *gb, float *pOut)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
295 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
296 int numSubbands, codingMode, cnt, first, last, subbWidth, *pIn;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
297 int subband_vlc_index[32], SF_idxs[32];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
298 int mantissas[128];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
299 float SF;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
300
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
301 numSubbands = get_bits(gb, 5); // number of coded subbands
5513
9f8219a3b86f use get_bits1(..) instead get_bits(.., 1)
alex
parents: 5423
diff changeset
302 codingMode = get_bits1(gb); // coding Mode: 0 - VLC/ 1-CLC
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
303
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
304 /* Get the VLC selector table for the subbands, 0 means not coded. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
305 for (cnt = 0; cnt <= numSubbands; cnt++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
306 subband_vlc_index[cnt] = get_bits(gb, 3);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
307
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
308 /* Read the scale factor indexes from the stream. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
309 for (cnt = 0; cnt <= numSubbands; cnt++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
310 if (subband_vlc_index[cnt] != 0)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
311 SF_idxs[cnt] = get_bits(gb, 6);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
312 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
313
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
314 for (cnt = 0; cnt <= numSubbands; cnt++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
315 first = subbandTab[cnt];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
316 last = subbandTab[cnt+1];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
317
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
318 subbWidth = last - first;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
319
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
320 if (subband_vlc_index[cnt] != 0) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
321 /* Decode spectral coefficients for this subband. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
322 /* TODO: This can be done faster is several blocks share the
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
323 * same VLC selector (subband_vlc_index) */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
324 readQuantSpectralCoeffs (gb, subband_vlc_index[cnt], codingMode, mantissas, subbWidth);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
325
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
326 /* Decode the scale factor for this subband. */
10150
29cedcc646fe Split out common routines needed in the atrac1 decoder from atrac3.c to atrac.c.
banan
parents: 9667
diff changeset
327 SF = sf_table[SF_idxs[cnt]] * iMaxQuant[subband_vlc_index[cnt]];
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
328
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
329 /* Inverse quantize the coefficients. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
330 for (pIn=mantissas ; first<last; first++, pIn++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
331 pOut[first] = *pIn * SF;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
332 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
333 /* This subband was not coded, so zero the entire subband. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
334 memset(pOut+first, 0, subbWidth*sizeof(float));
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
335 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
336 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
337
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
338 /* Clear the subbands that were not coded. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
339 first = subbandTab[cnt];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
340 memset(pOut+first, 0, (1024 - first) * sizeof(float));
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
341 return numSubbands;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
342 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
343
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
344 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
345 * Restore the quantized tonal components
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
346 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
347 * @param gb the GetBit context
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
348 * @param pComponent tone component
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
349 * @param numBands amount of coded bands
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
350 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
351
4865
086291824752 Deobfuscade decodeTonalComponents calling logic.
banan
parents: 4856
diff changeset
352 static int decodeTonalComponents (GetBitContext *gb, tonal_component *pComponent, int numBands)
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
353 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
354 int i,j,k,cnt;
4865
086291824752 Deobfuscade decodeTonalComponents calling logic.
banan
parents: 4856
diff changeset
355 int components, coding_mode_selector, coding_mode, coded_values_per_component;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
356 int sfIndx, coded_values, max_coded_values, quant_step_index, coded_components;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
357 int band_flags[4], mantissa[8];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
358 float *pCoef;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
359 float scalefactor;
4865
086291824752 Deobfuscade decodeTonalComponents calling logic.
banan
parents: 4856
diff changeset
360 int component_count = 0;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
361
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
362 components = get_bits(gb,5);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
363
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
364 /* no tonal components */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
365 if (components == 0)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
366 return 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
367
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
368 coding_mode_selector = get_bits(gb,2);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
369 if (coding_mode_selector == 2)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
370 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
371
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
372 coding_mode = coding_mode_selector & 1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
373
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
374 for (i = 0; i < components; i++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
375 for (cnt = 0; cnt <= numBands; cnt++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
376 band_flags[cnt] = get_bits1(gb);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
377
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
378 coded_values_per_component = get_bits(gb,3);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
379
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
380 quant_step_index = get_bits(gb,3);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
381 if (quant_step_index <= 1)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
382 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
383
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
384 if (coding_mode_selector == 3)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
385 coding_mode = get_bits1(gb);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
386
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
387 for (j = 0; j < (numBands + 1) * 4; j++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
388 if (band_flags[j >> 2] == 0)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
389 continue;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
390
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
391 coded_components = get_bits(gb,3);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
392
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
393 for (k=0; k<coded_components; k++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
394 sfIndx = get_bits(gb,6);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
395 pComponent[component_count].pos = j * 64 + (get_bits(gb,6));
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
396 max_coded_values = 1024 - pComponent[component_count].pos;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
397 coded_values = coded_values_per_component + 1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
398 coded_values = FFMIN(max_coded_values,coded_values);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
399
10150
29cedcc646fe Split out common routines needed in the atrac1 decoder from atrac3.c to atrac.c.
banan
parents: 9667
diff changeset
400 scalefactor = sf_table[sfIndx] * iMaxQuant[quant_step_index];
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
401
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
402 readQuantSpectralCoeffs(gb, quant_step_index, coding_mode, mantissa, coded_values);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
403
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
404 pComponent[component_count].numCoefs = coded_values;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
405
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
406 /* inverse quant */
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
407 pCoef = pComponent[component_count].coef;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
408 for (cnt = 0; cnt < coded_values; cnt++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
409 pCoef[cnt] = mantissa[cnt] * scalefactor;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
410
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
411 component_count++;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
412 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
413 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
414 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
415
4865
086291824752 Deobfuscade decodeTonalComponents calling logic.
banan
parents: 4856
diff changeset
416 return component_count;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
417 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
418
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
419 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
420 * Decode gain parameters for the coded bands
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
421 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
422 * @param gb the GetBit context
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
423 * @param pGb the gainblock for the current band
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
424 * @param numBands amount of coded bands
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
425 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
426
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
427 static int decodeGainControl (GetBitContext *gb, gain_block *pGb, int numBands)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
428 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
429 int i, cf, numData;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
430 int *pLevel, *pLoc;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
431
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
432 gain_info *pGain = pGb->gBlock;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
433
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
434 for (i=0 ; i<=numBands; i++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
435 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
436 numData = get_bits(gb,3);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
437 pGain[i].num_gain_data = numData;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
438 pLevel = pGain[i].levcode;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
439 pLoc = pGain[i].loccode;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
440
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
441 for (cf = 0; cf < numData; cf++){
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
442 pLevel[cf]= get_bits(gb,4);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
443 pLoc [cf]= get_bits(gb,5);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
444 if(cf && pLoc[cf] <= pLoc[cf-1])
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
445 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
446 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
447 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
448
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
449 /* Clear the unused blocks. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
450 for (; i<4 ; i++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
451 pGain[i].num_gain_data = 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
452
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
453 return 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
454 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
455
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
456 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
457 * Apply gain parameters and perform the MDCT overlapping part
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
458 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
459 * @param pIn input float buffer
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
460 * @param pPrev previous float buffer to perform overlap against
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
461 * @param pOut output float buffer
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
462 * @param pGain1 current band gain info
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
463 * @param pGain2 next band gain info
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
464 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
465
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
466 static void gainCompensateAndOverlap (float *pIn, float *pPrev, float *pOut, gain_info *pGain1, gain_info *pGain2)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
467 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
468 /* gain compensation function */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
469 float gain1, gain2, gain_inc;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
470 int cnt, numdata, nsample, startLoc, endLoc;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
471
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
472
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
473 if (pGain2->num_gain_data == 0)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
474 gain1 = 1.0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
475 else
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
476 gain1 = gain_tab1[pGain2->levcode[0]];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
477
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
478 if (pGain1->num_gain_data == 0) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
479 for (cnt = 0; cnt < 256; cnt++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
480 pOut[cnt] = pIn[cnt] * gain1 + pPrev[cnt];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
481 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
482 numdata = pGain1->num_gain_data;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
483 pGain1->loccode[numdata] = 32;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
484 pGain1->levcode[numdata] = 4;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
485
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
486 nsample = 0; // current sample = 0
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
487
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
488 for (cnt = 0; cnt < numdata; cnt++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
489 startLoc = pGain1->loccode[cnt] * 8;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
490 endLoc = startLoc + 8;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
491
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
492 gain2 = gain_tab1[pGain1->levcode[cnt]];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
493 gain_inc = gain_tab2[(pGain1->levcode[cnt+1] - pGain1->levcode[cnt])+15];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
494
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
495 /* interpolate */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
496 for (; nsample < startLoc; nsample++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
497 pOut[nsample] = (pIn[nsample] * gain1 + pPrev[nsample]) * gain2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
498
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
499 /* interpolation is done over eight samples */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
500 for (; nsample < endLoc; nsample++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
501 pOut[nsample] = (pIn[nsample] * gain1 + pPrev[nsample]) * gain2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
502 gain2 *= gain_inc;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
503 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
504 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
505
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
506 for (; nsample < 256; nsample++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
507 pOut[nsample] = (pIn[nsample] * gain1) + pPrev[nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
508 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
509
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
510 /* Delay for the overlapping part. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
511 memcpy(pPrev, &pIn[256], 256*sizeof(float));
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
512 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
513
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
514 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
515 * Combine the tonal band spectrum and regular band spectrum
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
516 * Return position of the last tonal coefficient
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
517 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
518 * @param pSpectrum output spectrum buffer
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
519 * @param numComponents amount of tonal components
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
520 * @param pComponent tonal components for this band
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
521 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
522
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
523 static int addTonalComponents (float *pSpectrum, int numComponents, tonal_component *pComponent)
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
524 {
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
525 int cnt, i, lastPos = -1;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
526 float *pIn, *pOut;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
527
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
528 for (cnt = 0; cnt < numComponents; cnt++){
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
529 lastPos = FFMAX(pComponent[cnt].pos + pComponent[cnt].numCoefs, lastPos);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
530 pIn = pComponent[cnt].coef;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
531 pOut = &(pSpectrum[pComponent[cnt].pos]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
532
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
533 for (i=0 ; i<pComponent[cnt].numCoefs ; i++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
534 pOut[i] += pIn[i];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
535 }
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
536
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
537 return lastPos;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
538 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
539
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
540
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
541 #define INTERPOLATE(old,new,nsample) ((old) + (nsample)*0.125*((new)-(old)))
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
542
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
543 static void reverseMatrixing(float *su1, float *su2, int *pPrevCode, int *pCurrCode)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
544 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
545 int i, band, nsample, s1, s2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
546 float c1, c2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
547 float mc1_l, mc1_r, mc2_l, mc2_r;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
548
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
549 for (i=0,band = 0; band < 4*256; band+=256,i++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
550 s1 = pPrevCode[i];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
551 s2 = pCurrCode[i];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
552 nsample = 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
553
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
554 if (s1 != s2) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
555 /* Selector value changed, interpolation needed. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
556 mc1_l = matrixCoeffs[s1*2];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
557 mc1_r = matrixCoeffs[s1*2+1];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
558 mc2_l = matrixCoeffs[s2*2];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
559 mc2_r = matrixCoeffs[s2*2+1];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
560
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
561 /* Interpolation is done over the first eight samples. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
562 for(; nsample < 8; nsample++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
563 c1 = su1[band+nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
564 c2 = su2[band+nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
565 c2 = c1 * INTERPOLATE(mc1_l,mc2_l,nsample) + c2 * INTERPOLATE(mc1_r,mc2_r,nsample);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
566 su1[band+nsample] = c2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
567 su2[band+nsample] = c1 * 2.0 - c2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
568 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
569 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
570
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
571 /* Apply the matrix without interpolation. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
572 switch (s2) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
573 case 0: /* M/S decoding */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
574 for (; nsample < 256; nsample++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
575 c1 = su1[band+nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
576 c2 = su2[band+nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
577 su1[band+nsample] = c2 * 2.0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
578 su2[band+nsample] = (c1 - c2) * 2.0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
579 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
580 break;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
581
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
582 case 1:
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
583 for (; nsample < 256; nsample++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
584 c1 = su1[band+nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
585 c2 = su2[band+nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
586 su1[band+nsample] = (c1 + c2) * 2.0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
587 su2[band+nsample] = c2 * -2.0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
588 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
589 break;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
590 case 2:
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
591 case 3:
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
592 for (; nsample < 256; nsample++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
593 c1 = su1[band+nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
594 c2 = su2[band+nsample];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
595 su1[band+nsample] = c1 + c2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
596 su2[band+nsample] = c1 - c2;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
597 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
598 break;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
599 default:
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
600 assert(0);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
601 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
602 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
603 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
604
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
605 static void getChannelWeights (int indx, int flag, float ch[2]){
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
606
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
607 if (indx == 7) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
608 ch[0] = 1.0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
609 ch[1] = 1.0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
610 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
611 ch[0] = (float)(indx & 7) / 7.0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
612 ch[1] = sqrt(2 - ch[0]*ch[0]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
613 if(flag)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
614 FFSWAP(float, ch[0], ch[1]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
615 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
616 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
617
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
618 static void channelWeighting (float *su1, float *su2, int *p3)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
619 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
620 int band, nsample;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
621 /* w[x][y] y=0 is left y=1 is right */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
622 float w[2][2];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
623
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
624 if (p3[1] != 7 || p3[3] != 7){
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
625 getChannelWeights(p3[1], p3[0], w[0]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
626 getChannelWeights(p3[3], p3[2], w[1]);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
627
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
628 for(band = 1; band < 4; band++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
629 /* scale the channels by the weights */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
630 for(nsample = 0; nsample < 8; nsample++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
631 su1[band*256+nsample] *= INTERPOLATE(w[0][0], w[0][1], nsample);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
632 su2[band*256+nsample] *= INTERPOLATE(w[1][0], w[1][1], nsample);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
633 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
634
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
635 for(; nsample < 256; nsample++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
636 su1[band*256+nsample] *= w[1][0];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
637 su2[band*256+nsample] *= w[1][1];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
638 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
639 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
640 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
641 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
642
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
643
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
644 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
645 * Decode a Sound Unit
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
646 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
647 * @param gb the GetBit context
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
648 * @param pSnd the channel unit to be used
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
649 * @param pOut the decoded samples before IQMF in float representation
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
650 * @param channelNum channel number
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
651 * @param codingMode the coding mode (JOINT_STEREO or regular stereo/mono)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
652 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
653
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
654
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
655 static int decodeChannelSoundUnit (ATRAC3Context *q, GetBitContext *gb, channel_unit *pSnd, float *pOut, int channelNum, int codingMode)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
656 {
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
657 int band, result=0, numSubbands, lastTonal, numBands;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
658
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
659 if (codingMode == JOINT_STEREO && channelNum == 1) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
660 if (get_bits(gb,2) != 3) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
661 av_log(NULL,AV_LOG_ERROR,"JS mono Sound Unit id != 3.\n");
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
662 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
663 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
664 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
665 if (get_bits(gb,6) != 0x28) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
666 av_log(NULL,AV_LOG_ERROR,"Sound Unit id != 0x28.\n");
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
667 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
668 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
669 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
670
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
671 /* number of coded QMF bands */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
672 pSnd->bandsCoded = get_bits(gb,2);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
673
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
674 result = decodeGainControl (gb, &(pSnd->gainBlock[pSnd->gcBlkSwitch]), pSnd->bandsCoded);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
675 if (result) return result;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
676
4865
086291824752 Deobfuscade decodeTonalComponents calling logic.
banan
parents: 4856
diff changeset
677 pSnd->numComponents = decodeTonalComponents (gb, pSnd->components, pSnd->bandsCoded);
086291824752 Deobfuscade decodeTonalComponents calling logic.
banan
parents: 4856
diff changeset
678 if (pSnd->numComponents == -1) return -1;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
679
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
680 numSubbands = decodeSpectrum (gb, pSnd->spectrum);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
681
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
682 /* Merge the decoded spectrum and tonal components. */
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
683 lastTonal = addTonalComponents (pSnd->spectrum, pSnd->numComponents, pSnd->components);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
684
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
685
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
686 /* calculate number of used MLT/QMF bands according to the amount of coded spectral lines */
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
687 numBands = (subbandTab[numSubbands] - 1) >> 8;
6843
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
688 if (lastTonal >= 0)
bc8faf4f8b7d Fix decoding of 01-Untitled(1).oma, patch by Maxim Poliakovski
banan
parents: 6716
diff changeset
689 numBands = FFMAX((lastTonal + 256) >> 8, numBands);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
690
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
691
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
692 /* Reconstruct time domain samples. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
693 for (band=0; band<4; band++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
694 /* Perform the IMDCT step without overlapping. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
695 if (band <= numBands) {
7546
97383e012cb9 remove mdct tmp buffer
lorenm
parents: 7451
diff changeset
696 IMLT(&(pSnd->spectrum[band*256]), pSnd->IMDCT_buf, band&1);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
697 } else
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
698 memset(pSnd->IMDCT_buf, 0, 512 * sizeof(float));
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
699
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
700 /* gain compensation and overlapping */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
701 gainCompensateAndOverlap (pSnd->IMDCT_buf, &(pSnd->prevFrame[band*256]), &(pOut[band*256]),
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
702 &((pSnd->gainBlock[1 - (pSnd->gcBlkSwitch)]).gBlock[band]),
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
703 &((pSnd->gainBlock[pSnd->gcBlkSwitch]).gBlock[band]));
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
704 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
705
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
706 /* Swap the gain control buffers for the next frame. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
707 pSnd->gcBlkSwitch ^= 1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
708
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
709 return 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
710 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
711
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
712 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
713 * Frame handling
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
714 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
715 * @param q Atrac3 private context
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
716 * @param databuf the input data
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
717 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
718
7939
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
719 static int decodeFrame(ATRAC3Context *q, const uint8_t* databuf)
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
720 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
721 int result, i;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
722 float *p1, *p2, *p3, *p4;
7939
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
723 uint8_t *ptr1;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
724
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
725 if (q->codingMode == JOINT_STEREO) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
726
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
727 /* channel coupling mode */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
728 /* decode Sound Unit 1 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
729 init_get_bits(&q->gb,databuf,q->bits_per_frame);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
730
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
731 result = decodeChannelSoundUnit(q,&q->gb, q->pUnits, q->outSamples, 0, JOINT_STEREO);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
732 if (result != 0)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
733 return (result);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
734
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
735 /* Framedata of the su2 in the joint-stereo mode is encoded in
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
736 * reverse byte order so we need to swap it first. */
7939
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
737 if (databuf == q->decoded_bytes_buffer) {
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
738 uint8_t *ptr2 = q->decoded_bytes_buffer+q->bytes_per_frame-1;
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
739 ptr1 = q->decoded_bytes_buffer;
7987
bf12bb0efb68 atrac3dec: cosmetics: indentation
aurel
parents: 7939
diff changeset
740 for (i = 0; i < (q->bytes_per_frame/2); i++, ptr1++, ptr2--) {
bf12bb0efb68 atrac3dec: cosmetics: indentation
aurel
parents: 7939
diff changeset
741 FFSWAP(uint8_t,*ptr1,*ptr2);
bf12bb0efb68 atrac3dec: cosmetics: indentation
aurel
parents: 7939
diff changeset
742 }
7939
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
743 } else {
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
744 const uint8_t *ptr2 = databuf+q->bytes_per_frame-1;
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
745 for (i = 0; i < q->bytes_per_frame; i++)
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
746 q->decoded_bytes_buffer[i] = *ptr2--;
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
747 }
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
748
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
749 /* Skip the sync codes (0xF8). */
7939
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
750 ptr1 = q->decoded_bytes_buffer;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
751 for (i = 4; *ptr1 == 0xF8; i++, ptr1++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
752 if (i >= q->bytes_per_frame)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
753 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
754 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
755
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
756
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
757 /* set the bitstream reader at the start of the second Sound Unit*/
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
758 init_get_bits(&q->gb,ptr1,q->bits_per_frame);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
759
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
760 /* Fill the Weighting coeffs delay buffer */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
761 memmove(q->weighting_delay,&(q->weighting_delay[2]),4*sizeof(int));
5513
9f8219a3b86f use get_bits1(..) instead get_bits(.., 1)
alex
parents: 5423
diff changeset
762 q->weighting_delay[4] = get_bits1(&q->gb);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
763 q->weighting_delay[5] = get_bits(&q->gb,3);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
764
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
765 for (i = 0; i < 4; i++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
766 q->matrix_coeff_index_prev[i] = q->matrix_coeff_index_now[i];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
767 q->matrix_coeff_index_now[i] = q->matrix_coeff_index_next[i];
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
768 q->matrix_coeff_index_next[i] = get_bits(&q->gb,2);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
769 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
770
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
771 /* Decode Sound Unit 2. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
772 result = decodeChannelSoundUnit(q,&q->gb, &q->pUnits[1], &q->outSamples[1024], 1, JOINT_STEREO);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
773 if (result != 0)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
774 return (result);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
775
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
776 /* Reconstruct the channel coefficients. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
777 reverseMatrixing(q->outSamples, &q->outSamples[1024], q->matrix_coeff_index_prev, q->matrix_coeff_index_now);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
778
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
779 channelWeighting(q->outSamples, &q->outSamples[1024], q->weighting_delay);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
780
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
781 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
782 /* normal stereo mode or mono */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
783 /* Decode the channel sound units. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
784 for (i=0 ; i<q->channels ; i++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
785
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
786 /* Set the bitstream reader at the start of a channel sound unit. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
787 init_get_bits(&q->gb, databuf+((i*q->bytes_per_frame)/q->channels), (q->bits_per_frame)/q->channels);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
788
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
789 result = decodeChannelSoundUnit(q,&q->gb, &q->pUnits[i], &q->outSamples[i*1024], i, q->codingMode);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
790 if (result != 0)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
791 return (result);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
792 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
793 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
794
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
795 /* Apply the iQMF synthesis filter. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
796 p1= q->outSamples;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
797 for (i=0 ; i<q->channels ; i++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
798 p2= p1+256;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
799 p3= p2+256;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
800 p4= p3+256;
10150
29cedcc646fe Split out common routines needed in the atrac1 decoder from atrac3.c to atrac.c.
banan
parents: 9667
diff changeset
801 atrac_iqmf (p1, p2, 256, p1, q->pUnits[i].delayBuf1, q->tempBuf);
29cedcc646fe Split out common routines needed in the atrac1 decoder from atrac3.c to atrac.c.
banan
parents: 9667
diff changeset
802 atrac_iqmf (p4, p3, 256, p3, q->pUnits[i].delayBuf2, q->tempBuf);
29cedcc646fe Split out common routines needed in the atrac1 decoder from atrac3.c to atrac.c.
banan
parents: 9667
diff changeset
803 atrac_iqmf (p1, p3, 512, p1, q->pUnits[i].delayBuf3, q->tempBuf);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
804 p1 +=1024;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
805 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
806
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
807 return 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
808 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
809
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
810
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
811 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
812 * Atrac frame decoding
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
813 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
814 * @param avctx pointer to the AVCodecContext
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
815 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
816
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
817 static int atrac3_decode_frame(AVCodecContext *avctx,
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
818 void *data, int *data_size,
9355
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 9183
diff changeset
819 AVPacket *avpkt) {
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 9183
diff changeset
820 const uint8_t *buf = avpkt->data;
54bc8a2727b0 Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents: 9183
diff changeset
821 int buf_size = avpkt->size;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
822 ATRAC3Context *q = avctx->priv_data;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
823 int result = 0, i;
7939
cd8602533b62 atrac3: ensure input frame is not overwritten (it is const)
aurel
parents: 7547
diff changeset
824 const uint8_t* databuf;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
825 int16_t* samples = data;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
826
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
827 if (buf_size < avctx->block_align)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
828 return buf_size;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
829
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
830 /* Check if we need to descramble and what buffer to pass on. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
831 if (q->scrambled_stream) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
832 decode_bytes(buf, q->decoded_bytes_buffer, avctx->block_align);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
833 databuf = q->decoded_bytes_buffer;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
834 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
835 databuf = buf;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
836 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
837
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
838 result = decodeFrame(q, databuf);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
839
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
840 if (result != 0) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
841 av_log(NULL,AV_LOG_ERROR,"Frame decoding error!\n");
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
842 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
843 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
844
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
845 if (q->channels == 1) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
846 /* mono */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
847 for (i = 0; i<1024; i++)
5523
c2ab2ac31edb use av_clip_int16() where it makes sense
aurel
parents: 5513
diff changeset
848 samples[i] = av_clip_int16(round(q->outSamples[i]));
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
849 *data_size = 1024 * sizeof(int16_t);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
850 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
851 /* stereo */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
852 for (i = 0; i < 1024; i++) {
5523
c2ab2ac31edb use av_clip_int16() where it makes sense
aurel
parents: 5513
diff changeset
853 samples[i*2] = av_clip_int16(round(q->outSamples[i]));
c2ab2ac31edb use av_clip_int16() where it makes sense
aurel
parents: 5513
diff changeset
854 samples[i*2+1] = av_clip_int16(round(q->outSamples[1024+i]));
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
855 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
856 *data_size = 2048 * sizeof(int16_t);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
857 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
858
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
859 return avctx->block_align;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
860 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
861
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
862
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
863 /**
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
864 * Atrac3 initialization
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
865 *
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
866 * @param avctx pointer to the AVCodecContext
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
867 */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
868
9007
043574c5c153 Add missing av_cold in static init/close functions.
stefano
parents: 8718
diff changeset
869 static av_cold int atrac3_decode_init(AVCodecContext *avctx)
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
870 {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
871 int i;
6228
michael
parents: 5523
diff changeset
872 const uint8_t *edata_ptr = avctx->extradata;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
873 ATRAC3Context *q = avctx->priv_data;
9666
c80df3181479 Change from INIT_VLC_USE_STATIC to INIT_VLC_USE_NEW_STATIC in atrac3
banan
parents: 9658
diff changeset
874 static VLC_TYPE atrac3_vlc_table[4096][2];
c80df3181479 Change from INIT_VLC_USE_STATIC to INIT_VLC_USE_NEW_STATIC in atrac3
banan
parents: 9658
diff changeset
875 static int vlcs_initialized = 0;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
876
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
877 /* Take data from the AVCodecContext (RM container). */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
878 q->sample_rate = avctx->sample_rate;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
879 q->channels = avctx->channels;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
880 q->bit_rate = avctx->bit_rate;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
881 q->bits_per_frame = avctx->block_align * 8;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
882 q->bytes_per_frame = avctx->block_align;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
883
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
884 /* Take care of the codec-specific extradata. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
885 if (avctx->extradata_size == 14) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
886 /* Parse the extradata, WAV format */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
887 av_log(avctx,AV_LOG_DEBUG,"[0-1] %d\n",bytestream_get_le16(&edata_ptr)); //Unknown value always 1
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
888 q->samples_per_channel = bytestream_get_le32(&edata_ptr);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
889 q->codingMode = bytestream_get_le16(&edata_ptr);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
890 av_log(avctx,AV_LOG_DEBUG,"[8-9] %d\n",bytestream_get_le16(&edata_ptr)); //Dupe of coding mode
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
891 q->frame_factor = bytestream_get_le16(&edata_ptr); //Unknown always 1
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
892 av_log(avctx,AV_LOG_DEBUG,"[12-13] %d\n",bytestream_get_le16(&edata_ptr)); //Unknown always 0
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
893
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
894 /* setup */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
895 q->samples_per_frame = 1024 * q->channels;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
896 q->atrac3version = 4;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
897 q->delay = 0x88E;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
898 if (q->codingMode)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
899 q->codingMode = JOINT_STEREO;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
900 else
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
901 q->codingMode = STEREO;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
902
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
903 q->scrambled_stream = 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
904
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
905 if ((q->bytes_per_frame == 96*q->channels*q->frame_factor) || (q->bytes_per_frame == 152*q->channels*q->frame_factor) || (q->bytes_per_frame == 192*q->channels*q->frame_factor)) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
906 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
907 av_log(avctx,AV_LOG_ERROR,"Unknown frame/channel/frame_factor configuration %d/%d/%d\n", q->bytes_per_frame, q->channels, q->frame_factor);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
908 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
909 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
910
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
911 } else if (avctx->extradata_size == 10) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
912 /* Parse the extradata, RM format. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
913 q->atrac3version = bytestream_get_be32(&edata_ptr);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
914 q->samples_per_frame = bytestream_get_be16(&edata_ptr);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
915 q->delay = bytestream_get_be16(&edata_ptr);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
916 q->codingMode = bytestream_get_be16(&edata_ptr);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
917
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
918 q->samples_per_channel = q->samples_per_frame / q->channels;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
919 q->scrambled_stream = 1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
920
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
921 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
922 av_log(NULL,AV_LOG_ERROR,"Unknown extradata size %d.\n",avctx->extradata_size);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
923 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
924 /* Check the extradata. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
925
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
926 if (q->atrac3version != 4) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
927 av_log(avctx,AV_LOG_ERROR,"Version %d != 4.\n",q->atrac3version);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
928 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
929 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
930
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
931 if (q->samples_per_frame != 1024 && q->samples_per_frame != 2048) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
932 av_log(avctx,AV_LOG_ERROR,"Unknown amount of samples per frame %d.\n",q->samples_per_frame);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
933 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
934 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
935
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
936 if (q->delay != 0x88E) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
937 av_log(avctx,AV_LOG_ERROR,"Unknown amount of delay %x != 0x88E.\n",q->delay);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
938 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
939 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
940
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
941 if (q->codingMode == STEREO) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
942 av_log(avctx,AV_LOG_DEBUG,"Normal stereo detected.\n");
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
943 } else if (q->codingMode == JOINT_STEREO) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
944 av_log(avctx,AV_LOG_DEBUG,"Joint stereo detected.\n");
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
945 } else {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
946 av_log(avctx,AV_LOG_ERROR,"Unknown channel coding mode %x!\n",q->codingMode);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
947 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
948 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
949
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
950 if (avctx->channels <= 0 || avctx->channels > 2 /*|| ((avctx->channels * 1024) != q->samples_per_frame)*/) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
951 av_log(avctx,AV_LOG_ERROR,"Channel configuration error!\n");
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
952 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
953 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
954
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
955
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
956 if(avctx->block_align >= UINT_MAX/2)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
957 return -1;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
958
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
959 /* Pad the data buffer with FF_INPUT_BUFFER_PADDING_SIZE,
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
960 * this is for the bitstream reader. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
961 if ((q->decoded_bytes_buffer = av_mallocz((avctx->block_align+(4-avctx->block_align%4) + FF_INPUT_BUFFER_PADDING_SIZE))) == NULL)
5407
91906ea3337f Replace a return of -1 with ENOMEM.
takis
parents: 4865
diff changeset
962 return AVERROR(ENOMEM);
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
963
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
964
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
965 /* Initialize the VLC tables. */
9666
c80df3181479 Change from INIT_VLC_USE_STATIC to INIT_VLC_USE_NEW_STATIC in atrac3
banan
parents: 9658
diff changeset
966 if (!vlcs_initialized) {
9667
banan
parents: 9666
diff changeset
967 for (i=0 ; i<7 ; i++) {
banan
parents: 9666
diff changeset
968 spectral_coeff_tab[i].table = &atrac3_vlc_table[atrac3_vlc_offs[i]];
banan
parents: 9666
diff changeset
969 spectral_coeff_tab[i].table_allocated = atrac3_vlc_offs[i + 1] - atrac3_vlc_offs[i];
banan
parents: 9666
diff changeset
970 init_vlc (&spectral_coeff_tab[i], 9, huff_tab_sizes[i],
banan
parents: 9666
diff changeset
971 huff_bits[i], 1, 1,
banan
parents: 9666
diff changeset
972 huff_codes[i], 1, 1, INIT_VLC_USE_NEW_STATIC);
banan
parents: 9666
diff changeset
973 }
9666
c80df3181479 Change from INIT_VLC_USE_STATIC to INIT_VLC_USE_NEW_STATIC in atrac3
banan
parents: 9658
diff changeset
974 vlcs_initialized = 1;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
975 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
976
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
977 init_atrac3_transforms(q);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
978
10150
29cedcc646fe Split out common routines needed in the atrac1 decoder from atrac3.c to atrac.c.
banan
parents: 9667
diff changeset
979 atrac_generate_tables();
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
980
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
981 /* Generate gain tables. */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
982 for (i=0 ; i<16 ; i++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
983 gain_tab1[i] = powf (2.0, (4 - i));
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
984
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
985 for (i=-15 ; i<16 ; i++)
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
986 gain_tab2[i+15] = powf (2.0, i * -0.125);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
987
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
988 /* init the joint-stereo decoding data */
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
989 q->weighting_delay[0] = 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
990 q->weighting_delay[1] = 7;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
991 q->weighting_delay[2] = 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
992 q->weighting_delay[3] = 7;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
993 q->weighting_delay[4] = 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
994 q->weighting_delay[5] = 7;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
995
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
996 for (i=0; i<4; i++) {
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
997 q->matrix_coeff_index_prev[i] = 3;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
998 q->matrix_coeff_index_now[i] = 3;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
999 q->matrix_coeff_index_next[i] = 3;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1000 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1001
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1002 dsputil_init(&dsp, avctx);
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1003
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1004 q->pUnits = av_mallocz(sizeof(channel_unit)*q->channels);
5423
2c98d63a8956 Handle malloc failure
takis
parents: 5407
diff changeset
1005 if (!q->pUnits) {
2c98d63a8956 Handle malloc failure
takis
parents: 5407
diff changeset
1006 av_free(q->decoded_bytes_buffer);
2c98d63a8956 Handle malloc failure
takis
parents: 5407
diff changeset
1007 return AVERROR(ENOMEM);
2c98d63a8956 Handle malloc failure
takis
parents: 5407
diff changeset
1008 }
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1009
7451
85ab7655ad4d Modify all codecs to report their supported input and output sample format(s).
pross
parents: 7040
diff changeset
1010 avctx->sample_fmt = SAMPLE_FMT_S16;
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1011 return 0;
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1012 }
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1013
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1014
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1015 AVCodec atrac3_decoder =
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1016 {
6716
aa09311685b2 Transform codec names into single words.
diego
parents: 6710
diff changeset
1017 .name = "atrac3",
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1018 .type = CODEC_TYPE_AUDIO,
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1019 .id = CODEC_ID_ATRAC3,
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1020 .priv_data_size = sizeof(ATRAC3Context),
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1021 .init = atrac3_decode_init,
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1022 .close = atrac3_decode_close,
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1023 .decode = atrac3_decode_frame,
7040
e943e1409077 Make AVCodec long_names definition conditional depending on CONFIG_SMALL.
stefano
parents: 6997
diff changeset
1024 .long_name = NULL_IF_CONFIG_SMALL("Atrac 3 (Adaptive TRansform Acoustic Coding 3)"),
4856
5af8895c2805 Atrac3 decoder.
banan
parents:
diff changeset
1025 };