Coverage Report

Created: 2026-06-10 06:48

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/proc/self/cwd/libfaad/specrec.c
Line
Count
Source
1
/*
2
** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
3
** Copyright (C) 2003-2005 M. Bakker, Nero AG, http://www.nero.com
4
**
5
** This program is free software; you can redistribute it and/or modify
6
** it under the terms of the GNU General Public License as published by
7
** the Free Software Foundation; either version 2 of the License, or
8
** (at your option) any later version.
9
**
10
** This program is distributed in the hope that it will be useful,
11
** but WITHOUT ANY WARRANTY; without even the implied warranty of
12
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
** GNU General Public License for more details.
14
**
15
** You should have received a copy of the GNU General Public License
16
** along with this program; if not, write to the Free Software
17
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18
**
19
** Any non-GPL usage of this software or parts of this software is strictly
20
** forbidden.
21
**
22
** The "appropriate copyright message" mentioned in section 2c of the GPLv2
23
** must read: "Code from FAAD2 is copyright (c) Nero AG, www.nero.com"
24
**
25
** Commercial non-GPL licensing of this software is possible.
26
** For more info contact Nero AG through Mpeg4AAClicense@nero.com.
27
**
28
** $Id: specrec.c,v 1.63 2010/06/04 20:47:56 menno Exp $
29
**/
30
31
/*
32
  Spectral reconstruction:
33
   - grouping/sectioning
34
   - inverse quantization
35
   - applying scalefactors
36
*/
37
38
#include "common.h"
39
#include "structs.h"
40
41
#include <stdlib.h>
42
#include "specrec.h"
43
#include "filtbank.h"
44
#include "syntax.h"
45
#include "iq_table.h"
46
#include "ms.h"
47
#include "is.h"
48
#include "pns.h"
49
#include "tns.h"
50
#include "drc.h"
51
#include "lt_predict.h"
52
#include "ic_predict.h"
53
#ifdef SSR_DEC
54
#include "ssr.h"
55
#include "ssr_fb.h"
56
#endif
57
58
59
/* static function declarations */
60
static uint8_t quant_to_spec(NeAACDecStruct *hDecoder,
61
                             ic_stream *ics, int16_t *quant_data,
62
                             real_t *spec_data, uint16_t frame_len);
