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
0
#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
0
{
304
0
    uint8_t i, g;
305
306
0
    uint8_t sf_index = hDecoder->sf_index;
307
308
0
    if (sf_index >= 12)
309
0
        return 32;
310
311
0
    switch (ics->window_sequence) {
312
0
    case ONLY_LONG_SEQUENCE:
313
0
    case LONG_START_SEQUENCE:
314
0
    case LONG_STOP_SEQUENCE:
315
0
        ics->num_windows = 1;
316
0
        ics->num_window_groups = 1;
317
0
        ics->window_group_length[ics->num_window_groups-1] = 1;
318
0
#ifdef LD_DEC
319
0
        if (hDecoder->object_type == LD)
320
0
        {
321
0
            if (hDecoder->frameLength == 512)
322
0
                ics->num_swb = num_swb_512_window[sf_index];
323
0
            else /* if (hDecoder->frameLength == 480) */
324
0
                ics->num_swb = num_swb_480_window[sf_index];
325
0
        } else {
326
0
#endif
327
0
            if (hDecoder->frameLength == 1024)
328
0
                ics->num_swb = num_swb_1024_window[sf_index];
329
0
            else /* if (hDecoder->frameLength == 960) */
330
0
                ics->num_swb = num_swb_960_window[sf_index];
331
0
#ifdef LD_DEC
332
0
        }
333
0
#endif
334
335
0
        if (ics->max_sfb > ics->num_swb)
336
0
        {
337
0
            return 32;
338
0
        }
339
340
        /* preparation of sect_sfb_offset for long blocks */
341
        /* also copy the last value! */
342
0
#ifdef LD_DEC
343
0
        if (hDecoder->object_type == LD)
344
0
        {
345
0
            if (hDecoder->frameLength == 512)
346
0
            {
347
0
                for (i = 0; i < ics->num_swb; i++)
348
0
                {
349
0
                    ics->sect_sfb_offset[0][i] = swb_offset_512_window[sf_index][i];
350
0
                    ics->swb_offset[i] = swb_offset_512_window[sf_index][i];
351
0
                }
352
0
            } else /* if (hDecoder->frameLength == 480) */ {
353
0
                for (i = 0; i < ics->num_swb; i++)
354
0
                {
355
0
                    ics->sect_sfb_offset[0][i] = swb_offset_480_window[sf_index][i];
356
0
                    ics->swb_offset[i] = swb_offset_480_window[sf_index][i];
357
0
                }
358
0
            }
359
0
            ics->sect_sfb_offset[0][ics->num_swb] = hDecoder->frameLength;
360
0
            ics->swb_offset[ics->num_swb] = hDecoder->frameLength;
361
0
            ics->swb_offset_max = hDecoder->frameLength;
362
0
        } else {
363
0
#endif
364
0
            for (i = 0; i < ics->num_swb; i++)
365
0
            {
366
0
                ics->sect_sfb_offset[0][i] = swb_offset_1024_window[sf_index][i];
367
0
                ics->swb_offset[i] = swb_offset_1024_window[sf_index][i];
368
0
            }
369
0
            ics->sect_sfb_offset[0][ics->num_swb] = hDecoder->frameLength;
370
0
            ics->swb_offset[ics->num_swb] = hDecoder->frameLength;
371
0
            ics->swb_offset_max = hDecoder->frameLength;
372
0
#ifdef LD_DEC
373
0
        }
374
0
#endif
375
0
        return 0;
376
0
    case EIGHT_SHORT_SEQUENCE:
377
0
        ics->num_windows = 8;
378
0
        ics->num_window_groups = 1;
379
0
        ics->window_group_length[ics->num_window_groups-1] = 1;
380
0
        ics->num_swb = num_swb_128_window[sf_index];
381
382
0
        if (ics->max_sfb > ics->num_swb)
383
0
        {
384
0
            return 32;
385
0
        }
386
387
0
        for (i = 0; i < ics->num_swb; i++)
388
0
            ics->swb_offset[i] = swb_offset_128_window[sf_index][i];
389
0
        ics->swb_offset[ics->num_swb] = hDecoder->frameLength/8;
390
0
        ics->swb_offset_max = hDecoder->frameLength/8;
391
392
0
        for (i = 0; i < ics->num_windows-1; i++) {
393
0
            if (bit_set(ics->scale_factor_grouping, 6-i) == 0)
394
0
            {
395
0
                ics->num_window_groups += 1;
396
0
                ics->window_group_length[ics->num_window_groups-1] = 1;
397
0
            } else {
398
0
                ics->window_group_length[ics->num_window_groups-1] += 1;
399
0
            }
400
0
        }
401
402
        /* preparation of sect_sfb_offset for short blocks */
403
0
        for (g = 0; g < ics->num_window_groups; g++)
404
0
        {
405
0
            uint16_t width;
406
0
            uint8_t sect_sfb = 0;
407
0
            uint16_t offset = 0;
408
409
0
            for (i = 0; i < ics->num_swb; i++)
410
0
            {
411
0
                if (i+1 == ics->num_swb)
412
0
                {
413
0
                    width = (hDecoder->frameLength/8) - swb_offset_128_window[sf_index][i];
414
0
                } else {
415
0
                    width = swb_offset_128_window[sf_index][i+1] -
416
0
                        swb_offset_128_window[sf_index][i];
417
0
                }
418
0
                width *= ics->window_group_length[g];
419
0
                ics->sect_sfb_offset[g][sect_sfb++] = offset;
420
0
                offset += width;
421
0
            }
422
0
            ics->sect_sfb_offset[g][sect_sfb] = offset;
423
0
        }
424
0
        return 0;
425
0
    default:
426
0
        return 32;
427
0
    }
428
0
}
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
0
{
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
0
    if (q < 0)
486
0
    {
487
        /* tab contains a value for all possible q [0,8192] */
488
0
        if (-q < IQ_TABLE_SIZE)
489
0
            return -tab[-q];
490
491
0
        *error = 17;
492
0
        return 0;
493
0
    } else {
494
        /* tab contains a value for all possible q [0,8192] */
495
0
        if (q < IQ_TABLE_SIZE)
496
0
            return tab[q];
497
498
0
        *error = 17;
499
0
        return 0;
500
0
    }
501
0
#endif
502
0
}
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
0
{
557
0
    ALIGN static const real_t pow2_table[] =
558
0
    {
559
0
        COEF_CONST(1.0),
560
0
        COEF_CONST(1.1892071150027210667174999705605), /* 2^0.25 */
561
0
        COEF_CONST(1.4142135623730950488016887242097), /* 2^0.5 */
562
0
        COEF_CONST(1.6817928305074290860622509524664) /* 2^0.75 */
563
0
    };
564
0
    const real_t *tab = iq_table;
565
566
0
    uint8_t g, sfb, win;
567
0
    uint16_t width, bin, k, gindex;
568
0
    uint8_t error = 0; /* Init error flag */
569
0
#ifndef FIXED_POINT
570
0
    real_t scf;
571
#else
572
    int32_t sat_shift_mask = 0;
573
#endif
574
575
0
    k = 0;
576
0
    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
0
    if (ics->num_swb == 0)
582
0
        memset(spec_data, 0, frame_len * sizeof(real_t));
583
584
0
    for (g = 0; g < ics->num_window_groups; g++)
585
0
    {
586
0
        uint16_t j = 0;
587
0
        uint16_t gincrease = 0;
588
0
        uint16_t win_inc = ics->swb_offset[ics->num_swb];
589
590
0
        for (sfb = 0; sfb < ics->num_swb; sfb++)
591
0
        {
592
0
            int32_t exp, frac;
593
0
            uint16_t wa = gindex + j;
594
0
            int16_t scale_factor = ics->scale_factors[g][sfb];
595
596
0
            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
0
            (void)hDecoder;
614
0
#endif
615
616
            /* scale_factor for IS or PNS, has different meaning; fill with almost zeroes */
617
0
            if (is_intensity(ics, g, sfb) || is_noise(ics, g, sfb))
618
0
            {
619
0
                scale_factor = 0;
620
0
            }
621
622
            /* scale_factor must be between 0 and 255 */
623
0
            exp = (scale_factor /* - 100 */) >> 2;
624
            /* frac must always be > 0 */
625
0
            frac = (scale_factor /* - 100 */) & 3;
626
627
0
#ifndef FIXED_POINT
628
0
            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
0
            for (win = 0; win < ics->window_group_length[g]; win++)
635
0
            {
636
0
                for (bin = 0; bin < width; bin += 4)
637
0
                {
638
0
                    uint16_t wb = wa + bin;
639
0
#ifndef FIXED_POINT
640
0
                    spec_data[wb+0] = iquant(quant_data[k+0], tab, &error) * scf;
641
0
                    spec_data[wb+1] = iquant(quant_data[k+1], tab, &error) * scf;
642
0
                    spec_data[wb+2] = iquant(quant_data[k+2], tab, &error) * scf;
643
0
                    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
0
                    gincrease += 4;
689
0
                    k += 4;
690
0
                }
691
0
                wa += win_inc;
692
0
            }
693
0
            j += width;
694
0
        }
695
0
        gindex += gincrease;
696
0
    }
697
698
0
    return error;
699
0
}
700
701
static uint8_t allocate_single_channel(NeAACDecStruct *hDecoder, uint8_t channel,
702
                                       uint8_t output_channels)