63
64
65
#ifdef LD_DEC
66
ALIGN static const uint8_t num_swb_512_window[] =
67
{
68
    0, 0, 0, 36, 36, 37, 31, 31, 0, 0, 0, 0
69
};
70
ALIGN static const uint8_t num_swb_480_window[] =
71
{
72
    0, 0, 0, 35, 35, 37, 30, 30, 0, 0, 0, 0
73
};
74
#endif
75
76
ALIGN static const uint8_t num_swb_960_window[] =
77
{
78
    40, 40, 45, 49, 49, 49, 46, 46, 42, 42, 42, 40
79
};
80
81
ALIGN static const uint8_t num_swb_1024_window[] =
82
{
83
    41, 41, 47, 49, 49, 51, 47, 47, 43, 43, 43, 40
84
};
85
86
ALIGN static const uint8_t num_swb_128_window[] =
87
{
88
    12, 12, 12, 14, 14, 14, 15, 15, 15, 15, 15, 15
89
};
90
91
ALIGN static const uint16_t swb_offset_1024_96[] =
92
{
93
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 48, 52, 56,
94
    64, 72, 80, 88, 96, 108, 120, 132, 144, 156, 172, 188, 212, 240,
95
    276, 320, 384, 448, 512, 576, 640, 704, 768, 832, 896, 960, 1024
96
};
97
98
ALIGN static const uint16_t swb_offset_128_96[] =
99
{
100
    0, 4, 8, 12, 16, 20, 24, 32, 40, 48, 64, 92, 128
101
};
102
103
ALIGN static const uint16_t swb_offset_1024_64[] =
104
{
105
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 48, 52, 56,
106
    64, 72, 80, 88, 100, 112, 124, 140, 156, 172, 192, 216, 240, 268,
107
    304, 344, 384, 424, 464, 504, 544, 584, 624, 664, 704, 744, 784, 824,
108
    864, 904, 944, 984, 1024
109
};
110
111
ALIGN static const uint16_t swb_offset_128_64[] =
112
{
113
    0, 4, 8, 12, 16, 20, 24, 32, 40, 48, 64, 92, 128
114
};
115
116
ALIGN static const uint16_t swb_offset_1024_48[] =
117
{
118
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 48, 56, 64, 72,
119
    80, 88, 96, 108, 120, 132, 144, 160, 176, 196, 216, 240, 264, 292,
120
    320, 352, 384, 416, 448, 480, 512, 544, 576, 608, 640, 672, 704, 736,
121
    768, 800, 832, 864, 896, 928, 1024
122
};
123
124
#ifdef LD_DEC
125
ALIGN static const uint16_t swb_offset_512_48[] =
126
{
127
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 48, 52, 56, 60, 68, 76, 84,
128
    92, 100, 112, 124, 136, 148, 164, 184, 208, 236, 268, 300, 332, 364, 396,
129
    428, 460, 512
130
};
131
132
ALIGN static const uint16_t swb_offset_480_48[] =
133
{
134
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 48, 52, 56, 64, 72 ,80 ,88,
135
    96, 108, 120, 132, 144, 156, 172, 188, 212, 240, 272, 304, 336, 368, 400,
136
    432, 480
137
};
138
#endif
139
140
ALIGN static const uint16_t swb_offset_128_48[] =
141
{
142
    0, 4, 8, 12, 16, 20, 28, 36, 44, 56, 68, 80, 96, 112, 128
143
};
144
145
ALIGN static const uint16_t swb_offset_1024_32[] =
146
{
147
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 48, 56, 64, 72,
148
    80, 88, 96, 108, 120, 132, 144, 160, 176, 196, 216, 240, 264, 292,
149
    320, 352, 384, 416, 448, 480, 512, 544, 576, 608, 640, 672, 704, 736,
150
    768, 800, 832, 864, 896, 928, 960, 992, 1024
151
};
152
153
#ifdef LD_DEC
154
ALIGN static const uint16_t swb_offset_512_32[] =
155
{
156
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 48, 52, 56, 64, 72, 80,
157
    88, 96, 108, 120, 132, 144, 160, 176, 192, 212, 236, 260, 288, 320, 352,
158
    384, 416, 448, 480, 512
159
};
160
161
ALIGN static const uint16_t swb_offset_480_32[] =
162
{
163
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 48, 52, 56, 60, 64, 72, 80,
164
    88, 96, 104, 112, 124, 136, 148, 164, 180, 200, 224, 256, 288, 320, 352,
165
    384, 416, 448, 480
166
};
167
#endif
168
169
ALIGN static const uint16_t swb_offset_1024_24[] =
170
{
171
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 52, 60, 68,
172
    76, 84, 92, 100, 108, 116, 124, 136, 148, 160, 172, 188, 204, 220,
173
    240, 260, 284, 308, 336, 364, 396, 432, 468, 508, 552, 600, 652, 704,
174
    768, 832, 896, 960, 1024
175
};
176
177
#ifdef LD_DEC
178
ALIGN static const uint16_t swb_offset_512_24[] =
179
{
180
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 52, 60, 68,
181
    80, 92, 104, 120, 140, 164, 192, 224, 256, 288, 320, 352, 384, 416,
182
    448, 480, 512
183
};
184
185
ALIGN static const uint16_t swb_offset_480_24[] =
186
{
187
    0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 52, 60, 68, 80, 92, 104, 120,
188
    140, 164, 192, 224, 256, 288, 320, 352, 384, 416, 448, 480
189
};
190
#endif
191
192
ALIGN static const uint16_t swb_offset_128_24[] =
193
{
194
    0, 4, 8, 12, 16, 20, 24, 28, 36, 44, 52, 64, 76, 92, 108, 128
195
};
196
197
ALIGN static const uint16_t swb_offset_1024_16[] =
198
{
199
    0, 8, 16, 24, 32, 40, 48, 56, 64, 72, 80, 88, 100, 112, 124,
200
    136, 148, 160, 172, 184, 196, 212, 228, 244, 260, 280, 300, 320, 344,
201
    368, 396, 424, 456, 492, 532, 572, 616, 664, 716, 772, 832, 896, 960, 1024
202
};
203
204
ALIGN static const uint16_t swb_offset_128_16[] =
205
{
206
    0, 4, 8, 12, 16, 20, 24, 28, 32, 40, 48, 60, 72, 88, 108, 128
207
};
208
209
ALIGN static const uint16_t swb_offset_1024_8[] =
210
{
211
    0, 12, 24, 36, 48, 60, 72, 84, 96, 108, 120, 132, 144, 156, 172,
212
    188, 204, 220, 236, 252, 268, 288, 308, 328, 348, 372, 396, 420, 448,
213
    476, 508, 544, 580, 620, 664, 712, 764, 820, 880, 944, 1024
214
};
215
216
ALIGN static const uint16_t swb_offset_128_8[] =
217
{
218
    0, 4, 8, 12, 16, 20, 24, 28, 36, 44, 52, 60, 72, 88, 108, 128
219
};
220
221
ALIGN static const uint16_t *swb_offset_1024_window[] =
222
{
223
    swb_offset_1024_96,      /* 96000 */
224
    swb_offset_1024_96,      /* 88200 */
225
    swb_offset_1024_64,      /* 64000 */
226
    swb_offset_1024_48,      /* 48000 */
227
    swb_offset_1024_48,      /* 44100 */
228
    swb_offset_1024_32,      /* 32000 */
229
    swb_offset_1024_24,      /* 24000 */
230
    swb_offset_1024_24,      /* 22050 */
231
    swb_offset_1024_16,      /* 16000 */
232
    swb_offset_1024_16,      /* 12000 */
233
    swb_offset_1024_16,      /* 11025 */
234
    swb_offset_1024_8        /* 8000  */
235
};
236
237
#ifdef LD_DEC
238
ALIGN static const uint16_t *swb_offset_512_window[] =
239
{
240
    0,                       /* 96000 */
241
    0,                       /* 88200 */
242
    0,                       /* 64000 */
243
    swb_offset_512_48,       /* 48000 */
244
    swb_offset_512_48,       /* 44100 */
245
    swb_offset_512_32,       /* 32000 */
246
    swb_offset_512_24,       /* 24000 */
247
    swb_offset_512_24,       /* 22050 */
248
    0,                       /* 16000 */
249
    0,                       /* 12000 */
250
    0,                       /* 11025 */
251
    0                        /* 8000  */
252
};
253
254
ALIGN static const uint16_t *swb_offset_480_window[] =
255
{
256
    0,                       /* 96000 */
257
    0,                       /* 88200 */
258
    0,                       /* 64000 */
259
    swb_offset_480_48,       /* 48000 */
260
    swb_offset_480_48,       /* 44100 */
261
    swb_offset_480_32,       /* 32000 */
262
    swb_offset_480_24,       /* 24000 */
263
    swb_offset_480_24,       /* 22050 */
264
    0,                       /* 16000 */
265
    0,                       /* 12000 */
266
    0,                       /* 11025 */
267
    0                        /* 8000  */
268
};
269
#endif
270
271
ALIGN static const  uint16_t *swb_offset_128_window[] =
272
{
273
    swb_offset_128_96,       /* 96000 */
274
    swb_offset_128_96,       /* 88200 */
275
    swb_offset_128_64,       /* 64000 */
276
    swb_offset_128_48,       /* 48000 */
277
    swb_offset_128_48,       /* 44100 */
278
    swb_offset_128_48,       /* 32000 */
279
    swb_offset_128_24,       /* 24000 */
280
    swb_offset_128_24,       /* 22050 */
281
    swb_offset_128_16,       /* 16000 */
282
    swb_offset_128_16,       /* 12000 */
283
    swb_offset_128_16,       /* 11025 */
284
    swb_offset_128_8         /* 8000  */
285
};
286
287
102k
#define bit_set(A, B) ((A) & (1<<(B)))
288
289
/* 4.5.2.3.4 */
290
/*
291
  - determine the number of windows in a window_sequence named num_windows
292
  - determine the number of window_groups named num_window_groups
293
  - determine the number of windows in each group named window_group_length[g]
294
  - determine the total number of scalefactor window bands named num_swb for
295
    the actual window type
296
  - determine swb_offset[swb], the offset of the first coefficient in
297
    scalefactor window band named swb of the window actually used
298
  - determine sect_sfb_offset[g][section],the offset of the first coefficient
299
    in section named section. This offset depends on window_sequence and
300
    scale_factor_grouping and is needed to decode the spectral_data().
301
*/
302
uint8_t window_grouping_info(NeAACDecStruct *hDecoder, ic_stream *ics)
303
128k
{
304
128k
    uint8_t i, g;
305
306
128k
    uint8_t sf_index = hDecoder->sf_index;
307
308
128k
    if (sf_index >= 12)
309
4
        return 32;
310
311
128k
    switch (ics->window_sequence) {
312
104k
    case ONLY_LONG_SEQUENCE:
313
108k
    case LONG_START_SEQUENCE:
314
114k
    case LONG_STOP_SEQUENCE:
315
114k
        ics->num_windows = 1;
316
114k
        ics->num_window_groups = 1;
317
114k
        ics->window_group_length[ics->num_window_groups-1] = 1;
318
#ifdef LD_DEC
319
        if (hDecoder->object_type == LD)
320
        {
321
            if (hDecoder->frameLength == 512)
322
                ics->num_swb = num_swb_512_window[sf_index];
323
            else /* if (hDecoder->frameLength == 480) */
324
                ics->num_swb = num_swb_480_window[sf_index];
325
        } else {
326
#endif
327
114k
            if (hDecoder->frameLength == 1024)
328
91.1k
                ics->num_swb = num_swb_1024_window[sf_index];
329
22.9k
            else /* if (hDecoder->frameLength == 960) */
330
22.9k
                ics->num_swb = num_swb_960_window[sf_index];
331
#ifdef LD_DEC
332
        }
333
#endif
334
335
114k
        if (ics->max_sfb > ics->num_swb)
336
55
        {
337
55
            return 32;
338
55
        }
339
340
        /* preparation of sect_sfb_offset for long blocks */
341
        /* also copy the last value! */
342
#ifdef LD_DEC
343
        if (hDecoder->object_type == LD)
344
        {
345
            if (hDecoder->frameLength == 512)
346
            {
347
                for (i = 0; i < ics->num_swb; i++)
348
                {
349
                    ics->sect_sfb_offset[0][i] = swb_offset_512_window[sf_index][i];
350
                    ics->swb_offset[i] = swb_offset_512_window[sf_index][i];
351
                }
352
            } else /* if (hDecoder->frameLength == 480) */ {
353
                for (i = 0; i < ics->num_swb; i++)
354
                {
355
                    ics->sect_sfb_offset[0][i] = swb_offset_480_window[sf_index][i];
356
                    ics->swb_offset[i] = swb_offset_480_window[sf_index][i];
357
                }
358
            }
359
            ics->sect_sfb_offset[0][ics->num_swb] = hDecoder->frameLength;
360
            ics->swb_offset[ics->num_swb] = hDecoder->frameLength;
361
            ics->swb_offset_max = hDecoder->frameLength;
362
        } else {
363
#endif
364
4.99M
            for (i = 0; i < ics->num_swb; i++)
365
4.88M
            {
366
4.88M
                ics->sect_sfb_offset[0][i] = swb_offset_1024_window[sf_index][i];
367
4.88M
                ics->swb_offset[i] = swb_offset_1024_window[sf_index][i];
368
4.88M
            }
369
114k
            ics->sect_sfb_offset[0][ics->num_swb] = hDecoder->frameLength;
370
114k
            ics->swb_offset[ics->num_swb] = hDecoder->frameLength;
371
114k
            ics->swb_offset_max = hDecoder->frameLength;
372
#ifdef LD_DEC
373
        }
374
#endif
375
114k
        return 0;
376
14.6k
    case EIGHT_SHORT_SEQUENCE:
377
14.6k
        ics->num_windows = 8;
378
14.6k
        ics->num_window_groups = 1;
379
14.6k
        ics->window_group_length[ics->num_window_groups-1] = 1;
380
14.6k
        ics->num_swb = num_swb_128_window[sf_index];
381
382
14.6k
        if (ics->max_sfb > ics->num_swb)
383
5
        {
384
5
            return 32;
385
5
        }
386
387
220k
        for (i = 0; i < ics->num_swb; i++)
388
205k
            ics->swb_offset[i] = swb_offset_128_window[sf_index][i];
389
14.5k
        ics->swb_offset[ics->num_swb] = hDecoder->frameLength/8;
390
14.5k
        ics->swb_offset_max = hDecoder->frameLength/8;
391
392
116k
        for (i = 0; i < ics->num_windows-1; i++) {
393
102k
            if (bit_set(ics->scale_factor_grouping, 6-i) == 0)
394
81.3k
            {
395
81.3k
                ics->num_window_groups += 1;
396
81.3k
                ics->window_group_length[ics->num_window_groups-1] = 1;
397
81.3k
            } else {
398
20.8k
                ics->window_group_length[ics->num_window_groups-1] += 1;
399
20.8k
            }
400
102k
        }
401
402
        /* preparation of sect_sfb_offset for short blocks */
403
110k
        for (g = 0; g < ics->num_window_groups; g++)
404
95.9k
        {
405
95.9k
            uint16_t width;
406
95.9k
            uint8_t sect_sfb = 0;
407
95.9k
            uint16_t offset = 0;
408
409
1.44M
            for (i = 0; i < ics->num_swb; i++)
410
1.35M
            {
411
1.35M
                if (i+1 == ics->num_swb)
412
95.9k
                {
413
95.9k
                    width = (hDecoder->frameLength/8) - swb_offset_128_window[sf_index][i];
414
1.25M
                } else {
415
1.25M
                    width = swb_offset_128_window[sf_index][i+1] -
416
1.25M
                        swb_offset_128_window[sf_index][i];
417
1.25M
                }
418
1.35M
                width *= ics->window_group_length[g];
419
1.35M
                ics->sect_sfb_offset[g][sect_sfb++] = offset;
420
1.35M
                offset += width;
421
1.35M
            }
422
95.9k
            ics->sect_sfb_offset[g][sect_sfb] = offset;
423
95.9k
        }
424
14.5k
        return 0;
425
0
    default:
426
0
        return 32;
427
128k
    }
428
128k
}
429
430
/* iquant() * output = sign(input)*abs(input)^(4/3) */
431
static INLINE real_t iquant(int16_t q, const real_t *tab, uint8_t *error)
432
140M
{
433
#ifdef FIXED_POINT
434
/* For FIXED_POINT the iq_table is prescaled by 3 bits (iq_table[]/8) */
435
/* BIG_IQ_TABLE allows you to use the full 8192 value table, if this is not
436
 * defined a 1026 value table and interpolation will be used
437
 */
438
#ifndef BIG_IQ_TABLE
439
    static const real_t errcorr[] = {
440
        REAL_CONST(0), REAL_CONST(1.0/8.0), REAL_CONST(2.0/8.0), REAL_CONST(3.0/8.0),
441
        REAL_CONST(4.0/8.0),  REAL_CONST(5.0/8.0), REAL_CONST(6.0/8.0), REAL_CONST(7.0/8.0),
442
        REAL_CONST(0)
443
    };
444
    real_t x1, x2;
445
#endif
446
    int16_t sgn = 1;
447
    /* compute the magnitude in int: -q is evaluated as int and so does not
448
       wrap for q == -32768 the way an int16_t negation would, which keeps the
449
       comparison against IQ_TABLE_SIZE in range like the floating-point path */
450
    int aq = q;
451
452
    if (aq < 0)
453
    {
454
        aq = -aq;
455
        sgn = -1;
456
    }
457
458
    if (aq < IQ_TABLE_SIZE)
459
    {
460
//#define IQUANT_PRINT
461
#ifdef IQUANT_PRINT
462
        //printf("0x%.8X\n", sgn * tab[aq]);
463
        printf("%d\n", sgn * tab[aq]);
464
#endif
465
        return sgn * tab[aq];
466
    }
467
468
#ifndef BIG_IQ_TABLE
469
    if (aq >= 8192)
470
    {
471
        *error = 17;
472
        return 0;
473
    }
474
475
    /* linear interpolation */
476
    x1 = tab[aq>>3];
477
    x2 = tab[(aq>>3) + 1];
478
    return sgn * 16 * (MUL_R(errcorr[aq&7],(x2-x1)) + x1);
479
#else
480
    *error = 17;
481
    return 0;
482
#endif
483
484
#else
485
140M
    if (q < 0)
486
80.2k
    {
487
        /* tab contains a value for all possible q [0,8192] */
488
80.2k
        if (-q < IQ_TABLE_SIZE)
489
79.3k
            return -tab[-q];
490
491
889
        *error = 17;
492
889
        return 0;
493
140M
    } else {
494
        /* tab contains a value for all possible q [0,8192] */
495
140M
        if (q < IQ_TABLE_SIZE)
496
140M
            return tab[q];
497
498
534
        *error = 17;
499
534
        return 0;
500
140M
    }
501
140M
#endif
502
140M
}
503
504
#ifndef FIXED_POINT
505
ALIGN static const real_t pow2sf_tab[] = {
506
    2.9802322387695313E-008, 5.9604644775390625E-008, 1.1920928955078125E-007,
507
    2.384185791015625E-007, 4.76837158203125E-007, 9.5367431640625E-007,
508
    1.9073486328125E-006, 3.814697265625E-006, 7.62939453125E-006,
509
    1.52587890625E-005, 3.0517578125E-005, 6.103515625E-005,
510
    0.0001220703125, 0.000244140625, 0.00048828125,
511
    0.0009765625, 0.001953125, 0.00390625,
512
    0.0078125, 0.015625, 0.03125,
513
    0.0625, 0.125, 0.25,
514
    0.5, 1.0, 2.0,
515
    4.0, 8.0, 16.0, 32.0,
516
    64.0, 128.0, 256.0,
517
    512.0, 1024.0, 2048.0,
518
    4096.0, 8192.0, 16384.0,
519
    32768.0, 65536.0, 131072.0,
520
    262144.0, 524288.0, 1048576.0,
521
    2097152.0, 4194304.0, 8388608.0,
522
    16777216.0, 33554432.0, 67108864.0,
523
    134217728.0, 268435456.0, 536870912.0,
524
    1073741824.0, 2147483648.0, 4294967296.0,
525
    8589934592.0, 17179869184.0, 34359738368.0,
526
    68719476736.0, 137438953472.0, 274877906944.0
527
};
528
#endif
529
530
/* quant_to_spec: perform dequantisation and scaling
531
 * and in case of short block it also does the deinterleaving
532
 */
533
/*
534
  For ONLY_LONG_SEQUENCE windows (num_window_groups = 1,
535
  window_group_length[0] = 1) the spectral data is in ascending spectral
536
  order.
537
  For the EIGHT_SHORT_SEQUENCE window, the spectral order depends on the
538
  grouping in the following manner:
539
  - Groups are ordered sequentially
540
  - Within a group, a scalefactor band consists of the spectral data of all
541
    grouped SHORT_WINDOWs for the associated scalefactor window band. To
542
    clarify via example, the length of a group is in the range of one to eight
543
    SHORT_WINDOWs.
544
  - If there are eight groups each with length one (num_window_groups = 8,
545
    window_group_length[0..7] = 1), the result is a sequence of eight spectra,
546
    each in ascending spectral order.
547
  - If there is only one group with length eight (num_window_groups = 1,
548
    window_group_length[0] = 8), the result is that spectral data of all eight
549
    SHORT_WINDOWs is interleaved by scalefactor window bands.
550
  - Within a scalefactor window band, the coefficients are in ascending
551
    spectral order.
552
*/
553
static uint8_t quant_to_spec(NeAACDecStruct *hDecoder,
554
                             ic_stream *ics, int16_t *quant_data,
555
                             real_t *spec_data, uint16_t frame_len)