703
0
{
704
0
    int mul = 1;
705
706
0
#ifdef MAIN_DEC
707
    /* MAIN object type prediction */
708
0
    if (hDecoder->object_type == MAIN)
709
0
    {
710
        /* allocate the state only when needed */
711
0
        if (hDecoder->pred_stat[channel] != NULL)
712
0
        {
713
0
            faad_free(hDecoder->pred_stat[channel]);
714
0
            hDecoder->pred_stat[channel] = NULL;
715
0
        }
716
717
0
        hDecoder->pred_stat[channel] = (pred_state*)faad_malloc(hDecoder->frameLength * sizeof(pred_state));
718
0
        reset_all_predictors(hDecoder->pred_stat[channel], hDecoder->frameLength);
719
0
    }
720
0
#endif
721
722
0
#ifdef LTP_DEC
723
0
    if (is_ltp_ot(hDecoder->object_type))
724
0
    {
725
        /* allocate the state only when needed */
726
0
        if (hDecoder->lt_pred_stat[channel] != NULL)
727
0
        {
728
0
            faad_free(hDecoder->lt_pred_stat[channel]);
729
0
            hDecoder->lt_pred_stat[channel] = NULL;
730
0
        }
731
732
0
        hDecoder->lt_pred_stat[channel] = (int16_t*)faad_malloc(hDecoder->frameLength*4 * sizeof(int16_t));
733
0
        memset(hDecoder->lt_pred_stat[channel], 0, hDecoder->frameLength*4 * sizeof(int16_t));
734
0
    }
735
0
#endif
736
737
0
    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
0
    {
744
0
        mul = 1;
745
0
#ifdef SBR_DEC
746
0
        hDecoder->sbr_alloced[hDecoder->fr_ch_ele] = 0;
747
0
        if ((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
748
0
        {
749
            /* SBR requires 2 times as much output data */
750
0
            mul = 2;
751
0
            hDecoder->sbr_alloced[hDecoder->fr_ch_ele] = 1;
752
0
        }
753
0
#endif
754
0
        hDecoder->time_out[channel] = (real_t*)faad_malloc(mul*hDecoder->frameLength*sizeof(real_t));
755
0
        memset(hDecoder->time_out[channel], 0, mul*hDecoder->frameLength*sizeof(real_t));
756
0
    }
757
758
0
#if (defined(PS_DEC) || defined(DRM_PS))
759
0
    if (output_channels == 2)
760
0
    {
761
0
        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
0
        hDecoder->time_out[channel+1] = (real_t*)faad_malloc(mul*hDecoder->frameLength*sizeof(real_t));
768
0
        memset(hDecoder->time_out[channel+1], 0, mul*hDecoder->frameLength*sizeof(real_t));
769
0
    }
770
0
#endif
771
772
0
    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
0
    hDecoder->fb_intermed[channel] = (real_t*)faad_malloc(hDecoder->frameLength*sizeof(real_t));
779
0
    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
0
    return 0;
800
0
}
801
802
static uint8_t allocate_channel_pair(NeAACDecStruct *hDecoder,
803
                                     uint8_t channel, uint8_t paired_channel)
804
0
{
805
0
    int mul = 1;
806
807
0
#ifdef MAIN_DEC
808
    /* MAIN object type prediction */
809
0
    if (hDecoder->object_type == MAIN)
810
0
    {
811
        /* allocate the state only when needed */
812
0
        if (hDecoder->pred_stat[channel] == NULL)
813
0
        {
814
0
            hDecoder->pred_stat[channel] = (pred_state*)faad_malloc(hDecoder->frameLength * sizeof(pred_state));
815
0
            reset_all_predictors(hDecoder->pred_stat[channel], hDecoder->frameLength);
816
0
        }
817
0
        if (hDecoder->pred_stat[paired_channel] == NULL)
818
0
        {
819
0
            hDecoder->pred_stat[paired_channel] = (pred_state*)faad_malloc(hDecoder->frameLength * sizeof(pred_state));
820
0
            reset_all_predictors(hDecoder->pred_stat[paired_channel], hDecoder->frameLength);
821
0
        }
822
0
    }
823
0
#endif
824
825
0
#ifdef LTP_DEC
826
0
    if (is_ltp_ot(hDecoder->object_type))
827
0
    {
828
        /* allocate the state only when needed */
829
0
        if (hDecoder->lt_pred_stat[channel] == NULL)
830
0
        {
831
0
            hDecoder->lt_pred_stat[channel] = (int16_t*)faad_malloc(hDecoder->frameLength*4 * sizeof(int16_t));
832
0
            memset(hDecoder->lt_pred_stat[channel], 0, hDecoder->frameLength*4 * sizeof(int16_t));
833
0
        }
834
0
        if (hDecoder->lt_pred_stat[paired_channel] == NULL)
835
0
        {
836
0
            hDecoder->lt_pred_stat[paired_channel] = (int16_t*)faad_malloc(hDecoder->frameLength*4 * sizeof(int16_t));
837
0
            memset(hDecoder->lt_pred_stat[paired_channel], 0, hDecoder->frameLength*4 * sizeof(int16_t));
838
0
        }
839
0
    }
840
0
#endif
841
842
0
    {
843
0
        mul = 1;
844
0
#ifdef SBR_DEC
845
0
        hDecoder->sbr_alloced[hDecoder->fr_ch_ele] = 0;
846
0
        if ((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
847
0
        {
848
            /* SBR requires 2 times as much output data */
849
0
            mul = 2;
850
0
            hDecoder->sbr_alloced[hDecoder->fr_ch_ele] = 1;
851
0
        }
852
0
#endif
853
0
    }
854
0
    if (hDecoder->time_out[channel] != NULL)
855
0
    {
856
0
        faad_free(hDecoder->time_out[channel]);
857
0
        hDecoder->time_out[channel] = NULL;
858
0
    }
859
0
    if (hDecoder->time_out[paired_channel] != NULL)
860
0
    {
861
0
        faad_free(hDecoder->time_out[paired_channel]);
862
0
        hDecoder->time_out[paired_channel] = NULL;
863
0
    }
864
0
    hDecoder->time_out[channel] = (real_t*)faad_malloc(mul*hDecoder->frameLength*sizeof(real_t));
865
0
    memset(hDecoder->time_out[channel], 0, mul*hDecoder->frameLength*sizeof(real_t));
866
0
    hDecoder->time_out[paired_channel] = (real_t*)faad_malloc(mul*hDecoder->frameLength*sizeof(real_t));
867
0
    memset(hDecoder->time_out[paired_channel], 0, mul*hDecoder->frameLength*sizeof(real_t));
868
869
0
    if (hDecoder->fb_intermed[channel] != NULL)
870
0
    {
871
0
        faad_free(hDecoder->fb_intermed[channel]);
872
0
        hDecoder->fb_intermed[channel] = NULL;
873
0
    }
874
0
    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
0
    hDecoder->fb_intermed[channel] = (real_t*)faad_malloc(hDecoder->frameLength*sizeof(real_t));
880
0
    memset(hDecoder->fb_intermed[channel], 0, hDecoder->frameLength*sizeof(real_t));
881
0
    hDecoder->fb_intermed[paired_channel] = (real_t*)faad_malloc(hDecoder->frameLength*sizeof(real_t));
882
0
    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
0
    return 0;
915
0
}
916
917
uint8_t reconstruct_single_channel(NeAACDecStruct *hDecoder, ic_stream *ics,
918
                                   element *sce, int16_t *spec_data)
919
0
{
920
0
    uint8_t retval;
921
0
    uint8_t output_channels;
922
0
    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
#if ( (defined(DRM) && defined(DRM_PS)) )
931
    output_channels = 2;
932
#elif defined(PS_DEC)
933
0
    if (hDecoder->ps_used[hDecoder->fr_ch_ele])
934
0
        output_channels = 2;
935
0
    else
936
0
        output_channels = 1;
937
#else
938
    output_channels = 1;
939
#endif
940
941
0
    if (hDecoder->element_output_channels[hDecoder->fr_ch_ele] == 0)
942
0
    {
943
        /* element_output_channels not set yet */
944
0
        hDecoder->element_output_channels[hDecoder->fr_ch_ele] = output_channels;
945
0
    } 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
0
    if (hDecoder->element_alloced[hDecoder->fr_ch_ele] == 0)
964
0
    {
965
0
        retval = allocate_single_channel(hDecoder, sce->channel, output_channels);
966
0
        if (retval > 0)
967
0
            return retval;
968
969
0
        hDecoder->element_alloced[hDecoder->fr_ch_ele] = 1;
970
0
    }
971
972
    /* sanity check, CVE-2018-20199, CVE-2018-20360 */
973
0
    if(!hDecoder->time_out[sce->channel])
974
0
        return 15;
975
0
    if(output_channels > 1 && !hDecoder->time_out[sce->channel+1])
976
0
        return 15;
977
0
    if(!hDecoder->fb_intermed[sce->channel])
978
0
        return 15;
979
980
    /* dequantisation and scaling */
981
0
    retval = quant_to_spec(hDecoder, ics, spec_data, spec_coef, hDecoder->frameLength);
982
0
    if (retval > 0)
983
0
        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
0
    pns_decode(ics, NULL, spec_coef, NULL, hDecoder->frameLength, 0, hDecoder->object_type,
993
0
        &(hDecoder->__r1), &(hDecoder->__r2));
994
995
0
#ifdef MAIN_DEC
996
    /* MAIN object type prediction */
997
0
    if (hDecoder->object_type == MAIN)
998
0
    {
999
0
    if (!hDecoder->pred_stat[sce->channel])
1000
0
      return 33;
1001
1002
        /* intra channel prediction */
1003
0
        ic_prediction(ics, spec_coef, hDecoder->pred_stat[sce->channel], hDecoder->frameLength,
1004
0
            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
0
        pns_reset_pred_state(ics, hDecoder->pred_stat[sce->channel]);
1011
0
    }
1012
0
#endif
1013
1014
0
#ifdef LTP_DEC
1015
0
    if (is_ltp_ot(hDecoder->object_type))
1016
0
    {
1017
0
#ifdef LD_DEC
1018
0
        if (hDecoder->object_type == LD)
1019
0
        {
1020
0
            if (ics->ltp.data_present)
1021
0
            {
1022
0
                if (ics->ltp.lag_update)
1023
0
                    hDecoder->ltp_lag[sce->channel] = ics->ltp.lag;
1024
0
            }
1025
0
            ics->ltp.lag = hDecoder->ltp_lag[sce->channel];
1026
0
        }
1027
0
#endif
1028
1029
        /* long term prediction */
1030
0
        lt_prediction(ics, &(ics->ltp), spec_coef, hDecoder->lt_pred_stat[sce->channel], hDecoder->fb,
1031
0
            ics->window_shape, hDecoder->window_shape_prev[sce->channel],
1032
0
            hDecoder->sf_index, hDecoder->object_type, hDecoder->frameLength);
1033
0
    }
1034
0
#endif
1035
1036
    /* tns decoding */
1037
0
    tns_decode_frame(ics, &(ics->tns), hDecoder->sf_index, hDecoder->object_type,
1038
0
        spec_coef, hDecoder->frameLength);
1039
1040
    /* drc decoding */
1041
0
#ifdef APPLY_DRC
1042
0
    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
0
#endif
1048
    /* filter bank */
1049
#ifdef SSR_DEC
1050
    if (hDecoder->object_type != SSR)
1051
    {
1052
#endif
1053
0
        ifilter_bank(hDecoder->fb, ics->window_sequence, ics->window_shape,
1054
0
            hDecoder->window_shape_prev[sce->channel], spec_coef,
1055
0
            hDecoder->time_out[sce->channel], hDecoder->fb_intermed[sce->channel],
1056
0
            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
0
    hDecoder->window_shape_prev[sce->channel] = ics->window_shape;
1068
1069
0
#ifdef LTP_DEC
1070
0
    if (is_ltp_ot(hDecoder->object_type))
1071
0
    {
1072
0
        lt_update_state(hDecoder->lt_pred_stat[sce->channel], hDecoder->time_out[sce->channel],
1073
0
            hDecoder->fb_intermed[sce->channel], hDecoder->frameLength, hDecoder->object_type);
1074
0
    }
1075
0
#endif
1076
1077
0
#ifdef SBR_DEC
1078
0
    if (((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
1079
0
        && hDecoder->sbr_alloced[hDecoder->fr_ch_ele])
1080
0
    {
1081
0
        int ele = hDecoder->fr_ch_ele;
1082
0
        int ch = sce->channel;
1083
1084
        /* following case can happen when forceUpSampling == 1 */
1085
0
        if (hDecoder->sbr[ele] == NULL)
1086
0
        {
1087
0
            hDecoder->sbr[ele] = sbrDecodeInit(hDecoder->frameLength,
1088
0
                hDecoder->element_id[ele], 2*get_sample_rate(hDecoder->sf_index),
1089
0
                hDecoder->downSampledSBR
1090
#ifdef DRM
1091
                , 0
1092
#endif
1093
0
                );
1094
0
        }
1095
0
        if (!hDecoder->sbr[ele])
1096
0
            return 19;
1097
1098
0
        if (sce->ics1.window_sequence == EIGHT_SHORT_SEQUENCE)
1099
0
            hDecoder->sbr[ele]->maxAACLine = 8*min(sce->ics1.swb_offset[max(sce->ics1.max_sfb-1, 0)], sce->ics1.swb_offset_max);
1100
0
        else
1101
0
            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
0
#if (defined(PS_DEC) || defined(DRM_PS))
1105
0
        if (hDecoder->ps_used[ele] == 0)
1106
0
        {
1107
0
#endif
1108
0
            retval = sbrDecodeSingleFrame(hDecoder->sbr[ele], hDecoder->time_out[ch],
1109
0
                hDecoder->postSeekResetFlag, hDecoder->downSampledSBR);
1110
0
#if (defined(PS_DEC) || defined(DRM_PS))
1111
0
        } else {
1112
0
            retval = sbrDecodeSingleFramePS(hDecoder->sbr[ele], hDecoder->time_out[ch],
1113
0
                hDecoder->time_out[ch+1], hDecoder->postSeekResetFlag,
1114
0
                hDecoder->downSampledSBR);
1115
0
        }
1116
0
#endif
1117
0
        if (retval > 0)
1118
0
            return retval;
1119
0
    } else if (((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
1120
0
        && !hDecoder->sbr_alloced[hDecoder->fr_ch_ele])
1121
0
    {
1122
0
        return 23;
1123
0
    }
1124
0
#endif
1125
1126
    /* copy L to R when no PS is used */
1127
0
#if (defined(PS_DEC) || defined(DRM_PS))
1128
0
    if ((hDecoder->ps_used[hDecoder->fr_ch_ele] == 0) &&
1129
0
        (hDecoder->element_output_channels[hDecoder->fr_ch_ele] == 2))
1130
0
    {
1131
0
        int ele = hDecoder->fr_ch_ele;
1132
0
        int ch = sce->channel;
1133
0
        int frame_size = (hDecoder->sbr_alloced[ele]) ? 2 : 1;
1134
0
        frame_size *= hDecoder->frameLength*sizeof(real_t);
1135
1136
0
        memcpy(hDecoder->time_out[ch+1], hDecoder->time_out[ch], frame_size);
1137
0
    }
1138
0
#endif
1139
1140
0
    return 0;
1141
0
}
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
0
{
1146
0
    uint8_t retval;
1147
0
    ALIGN real_t spec_coef1[1024];
1148
0
    ALIGN real_t spec_coef2[1024];
1149
1150
#ifdef PROFILE
1151
    int64_t count = faad_get_ts();
1152
#endif
1153
0
    if (hDecoder->element_alloced[hDecoder->fr_ch_ele] != 2)
1154
0
    {
1155
0
        retval = allocate_channel_pair(hDecoder, cpe->channel, (uint8_t)cpe->paired_channel);
1156
0
        if (retval > 0)
1157
0
            return retval;
1158
1159
0
        hDecoder->element_alloced[hDecoder->fr_ch_ele] = 2;
1160
0
    }
1161
1162
    /* sanity check, CVE-2018-20199, CVE-2018-20360 */
1163
0
    if(!hDecoder->time_out[cpe->channel] || !hDecoder->time_out[cpe->paired_channel])
1164
0
        return 15;
1165
0
    if(!hDecoder->fb_intermed[cpe->channel] || !hDecoder->fb_intermed[cpe->paired_channel])
1166
0
        return 15;
1167
1168
    /* dequantisation and scaling */
1169
0
    retval = quant_to_spec(hDecoder, ics1, spec_data1, spec_coef1, hDecoder->frameLength);
1170
0
    if (retval > 0)
1171
0
        return retval;
1172
0
    retval = quant_to_spec(hDecoder, ics2, spec_data2, spec_coef2, hDecoder->frameLength);
1173
0
    if (retval > 0)
1174
0
        return retval;
1175
1176
#ifdef PROFILE
1177
    count = faad_get_ts() - count;
1178
    hDecoder->requant_cycles += count;
1179
#endif
1180
1181
    /* pns decoding */
1182
0
    if (ics1->ms_mask_present)
1183
0
    {
1184
0
        pns_decode(ics1, ics2, spec_coef1, spec_coef2, hDecoder->frameLength, 1, hDecoder->object_type,
1185
0
            &(hDecoder->__r1), &(hDecoder->__r2));
1186
0
    } else {
1187
0
        pns_decode(ics1, ics2, spec_coef1, spec_coef2, hDecoder->frameLength, 0, hDecoder->object_type,
1188
0
            &(hDecoder->__r1), &(hDecoder->__r2));
1189
0
    }
1190
1191
    /* mid/side decoding */
1192
0
    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
0
    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
0
#ifdef MAIN_DEC
1230
    /* MAIN object type prediction */
1231
0
    if (hDecoder->object_type == MAIN)
1232
0
    {
1233
        /* intra channel prediction */
1234
0
        ic_prediction(ics1, spec_coef1, hDecoder->pred_stat[cpe->channel], hDecoder->frameLength,
1235
0
            hDecoder->sf_index);
1236
0
        ic_prediction(ics2, spec_coef2, hDecoder->pred_stat[cpe->paired_channel], hDecoder->frameLength,
1237
0
            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
0
        pns_reset_pred_state(ics1, hDecoder->pred_stat[cpe->channel]);
1244
0
        pns_reset_pred_state(ics2, hDecoder->pred_stat[cpe->paired_channel]);
1245
0
    }
1246
0
#endif
1247
1248
0
#ifdef LTP_DEC
1249
0
    if (is_ltp_ot(hDecoder->object_type))
1250
0
    {
1251
0
        ltp_info *ltp1 = &(ics1->ltp);
1252
0
        ltp_info *ltp2 = (cpe->common_window) ? &(ics2->ltp2) : &(ics2->ltp);
1253
0
#ifdef LD_DEC
1254
0
        if (hDecoder->object_type == LD)
1255
0
        {
1256
0
            if (ltp1->data_present)
1257
0
            {
1258
0
                if (ltp1->lag_update)
1259
0
                    hDecoder->ltp_lag[cpe->channel] = ltp1->lag;
1260
0
            }
1261
0
            ltp1->lag = hDecoder->ltp_lag[cpe->channel];
1262
0
            if (ltp2->data_present)
1263
0
            {
1264
0
                if (ltp2->lag_update)
1265
0
                    hDecoder->ltp_lag[cpe->paired_channel] = ltp2->lag;
1266
0
            }
1267
0
            ltp2->lag = hDecoder->ltp_lag[cpe->paired_channel];
1268
0
        }
1269
0
#endif
1270
1271
        /* long term prediction */
1272
0
        lt_prediction(ics1, ltp1, spec_coef1, hDecoder->lt_pred_stat[cpe->channel], hDecoder->fb,
1273
0
            ics1->window_shape, hDecoder->window_shape_prev[cpe->channel],
1274
0
            hDecoder->sf_index, hDecoder->object_type, hDecoder->frameLength);
1275
0
        lt_prediction(ics2, ltp2, spec_coef2, hDecoder->lt_pred_stat[cpe->paired_channel], hDecoder->fb,
1276
0
            ics2->window_shape, hDecoder->window_shape_prev[cpe->paired_channel],
1277
0
            hDecoder->sf_index, hDecoder->object_type, hDecoder->frameLength);
1278
0
    }
1279
0
#endif
1280
1281
    /* tns decoding */
1282
0
    tns_decode_frame(ics1, &(ics1->tns), hDecoder->sf_index, hDecoder->object_type,
1283
0
        spec_coef1, hDecoder->frameLength);
1284
0
    tns_decode_frame(ics2, &(ics2->tns), hDecoder->sf_index, hDecoder->object_type,
1285
0
        spec_coef2, hDecoder->frameLength);
1286
1287
    /* drc decoding */
1288
0
#if APPLY_DRC
1289
0
    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
0
#endif
1297
    /* filter bank */
1298
#ifdef SSR_DEC
1299
    if (hDecoder->object_type != SSR)
1300
    {
1301
#endif
1302
0
        ifilter_bank(hDecoder->fb, ics1->window_sequence, ics1->window_shape,
1303
0
            hDecoder->window_shape_prev[cpe->channel], spec_coef1,
1304
0
            hDecoder->time_out[cpe->channel], hDecoder->fb_intermed[cpe->channel],
1305
0
            hDecoder->object_type, hDecoder->frameLength);
1306
0
        ifilter_bank(hDecoder->fb, ics2->window_sequence, ics2->window_shape,
1307
0
            hDecoder->window_shape_prev[cpe->paired_channel], spec_coef2,
1308
0
            hDecoder->time_out[cpe->paired_channel], hDecoder->fb_intermed[cpe->paired_channel],
1309
0
            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
0
    hDecoder->window_shape_prev[cpe->channel] = ics1->window_shape;
1325
0
    hDecoder->window_shape_prev[cpe->paired_channel] = ics2->window_shape;
1326
1327
0
#ifdef LTP_DEC
1328
0
    if (is_ltp_ot(hDecoder->object_type))
1329
0
    {
1330
0
        lt_update_state(hDecoder->lt_pred_stat[cpe->channel], hDecoder->time_out[cpe->channel],
1331
0
            hDecoder->fb_intermed[cpe->channel], hDecoder->frameLength, hDecoder->object_type);
1332
0
        lt_update_state(hDecoder->lt_pred_stat[cpe->paired_channel], hDecoder->time_out[cpe->paired_channel],
1333
0
            hDecoder->fb_intermed[cpe->paired_channel], hDecoder->frameLength, hDecoder->object_type);
1334
0
    }
1335
0
#endif
1336
1337
0
#ifdef SBR_DEC
1338
0
    if (((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
1339
0
        && hDecoder->sbr_alloced[hDecoder->fr_ch_ele])
1340
0
    {
1341
0
        int ele = hDecoder->fr_ch_ele;
1342
0
        int ch0 = cpe->channel;
1343
0
        int ch1 = cpe->paired_channel;
1344
1345
        /* following case can happen when forceUpSampling == 1 */
1346
0
        if (hDecoder->sbr[ele] == NULL)
1347
0
        {
1348
0
            hDecoder->sbr[ele] = sbrDecodeInit(hDecoder->frameLength,
1349
0
                hDecoder->element_id[ele], 2*get_sample_rate(hDecoder->sf_index),
1350
0
                hDecoder->downSampledSBR
1351
#ifdef DRM
1352
                , 0
1353
#endif
1354
0
                );
1355
0
        }
1356
0
        if (!hDecoder->sbr[ele])
1357
0
            return 19;
1358
1359
0
        if (cpe->ics1.window_sequence == EIGHT_SHORT_SEQUENCE)
1360
0
            hDecoder->sbr[ele]->maxAACLine = 8*min(cpe->ics1.swb_offset[max(cpe->ics1.max_sfb-1, 0)], cpe->ics1.swb_offset_max);
1361
0
        else
1362
0
            hDecoder->sbr[ele]->maxAACLine = min(cpe->ics1.swb_offset[max(cpe->ics1.max_sfb-1, 0)], cpe->ics1.swb_offset_max);
1363
1364
0
        retval = sbrDecodeCoupleFrame(hDecoder->sbr[ele],
1365
0
            hDecoder->time_out[ch0], hDecoder->time_out[ch1],
1366
0
            hDecoder->postSeekResetFlag, hDecoder->downSampledSBR);
1367
0
        if (retval > 0)
1368
0
            return retval;
1369
0
    } else if (((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
1370
0
        && !hDecoder->sbr_alloced[hDecoder->fr_ch_ele])
1371
0
    {
1372
0
        return 23;
1373
0
    }
1374
0
#endif
1375
1376
0
    return 0;
1377
0
}