556
138k
{
557
138k
    ALIGN static const real_t pow2_table[] =
558
138k
    {
559
138k
        COEF_CONST(1.0),
560
138k
        COEF_CONST(1.1892071150027210667174999705605), /* 2^0.25 */
561
138k
        COEF_CONST(1.4142135623730950488016887242097), /* 2^0.5 */
562
138k
        COEF_CONST(1.6817928305074290860622509524664) /* 2^0.75 */
563
138k
    };
564
138k
    const real_t *tab = iq_table;
565
566
138k
    uint8_t g, sfb, win;
567
138k
    uint16_t width, bin, k, gindex;
568
138k
    uint8_t error = 0; /* Init error flag */
569
138k
#ifndef FIXED_POINT
570
138k
    real_t scf;
571
#else
572
    int32_t sat_shift_mask = 0;
573
#endif
574
575
138k
    k = 0;
576
138k
    gindex = 0;
577
578
    /* In this case quant_to_spec is no-op and spec_data remains undefined.
579
     * Without peeking into AAC specification, there is no strong evidence if
580
     * such streams are invalid -> just calm down MSAN. */
581
138k
    if (ics->num_swb == 0)
582
0
        memset(spec_data, 0, frame_len * sizeof(real_t));
583
584
362k
    for (g = 0; g < ics->num_window_groups; g++)
585
223k
    {
586
223k
        uint16_t j = 0;
587
223k
        uint16_t gincrease = 0;
588
223k
        uint16_t win_inc = ics->swb_offset[ics->num_swb];
589
590
6.90M
        for (sfb = 0; sfb < ics->num_swb; sfb++)
591
6.68M
        {
592
6.68M
            int32_t exp, frac;
593
6.68M
            uint16_t wa = gindex + j;
594
6.68M
            int16_t scale_factor = ics->scale_factors[g][sfb];
595
596
6.68M
            width = ics->swb_offset[sfb+1] - ics->swb_offset[sfb];
597
598
#ifdef FIXED_POINT
599
            scale_factor -= 100;
600
            /* IMDCT pre-scaling */
601
            if (hDecoder->object_type == LD)
602
            {
603
                scale_factor -= 24 /*9*/;
604
            } else {
605
                if (ics->window_sequence == EIGHT_SHORT_SEQUENCE)
606
                    scale_factor -= 16 /*7*/;
607
                else
608
                    scale_factor -= 28 /*10*/;
609
            }
610
            if (scale_factor > 120)
611
                scale_factor = 120;  /* => exp <= 30 */
612
#else
613
6.68M
            (void)hDecoder;
614
6.68M
#endif
615
616
            /* scale_factor for IS or PNS, has different meaning; fill with almost zeroes */
617
6.68M
            if (is_intensity(ics, g, sfb) || is_noise(ics, g, sfb))
618
6.51k
            {
619
6.51k
                scale_factor = 0;
620
6.51k
            }
621
622
            /* scale_factor must be between 0 and 255 */
623
6.68M
            exp = (scale_factor /* - 100 */) >> 2;
624
            /* frac must always be > 0 */
625
6.68M
            frac = (scale_factor /* - 100 */) & 3;
626
627
6.68M
#ifndef FIXED_POINT
628
6.68M
            scf = pow2sf_tab[exp/*+25*/] * pow2_table[frac];
629
#else
630
            if (exp > 0)
631
                sat_shift_mask = SAT_SHIFT_MASK(exp);
632
#endif
633
634
13.6M
            for (win = 0; win < ics->window_group_length[g]; win++)
635
6.99M
            {
636
42.0M
                for (bin = 0; bin < width; bin += 4)
637
35.0M
                {
638
35.0M
                    uint16_t wb = wa + bin;
639
35.0M
#ifndef FIXED_POINT
640
35.0M
                    spec_data[wb+0] = iquant(quant_data[k+0], tab, &error) * scf;
641
35.0M
                    spec_data[wb+1] = iquant(quant_data[k+1], tab, &error) * scf;
642
35.0M
                    spec_data[wb+2] = iquant(quant_data[k+2], tab, &error) * scf;
643
35.0M
                    spec_data[wb+3] = iquant(quant_data[k+3], tab, &error) * scf;
644
#else
645
                    real_t iq0 = iquant(quant_data[k+0], tab, &error);
646
                    real_t iq1 = iquant(quant_data[k+1], tab, &error);
647
                    real_t iq2 = iquant(quant_data[k+2], tab, &error);
648
                    real_t iq3 = iquant(quant_data[k+3], tab, &error);
649
650
                    if (exp == -32)
651
                    {
652
                        spec_data[wb+0] = 0;
653
                        spec_data[wb+1] = 0;
654
                        spec_data[wb+2] = 0;
655
                        spec_data[wb+3] = 0;
656
                    } else if (exp <= 0) {
657
                        spec_data[wb+0] = iq0 >> -exp;
658
                        spec_data[wb+1] = iq1 >> -exp;
659
                        spec_data[wb+2] = iq2 >> -exp;
660
                        spec_data[wb+3] = iq3 >> -exp;
661
                    } else { /* exp > 0 */
662
                        spec_data[wb+0] = SAT_SHIFT(iq0, exp, sat_shift_mask);
663
                        spec_data[wb+1] = SAT_SHIFT(iq1, exp, sat_shift_mask);
664
                        spec_data[wb+2] = SAT_SHIFT(iq2, exp, sat_shift_mask);
665
                        spec_data[wb+3] = SAT_SHIFT(iq3, exp, sat_shift_mask);
666
                    }
667
                    if (frac != 0)
668
                    {
669
                        spec_data[wb+0] = MUL_C(spec_data[wb+0],pow2_table[frac]);
670
                        spec_data[wb+1] = MUL_C(spec_data[wb+1],pow2_table[frac]);
671
                        spec_data[wb+2] = MUL_C(spec_data[wb+2],pow2_table[frac]);
672
                        spec_data[wb+3] = MUL_C(spec_data[wb+3],pow2_table[frac]);
673
                    }
674
675
//#define SCFS_PRINT
676
#ifdef SCFS_PRINT
677
                    printf("%d\n", spec_data[gindex+(win*win_inc)+j+bin+0]);
678
                    printf("%d\n", spec_data[gindex+(win*win_inc)+j+bin+1]);
679
                    printf("%d\n", spec_data[gindex+(win*win_inc)+j+bin+2]);
680
                    printf("%d\n", spec_data[gindex+(win*win_inc)+j+bin+3]);
681
                    //printf("0x%.8X\n", spec_data[gindex+(win*win_inc)+j+bin+0]);
682
                    //printf("0x%.8X\n", spec_data[gindex+(win*win_inc)+j+bin+1]);
683
                    //printf("0x%.8X\n", spec_data[gindex+(win*win_inc)+j+bin+2]);
684
                    //printf("0x%.8X\n", spec_data[gindex+(win*win_inc)+j+bin+3]);
685
#endif
686
#endif
687
688
35.0M
                    gincrease += 4;
689
35.0M
                    k += 4;
690
35.0M
                }
691
6.99M
                wa += win_inc;
692
6.99M
            }
693
6.68M
            j += width;
694
6.68M
        }
695
223k
        gindex += gincrease;
696
223k
    }
697
698
138k
    return error;
699
138k
}
700
701
static uint8_t allocate_single_channel(NeAACDecStruct *hDecoder, uint8_t channel,
702
                                       uint8_t output_channels)
703
85.2k
{
704
85.2k
    int mul = 1;
705
706
#ifdef MAIN_DEC
707
    /* MAIN object type prediction */
708
    if (hDecoder->object_type == MAIN)
709
    {
710
        /* allocate the state only when needed */
711
        if (hDecoder->pred_stat[channel] != NULL)
712
        {
713
            faad_free(hDecoder->pred_stat[channel]);
714
            hDecoder->pred_stat[channel] = NULL;
715
        }
716
717
        hDecoder->pred_stat[channel] = (pred_state*)faad_malloc(hDecoder->frameLength * sizeof(pred_state));
718
        reset_all_predictors(hDecoder->pred_stat[channel], hDecoder->frameLength);
719
    }
720
#endif
721
722
#ifdef LTP_DEC
723
    if (is_ltp_ot(hDecoder->object_type))
724
    {
725
        /* allocate the state only when needed */
726
        if (hDecoder->lt_pred_stat[channel] != NULL)
727
        {
728
            faad_free(hDecoder->lt_pred_stat[channel]);
729
            hDecoder->lt_pred_stat[channel] = NULL;
730
        }
731
732
        hDecoder->lt_pred_stat[channel] = (int16_t*)faad_malloc(hDecoder->frameLength*4 * sizeof(int16_t));
733
        memset(hDecoder->lt_pred_stat[channel], 0, hDecoder->frameLength*4 * sizeof(int16_t));
734
    }
735
#endif
736
737
85.2k
    if (hDecoder->time_out[channel] != NULL)
738
0
    {
739
0
        faad_free(hDecoder->time_out[channel]);
740
0
        hDecoder->time_out[channel] = NULL;
741
0
    }
742
743
85.2k
    {
744
85.2k
        mul = 1;
745
85.2k
#ifdef SBR_DEC
746
85.2k
        hDecoder->sbr_alloced[hDecoder->fr_ch_ele] = 0;
747
85.2k
        if ((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
748
72.8k
        {
749
            /* SBR requires 2 times as much output data */
750
72.8k
            mul = 2;
751
72.8k
            hDecoder->sbr_alloced[hDecoder->fr_ch_ele] = 1;
752
72.8k
        }
753
85.2k
#endif
754
85.2k
        hDecoder->time_out[channel] = (real_t*)faad_malloc(mul*hDecoder->frameLength*sizeof(real_t));
755
85.2k
        memset(hDecoder->time_out[channel], 0, mul*hDecoder->frameLength*sizeof(real_t));
756
85.2k
    }
757
758
85.2k
#if (defined(PS_DEC) || defined(DRM_PS))
759
85.2k
    if (output_channels == 2)
760
85.2k
    {
761
85.2k
        if (hDecoder->time_out[channel+1] != NULL)
762
0
        {
763
0
            faad_free(hDecoder->time_out[channel+1]);
764
0
            hDecoder->time_out[channel+1] = NULL;
765
0
        }
766
767
85.2k
        hDecoder->time_out[channel+1] = (real_t*)faad_malloc(mul*hDecoder->frameLength*sizeof(real_t));
768
85.2k
        memset(hDecoder->time_out[channel+1], 0, mul*hDecoder->frameLength*sizeof(real_t));
769
85.2k
    }
770
85.2k
#endif
771
772
85.2k
    if (hDecoder->fb_intermed[channel] != NULL)
773
0
    {
774
0
        faad_free(hDecoder->fb_intermed[channel]);
775
0
        hDecoder->fb_intermed[channel] = NULL;
776
0
    }
777
778
85.2k
    hDecoder->fb_intermed[channel] = (real_t*)faad_malloc(hDecoder->frameLength*sizeof(real_t));
779
85.2k
    memset(hDecoder->fb_intermed[channel], 0, hDecoder->frameLength*sizeof(real_t));
780
781
#ifdef SSR_DEC
782
    if (hDecoder->object_type == SSR)
783
    {
784
        if (hDecoder->ssr_overlap[channel] == NULL)
785
        {
786
            hDecoder->ssr_overlap[channel] = (real_t*)faad_malloc(2*hDecoder->frameLength*sizeof(real_t));
787
            memset(hDecoder->ssr_overlap[channel], 0, 2*hDecoder->frameLength*sizeof(real_t));
788
        }
789
        if (hDecoder->prev_fmd[channel] == NULL)
790
        {
791
            uint16_t k;
792
            hDecoder->prev_fmd[channel] = (real_t*)faad_malloc(2*hDecoder->frameLength*sizeof(real_t));
793
            for (k = 0; k < 2*hDecoder->frameLength; k++)
794
                hDecoder->prev_fmd[channel][k] = REAL_CONST(-1);
795
        }
796
    }
797
#endif
798
799
85.2k
    return 0;
800
85.2k
}
801
802
static uint8_t allocate_channel_pair(NeAACDecStruct *hDecoder,
803
                                     uint8_t channel, uint8_t paired_channel)
804
16.5k
{
805
16.5k
    int mul = 1;
806
807
#ifdef MAIN_DEC
808
    /* MAIN object type prediction */
809
    if (hDecoder->object_type == MAIN)
810
    {
811
        /* allocate the state only when needed */
812
        if (hDecoder->pred_stat[channel] == NULL)
813
        {
814
            hDecoder->pred_stat[channel] = (pred_state*)faad_malloc(hDecoder->frameLength * sizeof(pred_state));
815
            reset_all_predictors(hDecoder->pred_stat[channel], hDecoder->frameLength);
816
        }
817
        if (hDecoder->pred_stat[paired_channel] == NULL)
818
        {
819
            hDecoder->pred_stat[paired_channel] = (pred_state*)faad_malloc(hDecoder->frameLength * sizeof(pred_state));
820
            reset_all_predictors(hDecoder->pred_stat[paired_channel], hDecoder->frameLength);
821
        }
822
    }
823
#endif
824
825
#ifdef LTP_DEC
826
    if (is_ltp_ot(hDecoder->object_type))
827
    {
828
        /* allocate the state only when needed */
829
        if (hDecoder->lt_pred_stat[channel] == NULL)
830
        {
831
            hDecoder->lt_pred_stat[channel] = (int16_t*)faad_malloc(hDecoder->frameLength*4 * sizeof(int16_t));
832
            memset(hDecoder->lt_pred_stat[channel], 0, hDecoder->frameLength*4 * sizeof(int16_t));
833
        }
834
        if (hDecoder->lt_pred_stat[paired_channel] == NULL)
835
        {
836
            hDecoder->lt_pred_stat[paired_channel] = (int16_t*)faad_malloc(hDecoder->frameLength*4 * sizeof(int16_t));
837
            memset(hDecoder->lt_pred_stat[paired_channel], 0, hDecoder->frameLength*4 * sizeof(int16_t));
838
        }
839
    }
840
#endif
841
842
16.5k
    {
843
16.5k
        mul = 1;
844
16.5k
#ifdef SBR_DEC
845
16.5k
        hDecoder->sbr_alloced[hDecoder->fr_ch_ele] = 0;
846
16.5k
        if ((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
847
14.5k
        {
848
            /* SBR requires 2 times as much output data */
849
14.5k
            mul = 2;
850
14.5k
            hDecoder->sbr_alloced[hDecoder->fr_ch_ele] = 1;
851
14.5k
        }
852
16.5k
#endif
853
16.5k
    }
854
16.5k
    if (hDecoder->time_out[channel] != NULL)
855
5
    {
856
5
        faad_free(hDecoder->time_out[channel]);
857
5
        hDecoder->time_out[channel] = NULL;
858
5
    }
859
16.5k
    if (hDecoder->time_out[paired_channel] != NULL)
860
5
    {
861
5
        faad_free(hDecoder->time_out[paired_channel]);
862
5
        hDecoder->time_out[paired_channel] = NULL;
863
5
    }
864
16.5k
    hDecoder->time_out[channel] = (real_t*)faad_malloc(mul*hDecoder->frameLength*sizeof(real_t));
865
16.5k
    memset(hDecoder->time_out[channel], 0, mul*hDecoder->frameLength*sizeof(real_t));
866
16.5k
    hDecoder->time_out[paired_channel] = (real_t*)faad_malloc(mul*hDecoder->frameLength*sizeof(real_t));
867
16.5k
    memset(hDecoder->time_out[paired_channel], 0, mul*hDecoder->frameLength*sizeof(real_t));
868
869
16.5k
    if (hDecoder->fb_intermed[channel] != NULL)
870
5
    {
871
5
        faad_free(hDecoder->fb_intermed[channel]);
872
5
        hDecoder->fb_intermed[channel] = NULL;
873
5
    }
874
16.5k
    if (hDecoder->fb_intermed[paired_channel] != NULL)
875
0
    {
876
0
        faad_free(hDecoder->fb_intermed[paired_channel]);
877
0
        hDecoder->fb_intermed[paired_channel] = NULL;
878
0
    }
879
16.5k
    hDecoder->fb_intermed[channel] = (real_t*)faad_malloc(hDecoder->frameLength*sizeof(real_t));
880
16.5k
    memset(hDecoder->fb_intermed[channel], 0, hDecoder->frameLength*sizeof(real_t));
881
16.5k
    hDecoder->fb_intermed[paired_channel] = (real_t*)faad_malloc(hDecoder->frameLength*sizeof(real_t));
882
16.5k
    memset(hDecoder->fb_intermed[paired_channel], 0, hDecoder->frameLength*sizeof(real_t));
883
884
#ifdef SSR_DEC
885
    if (hDecoder->object_type == SSR)
886
    {
887
        if (hDecoder->ssr_overlap[cpe->channel] == NULL)
888
        {
889
            hDecoder->ssr_overlap[cpe->channel] = (real_t*)faad_malloc(2*hDecoder->frameLength*sizeof(real_t));
890
            memset(hDecoder->ssr_overlap[cpe->channel], 0, 2*hDecoder->frameLength*sizeof(real_t));
891
        }
892
        if (hDecoder->ssr_overlap[cpe->paired_channel] == NULL)
893
        {
894
            hDecoder->ssr_overlap[cpe->paired_channel] = (real_t*)faad_malloc(2*hDecoder->frameLength*sizeof(real_t));
895
            memset(hDecoder->ssr_overlap[cpe->paired_channel], 0, 2*hDecoder->frameLength*sizeof(real_t));
896
        }
897
        if (hDecoder->prev_fmd[cpe->channel] == NULL)
898
        {
899
            uint16_t k;
900
            hDecoder->prev_fmd[cpe->channel] = (real_t*)faad_malloc(2*hDecoder->frameLength*sizeof(real_t));
901
            for (k = 0; k < 2*hDecoder->frameLength; k++)
902
                hDecoder->prev_fmd[cpe->channel][k] = REAL_CONST(-1);
903
        }
904
        if (hDecoder->prev_fmd[cpe->paired_channel] == NULL)
905
        {
906
            uint16_t k;
907
            hDecoder->prev_fmd[cpe->paired_channel] = (real_t*)faad_malloc(2*hDecoder->frameLength*sizeof(real_t));
908
            for (k = 0; k < 2*hDecoder->frameLength; k++)
909
                hDecoder->prev_fmd[cpe->paired_channel][k] = REAL_CONST(-1);
910
        }
911
    }
912
#endif
913
914
16.5k
    return 0;
915
16.5k
}
916
917
uint8_t reconstruct_single_channel(NeAACDecStruct *hDecoder, ic_stream *ics,
918
                                   element *sce, int16_t *spec_data)
919
98.9k
{
920
98.9k
    uint8_t retval;
921
98.9k
    uint8_t output_channels;
922
98.9k
    ALIGN real_t spec_coef[1024];
923
924
#ifdef PROFILE
925
    int64_t count = faad_get_ts();
926
#endif
927
928
929
    /* always allocate 2 channels, PS can always "suddenly" turn up */
930
98.9k
#if ( (defined(DRM) && defined(DRM_PS)) )
931
98.9k
    output_channels = 2;
932
#elif defined(PS_DEC)
933
    if (hDecoder->ps_used[hDecoder->fr_ch_ele])
934
        output_channels = 2;
935
    else
936
        output_channels = 1;
937
#else
938
    output_channels = 1;
939
#endif
940
941
98.9k
    if (hDecoder->element_output_channels[hDecoder->fr_ch_ele] == 0)
942
85.2k
    {
943
        /* element_output_channels not set yet */
944
85.2k
        hDecoder->element_output_channels[hDecoder->fr_ch_ele] = output_channels;
945
85.2k
    } else if (hDecoder->element_output_channels[hDecoder->fr_ch_ele] != output_channels) {
946
        /* element inconsistency */
947
948
        /* this only happens if PS is actually found but not in the first frame
949
         * this means that there is only 1 bitstream element!
950
         */
951
952
        /* The simplest way to fix the accounting,
953
         * is to reallocate this and all the following channels.
954
         */
955
0
        memset(&hDecoder->element_alloced[hDecoder->fr_ch_ele], 0,
956
0
            sizeof(uint8_t) * (MAX_SYNTAX_ELEMENTS - hDecoder->fr_ch_ele));
957
958
0
        hDecoder->element_output_channels[hDecoder->fr_ch_ele] = output_channels;
959
960
        //return 21;
961
0
    }
962
963
98.9k
    if (hDecoder->element_alloced[hDecoder->fr_ch_ele] == 0)
964
85.2k
    {
965
85.2k
        retval = allocate_single_channel(hDecoder, sce->channel, output_channels);
966
85.2k
        if (retval > 0)
967
0
            return retval;
968
969
85.2k
        hDecoder->element_alloced[hDecoder->fr_ch_ele] = 1;
970
85.2k
    }
971
972
    /* sanity check, CVE-2018-20199, CVE-2018-20360 */
973
98.9k
    if(!hDecoder->time_out[sce->channel])
974
0
        return 15;
975
98.9k
    if(output_channels > 1 && !hDecoder->time_out[sce->channel+1])
976
0
        return 15;
977
98.9k
    if(!hDecoder->fb_intermed[sce->channel])
978
0
        return 15;
979
980
    /* dequantisation and scaling */
981
98.9k
    retval = quant_to_spec(hDecoder, ics, spec_data, spec_coef, hDecoder->frameLength);
982
98.9k
    if (retval > 0)
983
57
        return retval;
984
985
#ifdef PROFILE
986
    count = faad_get_ts() - count;
987
    hDecoder->requant_cycles += count;
988
#endif
989
990
991
    /* pns decoding */
992
98.8k
    pns_decode(ics, NULL, spec_coef, NULL, hDecoder->frameLength, 0, hDecoder->object_type,
993
98.8k
        &(hDecoder->__r1), &(hDecoder->__r2));
994
995
#ifdef MAIN_DEC
996
    /* MAIN object type prediction */
997
    if (hDecoder->object_type == MAIN)
998
    {
999
    if (!hDecoder->pred_stat[sce->channel])
1000
      return 33;
1001
1002
        /* intra channel prediction */
1003
        ic_prediction(ics, spec_coef, hDecoder->pred_stat[sce->channel], hDecoder->frameLength,
1004
            hDecoder->sf_index);
1005
1006
        /* In addition, for scalefactor bands coded by perceptual
1007
           noise substitution the predictors belonging to the
1008
           corresponding spectral coefficients are reset.
1009
        */
1010
        pns_reset_pred_state(ics, hDecoder->pred_stat[sce->channel]);
1011
    }
1012
#endif
1013
1014
#ifdef LTP_DEC
1015
    if (is_ltp_ot(hDecoder->object_type))
1016
    {
1017
#ifdef LD_DEC
1018
        if (hDecoder->object_type == LD)
1019
        {
1020
            if (ics->ltp.data_present)
1021
            {
1022
                if (ics->ltp.lag_update)
1023
                    hDecoder->ltp_lag[sce->channel] = ics->ltp.lag;
1024
            }
1025
            ics->ltp.lag = hDecoder->ltp_lag[sce->channel];
1026
        }
1027
#endif
1028
1029
        /* long term prediction */
1030
        lt_prediction(ics, &(ics->ltp), spec_coef, hDecoder->lt_pred_stat[sce->channel], hDecoder->fb,
1031
            ics->window_shape, hDecoder->window_shape_prev[sce->channel],
1032
            hDecoder->sf_index, hDecoder->object_type, hDecoder->frameLength);
1033
    }
1034
#endif
1035
1036
    /* tns decoding */
1037
98.8k
    tns_decode_frame(ics, &(ics->tns), hDecoder->sf_index, hDecoder->object_type,
1038
98.8k
        spec_coef, hDecoder->frameLength);
1039
1040
    /* drc decoding */
1041
98.8k
#ifdef APPLY_DRC
1042
98.8k
    if (hDecoder->drc->present)
1043
0
    {
1044
0
        if (!hDecoder->drc->exclude_mask[sce->channel] || !hDecoder->drc->excluded_chns_present)
1045
0
            drc_decode(hDecoder->drc, spec_coef);
1046
0
    }
1047
98.8k
#endif
1048
    /* filter bank */
1049
#ifdef SSR_DEC
1050
    if (hDecoder->object_type != SSR)
1051
    {
1052
#endif
1053
98.8k
        ifilter_bank(hDecoder->fb, ics->window_sequence, ics->window_shape,
1054
98.8k
            hDecoder->window_shape_prev[sce->channel], spec_coef,
1055
98.8k
            hDecoder->time_out[sce->channel], hDecoder->fb_intermed[sce->channel],
1056
98.8k
            hDecoder->object_type, hDecoder->frameLength);
1057
#ifdef SSR_DEC
1058
    } else {
1059
        ssr_decode(&(ics->ssr), hDecoder->fb, ics->window_sequence, ics->window_shape,
1060
            hDecoder->window_shape_prev[sce->channel], spec_coef, hDecoder->time_out[sce->channel],
1061
            hDecoder->ssr_overlap[sce->channel], hDecoder->ipqf_buffer[sce->channel], hDecoder->prev_fmd[sce->channel],
1062
            hDecoder->frameLength);
1063
    }
1064
#endif
1065
1066
    /* save window shape for next frame */
1067
98.8k
    hDecoder->window_shape_prev[sce->channel] = ics->window_shape;
1068
1069
#ifdef LTP_DEC
1070
    if (is_ltp_ot(hDecoder->object_type))
1071
    {
1072
        lt_update_state(hDecoder->lt_pred_stat[sce->channel], hDecoder->time_out[sce->channel],
1073
            hDecoder->fb_intermed[sce->channel], hDecoder->frameLength, hDecoder->object_type);
1074
    }
1075
#endif
1076
1077
98.8k
#ifdef SBR_DEC
1078
98.8k
    if (((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
1079
85.1k
        && hDecoder->sbr_alloced[hDecoder->fr_ch_ele])
1080
85.1k
    {
1081
85.1k
        int ele = hDecoder->fr_ch_ele;
1082
85.1k
        int ch = sce->channel;
1083
1084
        /* following case can happen when forceUpSampling == 1 */
1085
85.1k
        if (hDecoder->sbr[ele] == NULL)
1086
61.8k
        {
1087
61.8k
            hDecoder->sbr[ele] = sbrDecodeInit(hDecoder->frameLength,
1088
61.8k
                hDecoder->element_id[ele], 2*get_sample_rate(hDecoder->sf_index),
1089
61.8k
                hDecoder->downSampledSBR
1090
61.8k
#ifdef DRM
1091
61.8k
                , 0
1092
61.8k
#endif
1093
61.8k
                );
1094
61.8k
        }
1095
85.1k
        if (!hDecoder->sbr[ele])
1096
0
            return 19;
1097
1098
85.1k
        if (sce->ics1.window_sequence == EIGHT_SHORT_SEQUENCE)
1099
10.3k
            hDecoder->sbr[ele]->maxAACLine = 8*min(sce->ics1.swb_offset[max(sce->ics1.max_sfb-1, 0)], sce->ics1.swb_offset_max);
1100
74.7k
        else
1101
74.7k
            hDecoder->sbr[ele]->maxAACLine = min(sce->ics1.swb_offset[max(sce->ics1.max_sfb-1, 0)], sce->ics1.swb_offset_max);
1102
1103
        /* check if any of the PS tools is used */
1104
85.1k
#if (defined(PS_DEC) || defined(DRM_PS))
1105
85.1k
        if (hDecoder->ps_used[ele] == 0)
1106
79.6k
        {
1107
79.6k
#endif
1108
79.6k
            retval = sbrDecodeSingleFrame(hDecoder->sbr[ele], hDecoder->time_out[ch],
1109
79.6k
                hDecoder->postSeekResetFlag, hDecoder->downSampledSBR);
1110
79.6k
#if (defined(PS_DEC) || defined(DRM_PS))
1111
79.6k
        } else {
1112
5.47k
            retval = sbrDecodeSingleFramePS(hDecoder->sbr[ele], hDecoder->time_out[ch],
1113
5.47k
                hDecoder->time_out[ch+1], hDecoder->postSeekResetFlag,
1114
5.47k
                hDecoder->downSampledSBR);
1115
5.47k
        }
1116
85.1k
#endif
1117
85.1k
        if (retval > 0)
1118
12
            return retval;
1119
85.1k
    } else if (((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
1120
1
        && !hDecoder->sbr_alloced[hDecoder->fr_ch_ele])
1121
1
    {
1122
1
        return 23;
1123
1
    }
1124
98.8k
#endif
1125
1126
    /* copy L to R when no PS is used */
1127
98.8k
#if (defined(PS_DEC) || defined(DRM_PS))
1128
98.8k
    if ((hDecoder->ps_used[hDecoder->fr_ch_ele] == 0) &&
1129
93.3k
        (hDecoder->element_output_channels[hDecoder->fr_ch_ele] == 2))
1130
93.3k
    {
1131
93.3k
        int ele = hDecoder->fr_ch_ele;
1132
93.3k
        int ch = sce->channel;
1133
93.3k
        int frame_size = (hDecoder->sbr_alloced[ele]) ? 2 : 1;
1134
93.3k
        frame_size *= hDecoder->frameLength*sizeof(real_t);
1135
1136
93.3k
        memcpy(hDecoder->time_out[ch+1], hDecoder->time_out[ch], frame_size);
1137
93.3k
    }
1138
98.8k
#endif
1139
1140
98.8k
    return 0;
1141
98.8k
}
1142
1143
uint8_t reconstruct_channel_pair(NeAACDecStruct *hDecoder, ic_stream *ics1, ic_stream *ics2,
1144
                                 element *cpe, int16_t *spec_data1, int16_t *spec_data2)
1145
19.9k
{
1146
19.9k
    uint8_t retval;
1147
19.9k
    ALIGN real_t spec_coef1[1024];
1148
19.9k
    ALIGN real_t spec_coef2[1024];
1149
1150
#ifdef PROFILE
1151
    int64_t count = faad_get_ts();
1152
#endif
1153
19.9k
    if (hDecoder->element_alloced[hDecoder->fr_ch_ele] != 2)
1154
16.5k
    {
1155
16.5k
        retval = allocate_channel_pair(hDecoder, cpe->channel, (uint8_t)cpe->paired_channel);
1156
16.5k
        if (retval > 0)
1157
0
            return retval;
1158
1159
16.5k
        hDecoder->element_alloced[hDecoder->fr_ch_ele] = 2;
1160
16.5k
    }
1161
1162
    /* sanity check, CVE-2018-20199, CVE-2018-20360 */
1163
19.9k
    if(!hDecoder->time_out[cpe->channel] || !hDecoder->time_out[cpe->paired_channel])
1164
0
        return 15;
1165
19.9k
    if(!hDecoder->fb_intermed[cpe->channel] || !hDecoder->fb_intermed[cpe->paired_channel])
1166
0
        return 15;
1167
1168
    /* dequantisation and scaling */
1169
19.9k
    retval = quant_to_spec(hDecoder, ics1, spec_data1, spec_coef1, hDecoder->frameLength);
1170
19.9k
    if (retval > 0)
1171
63
        return retval;
1172
19.8k
    retval = quant_to_spec(hDecoder, ics2, spec_data2, spec_coef2, hDecoder->frameLength);
1173
19.8k
    if (retval > 0)
1174
3
        return retval;
1175
1176
#ifdef PROFILE
1177
    count = faad_get_ts() - count;
1178
    hDecoder->requant_cycles += count;
1179
#endif
1180
1181
    /* pns decoding */
1182
19.8k
    if (ics1->ms_mask_present)
1183
6.43k
    {
1184
6.43k
        pns_decode(ics1, ics2, spec_coef1, spec_coef2, hDecoder->frameLength, 1, hDecoder->object_type,
1185
6.43k
            &(hDecoder->__r1), &(hDecoder->__r2));
1186
13.4k
    } else {
1187
13.4k
        pns_decode(ics1, ics2, spec_coef1, spec_coef2, hDecoder->frameLength, 0, hDecoder->object_type,
1188
13.4k
            &(hDecoder->__r1), &(hDecoder->__r2));
1189
13.4k
    }
1190
1191
    /* mid/side decoding */
1192
19.8k
    ms_decode(ics1, ics2, spec_coef1, spec_coef2, hDecoder->frameLength);
1193
1194
#if 0
1195
    {
1196
        int i;
1197
        for (i = 0; i < 1024; i++)
1198
        {
1199
            //printf("%d\n", spec_coef1[i]);
1200
            printf("0x%.8X\n", spec_coef1[i]);
1201
        }
1202
        for (i = 0; i < 1024; i++)
1203
        {
1204
            //printf("%d\n", spec_coef2[i]);
1205
            printf("0x%.8X\n", spec_coef2[i]);
1206
        }
1207
    }
1208
#endif
1209
1210
    /* intensity stereo decoding */
1211
19.8k
    is_decode(ics1, ics2, spec_coef1, spec_coef2, hDecoder->frameLength);
1212
1213
#if 0
1214
    {
1215
        int i;
1216
        for (i = 0; i < 1024; i++)
1217
        {
1218
            printf("%d\n", spec_coef1[i]);
1219
            //printf("0x%.8X\n", spec_coef1[i]);
1220
        }
1221
        for (i = 0; i < 1024; i++)
1222
        {
1223
            printf("%d\n", spec_coef2[i]);
1224
            //printf("0x%.8X\n", spec_coef2[i]);
1225
        }
1226
    }
1227
#endif
1228
1229
#ifdef MAIN_DEC
1230
    /* MAIN object type prediction */
1231
    if (hDecoder->object_type == MAIN)
1232
    {
1233
        /* intra channel prediction */
1234
        ic_prediction(ics1, spec_coef1, hDecoder->pred_stat[cpe->channel], hDecoder->frameLength,
1235
            hDecoder->sf_index);
1236
        ic_prediction(ics2, spec_coef2, hDecoder->pred_stat[cpe->paired_channel], hDecoder->frameLength,
1237
            hDecoder->sf_index);
1238
1239
        /* In addition, for scalefactor bands coded by perceptual
1240
           noise substitution the predictors belonging to the
1241
           corresponding spectral coefficients are reset.
1242
        */
1243
        pns_reset_pred_state(ics1, hDecoder->pred_stat[cpe->channel]);
1244
        pns_reset_pred_state(ics2, hDecoder->pred_stat[cpe->paired_channel]);
1245
    }
1246
#endif
1247
1248
#ifdef LTP_DEC
1249
    if (is_ltp_ot(hDecoder->object_type))
1250
    {
1251
        ltp_info *ltp1 = &(ics1->ltp);
1252
        ltp_info *ltp2 = (cpe->common_window) ? &(ics2->ltp2) : &(ics2->ltp);
1253
#ifdef LD_DEC
1254
        if (hDecoder->object_type == LD)
1255
        {
1256
            if (ltp1->data_present)
1257
            {
1258
                if (ltp1->lag_update)
1259
                    hDecoder->ltp_lag[cpe->channel] = ltp1->lag;
1260
            }
1261
            ltp1->lag = hDecoder->ltp_lag[cpe->channel];
1262
            if (ltp2->data_present)
1263
            {
1264
                if (ltp2->lag_update)
1265
                    hDecoder->ltp_lag[cpe->paired_channel] = ltp2->lag;
1266
            }
1267
            ltp2->lag = hDecoder->ltp_lag[cpe->paired_channel];
1268
        }
1269
#endif
1270
1271
        /* long term prediction */
1272
        lt_prediction(ics1, ltp1, spec_coef1, hDecoder->lt_pred_stat[cpe->channel], hDecoder->fb,
1273
            ics1->window_shape, hDecoder->window_shape_prev[cpe->channel],
1274
            hDecoder->sf_index, hDecoder->object_type, hDecoder->frameLength);
1275
        lt_prediction(ics2, ltp2, spec_coef2, hDecoder->lt_pred_stat[cpe->paired_channel], hDecoder->fb,
1276
            ics2->window_shape, hDecoder->window_shape_prev[cpe->paired_channel],
1277
            hDecoder->sf_index, hDecoder->object_type, hDecoder->frameLength);
1278
    }
1279
#endif
1280
1281
    /* tns decoding */
1282
19.8k
    tns_decode_frame(ics1, &(ics1->tns), hDecoder->sf_index, hDecoder->object_type,
1283
19.8k
        spec_coef1, hDecoder->frameLength);
1284
19.8k
    tns_decode_frame(ics2, &(ics2->tns), hDecoder->sf_index, hDecoder->object_type,
1285
19.8k
        spec_coef2, hDecoder->frameLength);
1286
1287
    /* drc decoding */
1288
19.8k
#if APPLY_DRC
1289
19.8k
    if (hDecoder->drc->present)
1290
0
    {
1291
0
        if (!hDecoder->drc->exclude_mask[cpe->channel] || !hDecoder->drc->excluded_chns_present)
1292
0
            drc_decode(hDecoder->drc, spec_coef1);
1293
0
        if (!hDecoder->drc->exclude_mask[cpe->paired_channel] || !hDecoder->drc->excluded_chns_present)
1294
0
            drc_decode(hDecoder->drc, spec_coef2);
1295
0
    }
1296
19.8k
#endif
1297
    /* filter bank */
1298
#ifdef SSR_DEC
1299
    if (hDecoder->object_type != SSR)
1300
    {
1301
#endif
1302
19.8k
        ifilter_bank(hDecoder->fb, ics1->window_sequence, ics1->window_shape,
1303
19.8k
            hDecoder->window_shape_prev[cpe->channel], spec_coef1,
1304
19.8k
            hDecoder->time_out[cpe->channel], hDecoder->fb_intermed[cpe->channel],
1305
19.8k
            hDecoder->object_type, hDecoder->frameLength);
1306
19.8k
        ifilter_bank(hDecoder->fb, ics2->window_sequence, ics2->window_shape,
1307
19.8k
            hDecoder->window_shape_prev[cpe->paired_channel], spec_coef2,
1308
19.8k
            hDecoder->time_out[cpe->paired_channel], hDecoder->fb_intermed[cpe->paired_channel],
1309
19.8k
            hDecoder->object_type, hDecoder->frameLength);
1310
#ifdef SSR_DEC
1311
    } else {
1312
        ssr_decode(&(ics1->ssr), hDecoder->fb, ics1->window_sequence, ics1->window_shape,
1313
            hDecoder->window_shape_prev[cpe->channel], spec_coef1, hDecoder->time_out[cpe->channel],
1314
            hDecoder->ssr_overlap[cpe->channel], hDecoder->ipqf_buffer[cpe->channel],
1315
            hDecoder->prev_fmd[cpe->channel], hDecoder->frameLength);
1316
        ssr_decode(&(ics2->ssr), hDecoder->fb, ics2->window_sequence, ics2->window_shape,
1317
            hDecoder->window_shape_prev[cpe->paired_channel], spec_coef2, hDecoder->time_out[cpe->paired_channel],
1318
            hDecoder->ssr_overlap[cpe->paired_channel], hDecoder->ipqf_buffer[cpe->paired_channel],
1319
            hDecoder->prev_fmd[cpe->paired_channel], hDecoder->frameLength);
1320
    }
1321
#endif
1322
1323
    /* save window shape for next frame */
1324
19.8k
    hDecoder->window_shape_prev[cpe->channel] = ics1->window_shape;
1325
19.8k
    hDecoder->window_shape_prev[cpe->paired_channel] = ics2->window_shape;
1326
1327
#ifdef LTP_DEC
1328
    if (is_ltp_ot(hDecoder->object_type))
1329
    {
1330
        lt_update_state(hDecoder->lt_pred_stat[cpe->channel], hDecoder->time_out[cpe->channel],
1331
            hDecoder->fb_intermed[cpe->channel], hDecoder->frameLength, hDecoder->object_type);
1332
        lt_update_state(hDecoder->lt_pred_stat[cpe->paired_channel], hDecoder->time_out[cpe->paired_channel],
1333
            hDecoder->fb_intermed[cpe->paired_channel], hDecoder->frameLength, hDecoder->object_type);
1334
    }
1335
#endif
1336
1337
19.8k
#ifdef SBR_DEC
1338
19.8k
    if (((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
1339
17.7k
        && hDecoder->sbr_alloced[hDecoder->fr_ch_ele])
1340
17.7k
    {
1341
17.7k
        int ele = hDecoder->fr_ch_ele;
1342
17.7k
        int ch0 = cpe->channel;
1343
17.7k
        int ch1 = cpe->paired_channel;
1344
1345
        /* following case can happen when forceUpSampling == 1 */
1346
17.7k
        if (hDecoder->sbr[ele] == NULL)
1347
3.88k
        {
1348
3.88k
            hDecoder->sbr[ele] = sbrDecodeInit(hDecoder->frameLength,
1349
3.88k
                hDecoder->element_id[ele], 2*get_sample_rate(hDecoder->sf_index),
1350
3.88k
                hDecoder->downSampledSBR
1351
3.88k
#ifdef DRM
1352
3.88k
                , 0
1353
3.88k
#endif
1354
3.88k
                );
1355
3.88k
        }
1356
17.7k
        if (!hDecoder->sbr[ele])
1357
0
            return 19;
1358
1359
17.7k
        if (cpe->ics1.window_sequence == EIGHT_SHORT_SEQUENCE)
1360
680
            hDecoder->sbr[ele]->maxAACLine = 8*min(cpe->ics1.swb_offset[max(cpe->ics1.max_sfb-1, 0)], cpe->ics1.swb_offset_max);
1361
17.0k
        else
1362
17.0k
            hDecoder->sbr[ele]->maxAACLine = min(cpe->ics1.swb_offset[max(cpe->ics1.max_sfb-1, 0)], cpe->ics1.swb_offset_max);
1363
1364
17.7k
        retval = sbrDecodeCoupleFrame(hDecoder->sbr[ele],
1365
17.7k
            hDecoder->time_out[ch0], hDecoder->time_out[ch1],
1366
17.7k
            hDecoder->postSeekResetFlag, hDecoder->downSampledSBR);
1367
17.7k
        if (retval > 0)
1368
5
            return retval;
1369
17.7k
    } else if (((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
1370
1
        && !hDecoder->sbr_alloced[hDecoder->fr_ch_ele])
1371
1
    {
1372
1
        return 23;
1373
1
    }
1374
19.8k
#endif
1375
1376
19.8k
    return 0;
1377
19.8k
}