Coverage Report

Created: 2025-12-31 06:47

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/aac/libAACdec/src/block.cpp
Line
Count
Source
1
/* -----------------------------------------------------------------------------
2
Software License for The Fraunhofer FDK AAC Codec Library for Android
3
4
© Copyright  1995 - 2019 Fraunhofer-Gesellschaft zur Förderung der angewandten
5
Forschung e.V. All rights reserved.
6
7
 1.    INTRODUCTION
8
The Fraunhofer FDK AAC Codec Library for Android ("FDK AAC Codec") is software
9
that implements the MPEG Advanced Audio Coding ("AAC") encoding and decoding
10
scheme for digital audio. This FDK AAC Codec software is intended to be used on
11
a wide variety of Android devices.
12
13
AAC's HE-AAC and HE-AAC v2 versions are regarded as today's most efficient
14
general perceptual audio codecs. AAC-ELD is considered the best-performing
15
full-bandwidth communications codec by independent studies and is widely
16
deployed. AAC has been standardized by ISO and IEC as part of the MPEG
17
specifications.
18
19
Patent licenses for necessary patent claims for the FDK AAC Codec (including
20
those of Fraunhofer) may be obtained through Via Licensing
21
(www.vialicensing.com) or through the respective patent owners individually for
22
the purpose of encoding or decoding bit streams in products that are compliant
23
with the ISO/IEC MPEG audio standards. Please note that most manufacturers of
24
Android devices already license these patent claims through Via Licensing or
25
directly from the patent owners, and therefore FDK AAC Codec software may
26
already be covered under those patent licenses when it is used for those
27
licensed purposes only.
28
29
Commercially-licensed AAC software libraries, including floating-point versions
30
with enhanced sound quality, are also available from Fraunhofer. Users are
31
encouraged to check the Fraunhofer website for additional applications
32
information and documentation.
33
34
2.    COPYRIGHT LICENSE
35
36
Redistribution and use in source and binary forms, with or without modification,
37
are permitted without payment of copyright license fees provided that you
38
satisfy the following conditions:
39
40
You must retain the complete text of this software license in redistributions of
41
the FDK AAC Codec or your modifications thereto in source code form.
42
43
You must retain the complete text of this software license in the documentation
44
and/or other materials provided with redistributions of the FDK AAC Codec or
45
your modifications thereto in binary form. You must make available free of
46
charge copies of the complete source code of the FDK AAC Codec and your
47
modifications thereto to recipients of copies in binary form.
48
49
The name of Fraunhofer may not be used to endorse or promote products derived
50
from this library without prior written permission.
51
52
You may not charge copyright license fees for anyone to use, copy or distribute
53
the FDK AAC Codec software or your modifications thereto.
54
55
Your modified versions of the FDK AAC Codec must carry prominent notices stating
56
that you changed the software and the date of any change. For modified versions
57
of the FDK AAC Codec, the term "Fraunhofer FDK AAC Codec Library for Android"
58
must be replaced by the term "Third-Party Modified Version of the Fraunhofer FDK
59
AAC Codec Library for Android."
60
61
3.    NO PATENT LICENSE
62
63
NO EXPRESS OR IMPLIED LICENSES TO ANY PATENT CLAIMS, including without
64
limitation the patents of Fraunhofer, ARE GRANTED BY THIS SOFTWARE LICENSE.
65
Fraunhofer provides no warranty of patent non-infringement with respect to this
66
software.
67
68
You may use this FDK AAC Codec software or modifications thereto only for
69
purposes that are authorized by appropriate patent licenses.
70
71
4.    DISCLAIMER
72
73
This FDK AAC Codec software is provided by Fraunhofer on behalf of the copyright
74
holders and contributors "AS IS" and WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES,
75
including but not limited to the implied warranties of merchantability and
76
fitness for a particular purpose. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
77
CONTRIBUTORS BE LIABLE for any direct, indirect, incidental, special, exemplary,
78
or consequential damages, including but not limited to procurement of substitute
79
goods or services; loss of use, data, or profits, or business interruption,
80
however caused and on any theory of liability, whether in contract, strict
81
liability, or tort (including negligence), arising in any way out of the use of
82
this software, even if advised of the possibility of such damage.
83
84
5.    CONTACT INFORMATION
85
86
Fraunhofer Institute for Integrated Circuits IIS
87
Attention: Audio and Multimedia Departments - FDK AAC LL
88
Am Wolfsmantel 33
89
91058 Erlangen, Germany
90
91
www.iis.fraunhofer.de/amm
92
amm-info@iis.fraunhofer.de
93
----------------------------------------------------------------------------- */
94
95
/**************************** AAC decoder library ******************************
96
97
   Author(s):   Josef Hoepfl
98
99
   Description: long/short-block decoding
100
101
*******************************************************************************/
102
103
#include "block.h"
104
105
#include "aac_rom.h"
106
#include "FDK_bitstream.h"
107
#include "scale.h"
108
#include "FDK_tools_rom.h"
109
110
#include "usacdec_fac.h"
111
#include "usacdec_lpd.h"
112
#include "usacdec_lpc.h"
113
#include "FDK_trigFcts.h"
114
115
#include "ac_arith_coder.h"
116
117
#include "aacdec_hcr.h"
118
#include "rvlc.h"
119
120
#if defined(__arm__)
121
#include "arm/block_arm.cpp"
122
#endif
123
124
/*!
125
  \brief Read escape sequence of codeword
126
127
  The function reads the escape sequence from the bitstream,
128
  if the absolute value of the quantized coefficient has the
129
  value 16.
130
  A limitation is implemented to maximal 21 bits according to
131
  ISO/IEC 14496-3:2009(E) 4.6.3.3.
132
  This limits the escape prefix to a maximum of eight 1's.
133
  If more than eight 1's are read, MAX_QUANTIZED_VALUE + 1 is
134
  returned, independent of the sign of parameter q.
135
136
  \return  quantized coefficient
137
*/
138
LONG CBlock_GetEscape(HANDLE_FDK_BITSTREAM bs, /*!< pointer to bitstream */
139
                      const LONG q)            /*!< quantized coefficient */
140
548k
{
141
548k
  if (fAbs(q) != 16) return (q);
142
143
29.1k
  LONG i, off;
144
39.8k
  for (i = 4; i < 13; i++) {
145
39.7k
    if (FDKreadBit(bs) == 0) break;
146
39.7k
  }
147
148
29.1k
  if (i == 13) return (MAX_QUANTIZED_VALUE + 1);
149
150
29.0k
  off = FDKreadBits(bs, i);
151
29.0k
  i = off + (1 << i);
152
153
29.0k
  if (q < 0) i = -i;
154
155
29.0k
  return i;
156
29.1k
}
157
158
AAC_DECODER_ERROR CBlock_ReadScaleFactorData(
159
    CAacDecoderChannelInfo *pAacDecoderChannelInfo, HANDLE_FDK_BITSTREAM bs,
160
611k
    UINT flags) {
161
611k
  int temp;
162
611k
  int band;
163
611k
  int group;
164
611k
  int position = 0; /* accu for intensity delta coding */
165
611k
  int factor = pAacDecoderChannelInfo->pDynData->RawDataInfo
166
611k
                   .GlobalGain; /* accu for scale factor delta coding */
167
611k
  UCHAR *pCodeBook = pAacDecoderChannelInfo->pDynData->aCodeBook;
168
611k
  SHORT *pScaleFactor = pAacDecoderChannelInfo->pDynData->aScaleFactor;
169
611k
  const CodeBookDescription *hcb = &AACcodeBookDescriptionTable[BOOKSCL];
170
171
611k
  const USHORT(*CodeBook)[HuffmanEntries] = hcb->CodeBook;
172
173
611k
  int ScaleFactorBandsTransmitted =
174
611k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
175
1.87M
  for (group = 0; group < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo);
176
1.26M
       group++) {
177
4.05M
    for (band = 0; band < ScaleFactorBandsTransmitted; band++) {
178
2.79M
      switch (pCodeBook[band]) {
179
73.1k
        case ZERO_HCB: /* zero book */
180
73.1k
          pScaleFactor[band] = 0;
181
73.1k
          break;
182
183
2.64M
        default: /* decode scale factor */
184
2.64M
          if (!((flags & (AC_USAC | AC_RSVD50 | AC_RSV603DA)) && band == 0 &&
185
2.47M
                group == 0)) {
186
2.47M
            temp = CBlock_DecodeHuffmanWordCB(bs, CodeBook);
187
2.47M
            factor += temp - 60; /* MIDFAC 1.5 dB */
188
2.47M
          }
189
2.64M
          pScaleFactor[band] = factor - 100;
190
2.64M
          break;
191
192
32.0k
        case INTENSITY_HCB: /* intensity steering */
193
49.4k
        case INTENSITY_HCB2:
194
49.4k
          temp = CBlock_DecodeHuffmanWordCB(bs, CodeBook);
195
49.4k
          position += temp - 60;
196
49.4k
          pScaleFactor[band] = position - 100;
197
49.4k
          break;
198
199
21.9k
        case NOISE_HCB: /* PNS */
200
21.9k
          if (flags & (AC_MPEGD_RES | AC_USAC | AC_RSVD50 | AC_RSV603DA)) {
201
0
            return AAC_DEC_PARSE_ERROR;
202
0
          }
203
21.9k
          CPns_Read(&pAacDecoderChannelInfo->data.aac.PnsData, bs, hcb,
204
21.9k
                    pAacDecoderChannelInfo->pDynData->aScaleFactor,
205
21.9k
                    pAacDecoderChannelInfo->pDynData->RawDataInfo.GlobalGain,
206
21.9k
                    band, group);
207
21.9k
          break;
208
2.79M
      }
209
2.79M
    }
210
1.26M
    pCodeBook += 16;
211
1.26M
    pScaleFactor += 16;
212
1.26M
  }
213
214
611k
  return AAC_DEC_OK;
215
611k
}
216
217
void CBlock_ScaleSpectralData(CAacDecoderChannelInfo *pAacDecoderChannelInfo,
218
                              UCHAR maxSfbs,
219
752k
                              SamplingRateInfo *pSamplingRateInfo) {
220
752k
  int band;
221
752k
  int window;
222
752k
  const SHORT *RESTRICT pSfbScale = pAacDecoderChannelInfo->pDynData->aSfbScale;
223
752k
  SHORT *RESTRICT pSpecScale = pAacDecoderChannelInfo->specScale;
224
752k
  int groupwin, group;
225
752k
  const SHORT *RESTRICT BandOffsets = GetScaleFactorBandOffsets(
226
752k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
227
752k
  SPECTRAL_PTR RESTRICT pSpectralCoefficient =
228
752k
      pAacDecoderChannelInfo->pSpectralCoefficient;
229
230
752k
  FDKmemclear(pSpecScale, 8 * sizeof(SHORT));
231
232
752k
  for (window = 0, group = 0;
233
2.20M
       group < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo); group++) {
234
3.21M
    for (groupwin = 0; groupwin < GetWindowGroupLength(
235
3.21M
                                      &pAacDecoderChannelInfo->icsInfo, group);
236
1.75M
         groupwin++, window++) {
237
1.75M
      int SpecScale_window = pSpecScale[window];
238
1.75M
      FIXP_DBL *pSpectrum = SPEC(pSpectralCoefficient, window,
239
1.75M
                                 pAacDecoderChannelInfo->granuleLength);
240
241
      /* find scaling for current window */
242
5.95M
      for (band = 0; band < maxSfbs; band++) {
243
4.20M
        SpecScale_window =
244
4.20M
            fMax(SpecScale_window, (int)pSfbScale[window * 16 + band]);
245
4.20M
      }
246
247
1.75M
      if (pAacDecoderChannelInfo->pDynData->TnsData.Active &&
248
689k
          pAacDecoderChannelInfo->pDynData->TnsData.NumberOfFilters[window] >
249
689k
              0) {
250
295k
        int filter_index, SpecScale_window_tns;
251
295k
        int tns_start, tns_stop;
252
253
        /* Find max scale of TNS bands */
254
295k
        SpecScale_window_tns = 0;
255
295k
        tns_start = GetMaximumTnsBands(&pAacDecoderChannelInfo->icsInfo,
256
295k
                                       pSamplingRateInfo->samplingRateIndex);
257
295k
        tns_stop = 0;
258
295k
        for (filter_index = 0;
259
612k
             filter_index < (int)pAacDecoderChannelInfo->pDynData->TnsData
260
612k
                                .NumberOfFilters[window];
261
316k
             filter_index++) {
262
316k
          for (band = pAacDecoderChannelInfo->pDynData->TnsData
263
316k
                          .Filter[window][filter_index]
264
316k
                          .StartBand;
265
3.22M
               band < pAacDecoderChannelInfo->pDynData->TnsData
266
3.22M
                          .Filter[window][filter_index]
267
3.22M
                          .StopBand;
268
2.90M
               band++) {
269
2.90M
            SpecScale_window_tns =
270
2.90M
                fMax(SpecScale_window_tns, (int)pSfbScale[window * 16 + band]);
271
2.90M
          }
272
          /* Find TNS line boundaries for all TNS filters */
273
316k
          tns_start =
274
316k
              fMin(tns_start, (int)pAacDecoderChannelInfo->pDynData->TnsData
275
316k
                                  .Filter[window][filter_index]
276
316k
                                  .StartBand);
277
316k
          tns_stop =
278
316k
              fMax(tns_stop, (int)pAacDecoderChannelInfo->pDynData->TnsData
279
316k
                                 .Filter[window][filter_index]
280
316k
                                 .StopBand);
281
316k
        }
282
295k
        SpecScale_window_tns = SpecScale_window_tns +
283
295k
                               pAacDecoderChannelInfo->pDynData->TnsData.GainLd;
284
295k
        FDK_ASSERT(tns_stop >= tns_start);
285
        /* Consider existing headroom of all MDCT lines inside the TNS bands. */
286
295k
        SpecScale_window_tns -=
287
295k
            getScalefactor(pSpectrum + BandOffsets[tns_start],
288
295k
                           BandOffsets[tns_stop] - BandOffsets[tns_start]);
289
295k
        if (SpecScale_window <= 17) {
290
278k
          SpecScale_window_tns++;
291
278k
        }
292
        /* Add enough mantissa head room such that the spectrum is still
293
           representable after applying TNS. */
294
295k
        SpecScale_window = fMax(SpecScale_window, SpecScale_window_tns);
295
295k
      }
296
297
      /* store scaling of current window */
298
1.75M
      pSpecScale[window] = SpecScale_window;
299
300
#ifdef FUNCTION_CBlock_ScaleSpectralData_func1
301
302
      CBlock_ScaleSpectralData_func1(pSpectrum, maxSfbs, BandOffsets,
303
                                     SpecScale_window, pSfbScale, window);
304
305
#else  /* FUNCTION_CBlock_ScaleSpectralData_func1 */
306
5.95M
      for (band = 0; band < maxSfbs; band++) {
307
4.20M
        int scale = fMin(DFRACT_BITS - 1,
308
4.20M
                         SpecScale_window - pSfbScale[window * 16 + band]);
309
4.20M
        if (scale) {
310
3.01M
          FDK_ASSERT(scale > 0);
311
312
          /* following relation can be used for optimizations:
313
           * (BandOffsets[i]%4) == 0 for all i */
314
3.01M
          int max_index = BandOffsets[band + 1];
315
3.01M
          DWORD_ALIGNED(pSpectrum);
316
29.0M
          for (int index = BandOffsets[band]; index < max_index; index++) {
317
26.0M
            pSpectrum[index] >>= scale;
318
26.0M
          }
319
3.01M
        }
320
4.20M
      }
321
1.75M
#endif /* FUNCTION_CBlock_ScaleSpectralData_func1 */
322
1.75M
    }
323
1.45M
  }
324
752k
}
325
326
AAC_DECODER_ERROR CBlock_ReadSectionData(
327
    HANDLE_FDK_BITSTREAM bs, CAacDecoderChannelInfo *pAacDecoderChannelInfo,
328
401k
    const SamplingRateInfo *pSamplingRateInfo, const UINT flags) {
329
401k
  int top, band;
330
401k
  int sect_len, sect_len_incr;
331
401k
  int group;
332
401k
  UCHAR sect_cb;
333
401k
  UCHAR *pCodeBook = pAacDecoderChannelInfo->pDynData->aCodeBook;
334
  /* HCR input (long) */
335
401k
  SHORT *pNumLinesInSec =
336
401k
      pAacDecoderChannelInfo->pDynData->specificTo.aac.aNumLineInSec4Hcr;
337
401k
  int numLinesInSecIdx = 0;
338
401k
  UCHAR *pHcrCodeBook =
339
401k
      pAacDecoderChannelInfo->pDynData->specificTo.aac.aCodeBooks4Hcr;
340
401k
  const SHORT *BandOffsets = GetScaleFactorBandOffsets(
341
401k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
342
401k
  pAacDecoderChannelInfo->pDynData->specificTo.aac.numberSection = 0;
343
401k
  AAC_DECODER_ERROR ErrorStatus = AAC_DEC_OK;
344
345
401k
  FDKmemclear(pCodeBook, sizeof(UCHAR) * (8 * 16));
346
347
401k
  const int nbits =
348
401k
      (IsLongBlock(&pAacDecoderChannelInfo->icsInfo) == 1) ? 5 : 3;
349
350
401k
  int sect_esc_val = (1 << nbits) - 1;
351
352
401k
  UCHAR ScaleFactorBandsTransmitted =
353
401k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
354
1.09M
  for (group = 0; group < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo);
355
691k
       group++) {
356
121M
    for (band = 0; band < ScaleFactorBandsTransmitted;) {
357
120M
      sect_len = 0;
358
120M
      if (flags & AC_ER_VCB11) {
359
79.7M
        sect_cb = (UCHAR)FDKreadBits(bs, 5);
360
79.7M
      } else
361
41.1M
        sect_cb = (UCHAR)FDKreadBits(bs, 4);
362
363
120M
      if (((flags & AC_ER_VCB11) == 0) || (sect_cb < 11) ||
364
120M
          ((sect_cb > 11) && (sect_cb < 16))) {
365
120M
        sect_len_incr = FDKreadBits(bs, nbits);
366
121M
        while (sect_len_incr == sect_esc_val) {
367
322k
          sect_len += sect_esc_val;
368
322k
          sect_len_incr = FDKreadBits(bs, nbits);
369
322k
        }
370
120M
      } else {
371
103k
        sect_len_incr = 1;
372
103k
      }
373
374
120M
      sect_len += sect_len_incr;
375
376
120M
      top = band + sect_len;
377
378
120M
      if (flags & AC_ER_HCR) {
379
        /* HCR input (long) -- collecting sideinfo (for HCR-_long_ only) */
380
157k
        if (numLinesInSecIdx >= MAX_SFB_HCR) {
381
303
          return AAC_DEC_PARSE_ERROR;
382
303
        }
383
157k
        if (top > (int)GetNumberOfScaleFactorBands(
384
157k
                      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo)) {
385
12
          return AAC_DEC_PARSE_ERROR;
386
12
        }
387
157k
        pNumLinesInSec[numLinesInSecIdx] = BandOffsets[top] - BandOffsets[band];
388
157k
        numLinesInSecIdx++;
389
157k
        if (sect_cb == BOOKSCL) {
390
2
          return AAC_DEC_INVALID_CODE_BOOK;
391
157k
        } else {
392
157k
          *pHcrCodeBook++ = sect_cb;
393
157k
        }
394
157k
        pAacDecoderChannelInfo->pDynData->specificTo.aac.numberSection++;
395
157k
      }
396
397
      /* Check spectral line limits */
398
120M
      if (IsLongBlock(&(pAacDecoderChannelInfo->icsInfo))) {
399
25.7M
        if (top > 64) {
400
7
          return AAC_DEC_DECODE_FRAME_ERROR;
401
7
        }
402
95.2M
      } else { /* short block */
403
95.2M
        if (top + group * 16 > (8 * 16)) {
404
39
          return AAC_DEC_DECODE_FRAME_ERROR;
405
39
        }
406
95.2M
      }
407
408
      /* Check if decoded codebook index is feasible */
409
120M
      if ((sect_cb == BOOKSCL) ||
410
120M
          ((sect_cb == INTENSITY_HCB || sect_cb == INTENSITY_HCB2) &&
411
47.0k
           pAacDecoderChannelInfo->pDynData->RawDataInfo.CommonWindow == 0)) {
412
165
        return AAC_DEC_INVALID_CODE_BOOK;
413
165
      }
414
415
      /* Store codebook index */
416
124M
      for (; band < top; band++) {
417
3.25M
        pCodeBook[group * 16 + band] = sect_cb;
418
3.25M
      }
419
120M
    }
420
691k
  }
421
422
400k
  return ErrorStatus;
423
401k
}
424
425
/* mso: provides a faster way to i-quantize a whole band in one go */
426
427
/**
428
 * \brief inverse quantize one sfb. Each value of the sfb is processed according
429
 * to the formula: spectrum[i] = Sign(spectrum[i]) * Matissa(spectrum[i])^(4/3)
430
 * * 2^(lsb/4).
431
 * \param spectrum pointer to first line of the sfb to be inverse quantized.
432
 * \param noLines number of lines belonging to the sfb.
433
 * \param lsb last 2 bits of the scale factor of the sfb.
434
 * \param scale max allowed shift scale for the sfb.
435
 */
436
static inline void InverseQuantizeBand(
437
    FIXP_DBL *RESTRICT spectrum, const FIXP_DBL *RESTRICT InverseQuantTabler,
438
    const FIXP_DBL *RESTRICT MantissaTabler,
439
1.86M
    const SCHAR *RESTRICT ExponentTabler, INT noLines, INT scale) {
440
1.86M
  scale = scale + 1; /* +1 to compensate fMultDiv2 shift-right in loop */
441
442
1.86M
  FIXP_DBL *RESTRICT ptr = spectrum;
443
1.86M
  FIXP_DBL signedValue;
444
445
13.8M
  for (INT i = noLines; i--;) {
446
12.0M
    if ((signedValue = *ptr++) != FL2FXCONST_DBL(0)) {
447
5.54M
      FIXP_DBL value = fAbs(signedValue);
448
5.54M
      UINT freeBits = CntLeadingZeros(value);
449
5.54M
      UINT exponent = 32 - freeBits;
450
451
5.54M
      UINT x = (UINT)(LONG)value << (INT)freeBits;
452
5.54M
      x <<= 1; /* shift out sign bit to avoid masking later on */
453
5.54M
      UINT tableIndex = x >> 24;
454
5.54M
      x = (x >> 20) & 0x0F;
455
456
5.54M
      UINT r0 = (UINT)(LONG)InverseQuantTabler[tableIndex + 0];
457
5.54M
      UINT r1 = (UINT)(LONG)InverseQuantTabler[tableIndex + 1];
458
5.54M
      UINT temp = (r1 - r0) * x + (r0 << 4);
459
460
5.54M
      value = fMultDiv2((FIXP_DBL)temp, MantissaTabler[exponent]);
461
462
      /* + 1 compensates fMultDiv2() */
463
5.54M
      scaleValueInPlace(&value, scale + ExponentTabler[exponent]);
464
465
5.54M
      signedValue = (signedValue < (FIXP_DBL)0) ? -value : value;
466
5.54M
      ptr[-1] = signedValue;
467
5.54M
    }
468
12.0M
  }
469
1.86M
}
470
471
static inline FIXP_DBL maxabs_D(const FIXP_DBL *pSpectralCoefficient,
472
3.44M
                                const int noLines) {
473
  /* Find max spectral line value of the current sfb */
474
3.44M
  FIXP_DBL locMax = (FIXP_DBL)0;
475
3.44M
  int i;
476
477
3.44M
  DWORD_ALIGNED(pSpectralCoefficient);
478
479
32.6M
  for (i = noLines; i-- > 0;) {
480
    /* Expensive memory access */
481
29.2M
    locMax = fMax(fixp_abs(pSpectralCoefficient[i]), locMax);
482
29.2M
  }
483
484
3.44M
  return locMax;
485
3.44M
}
486
487
AAC_DECODER_ERROR CBlock_InverseQuantizeSpectralData(
488
    CAacDecoderChannelInfo *pAacDecoderChannelInfo,
489
    SamplingRateInfo *pSamplingRateInfo, UCHAR *band_is_noise,
490
774k
    UCHAR active_band_search) {
491
774k
  int window, group, groupwin, band;
492
774k
  int ScaleFactorBandsTransmitted =
493
774k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
494
774k
  UCHAR *RESTRICT pCodeBook = pAacDecoderChannelInfo->pDynData->aCodeBook;
495
774k
  SHORT *RESTRICT pSfbScale = pAacDecoderChannelInfo->pDynData->aSfbScale;
496
774k
  SHORT *RESTRICT pScaleFactor = pAacDecoderChannelInfo->pDynData->aScaleFactor;
497
774k
  const SHORT *RESTRICT BandOffsets = GetScaleFactorBandOffsets(
498
774k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
499
774k
  const SHORT total_bands =
500
774k
      GetScaleFactorBandsTotal(&pAacDecoderChannelInfo->icsInfo);
501
502
774k
  FDKmemclear(pAacDecoderChannelInfo->pDynData->aSfbScale,
503
774k
              (8 * 16) * sizeof(SHORT));
504
505
774k
  for (window = 0, group = 0;
506
2.28M
       group < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo); group++) {
507
3.32M
    for (groupwin = 0; groupwin < GetWindowGroupLength(
508
3.32M
                                      &pAacDecoderChannelInfo->icsInfo, group);
509
1.82M
         groupwin++, window++) {
510
      /* inverse quantization */
511
6.04M
      for (band = 0; band < ScaleFactorBandsTransmitted; band++) {
512
4.22M
        FIXP_DBL *pSpectralCoefficient =
513
4.22M
            SPEC(pAacDecoderChannelInfo->pSpectralCoefficient, window,
514
4.22M
                 pAacDecoderChannelInfo->granuleLength) +
515
4.22M
            BandOffsets[band];
516
4.22M
        FIXP_DBL locMax;
517
518
4.22M
        const int noLines = BandOffsets[band + 1] - BandOffsets[band];
519
4.22M
        const int bnds = group * 16 + band;
520
521
4.22M
        if ((pCodeBook[bnds] == ZERO_HCB) ||
522
3.75M
            (pCodeBook[bnds] == INTENSITY_HCB) ||
523
3.64M
            (pCodeBook[bnds] == INTENSITY_HCB2))
524
678k
          continue;
525
526
3.54M
        if (pCodeBook[bnds] == NOISE_HCB) {
527
          /* Leave headroom for PNS values. + 1 because ceil(log2(2^(0.25*3))) =
528
             1, worst case of additional headroom required because of the
529
             scalefactor. */
530
100k
          pSfbScale[window * 16 + band] = (pScaleFactor[bnds] >> 2) + 1;
531
100k
          continue;
532
100k
        }
533
534
3.44M
        locMax = maxabs_D(pSpectralCoefficient, noLines);
535
536
3.44M
        if (active_band_search) {
537
3.44M
          if (locMax != FIXP_DBL(0)) {
538
1.86M
            band_is_noise[group * 16 + band] = 0;
539
1.86M
          }
540
3.44M
        }
541
542
        /* Cheap robustness improvement - Do not remove!!! */
543
3.44M
        if (fixp_abs(locMax) > (FIXP_DBL)MAX_QUANTIZED_VALUE) {
544
24
          return AAC_DEC_PARSE_ERROR;
545
24
        }
546
547
        /* Added by Youliy Ninov:
548
        The inverse quantization operation is given by (ISO/IEC 14496-3:2009(E))
549
        by:
550
551
        x_invquant=Sign(x_quant). abs(x_quant)^(4/3)
552
553
        We apply a gain, derived from the scale factor for the particular sfb,
554
        according to the following function:
555
556
        gain=2^(0.25*ScaleFactor)
557
558
        So, after scaling we have:
559
560
        x_rescale=gain*x_invquant=Sign(x_quant)*2^(0.25*ScaleFactor)*abs(s_quant)^(4/3)
561
562
        We could represent the ScaleFactor as:
563
564
        ScaleFactor= (ScaleFactor >> 2)*4 + ScaleFactor %4
565
566
        When we substitute it we get:
567
568
        x_rescale=Sign(x_quant)*2^(ScaleFactor>>2)* (
569
        2^(0.25*(ScaleFactor%4))*abs(s_quant)^(4/3))
570
571
        When we set: msb=(ScaleFactor>>2) and lsb=(ScaleFactor%4), we obtain:
572
573
        x_rescale=Sign(x_quant)*(2^msb)* ( 2^(lsb/4)*abs(s_quant)^(4/3))
574
575
        The rescaled output can be represented by:
576
           mantissa : Sign(x_quant)*( 2^(lsb/4)*abs(s_quant)^(4/3))
577
           exponent :(2^msb)
578
579
        */
580
581
3.44M
        int msb = pScaleFactor[bnds] >> 2;
582
583
        /* Inverse quantize band only if it is not empty */
584
3.44M
        if (locMax != FIXP_DBL(0)) {
585
1.86M
          int lsb = pScaleFactor[bnds] & 0x03;
586
587
1.86M
          int scale = EvaluatePower43(&locMax, lsb);
588
589
1.86M
          scale = CntLeadingZeros(locMax) - scale - 2;
590
591
1.86M
          pSfbScale[window * 16 + band] = msb - scale;
592
1.86M
          InverseQuantizeBand(pSpectralCoefficient, InverseQuantTable,
593
1.86M
                              MantissaTable[lsb], ExponentTable[lsb], noLines,
594
1.86M
                              scale);
595
1.86M
        } else {
596
1.58M
          pSfbScale[window * 16 + band] = msb;
597
1.58M
        }
598
599
3.44M
      } /* for (band=0; band < ScaleFactorBandsTransmitted; band++) */
600
601
      /* Make sure the array is cleared to the end */
602
1.82M
      SHORT start_clear = BandOffsets[ScaleFactorBandsTransmitted];
603
1.82M
      SHORT end_clear = BandOffsets[total_bands];
604
1.82M
      int diff_clear = (int)(end_clear - start_clear);
605
1.82M
      FIXP_DBL *pSpectralCoefficient =
606
1.82M
          SPEC(pAacDecoderChannelInfo->pSpectralCoefficient, window,
607
1.82M
               pAacDecoderChannelInfo->granuleLength) +
608
1.82M
          start_clear;
609
1.82M
      FDKmemclear(pSpectralCoefficient, diff_clear * sizeof(FIXP_DBL));
610
611
1.82M
    } /* for (groupwin=0; groupwin <
612
         GetWindowGroupLength(&pAacDecoderChannelInfo->icsInfo,group);
613
         groupwin++, window++) */
614
1.50M
  }   /* for (window=0, group=0; group <
615
         GetWindowGroups(&pAacDecoderChannelInfo->icsInfo); group++)*/
616
617
774k
  return AAC_DEC_OK;
618
774k
}
619
620
AAC_DECODER_ERROR CBlock_ReadSpectralData(
621
    HANDLE_FDK_BITSTREAM bs, CAacDecoderChannelInfo *pAacDecoderChannelInfo,
622
400k
    const SamplingRateInfo *pSamplingRateInfo, const UINT flags) {
623
400k
  int index, i;
624
400k
  const SHORT *RESTRICT BandOffsets = GetScaleFactorBandOffsets(
625
400k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
626
627
400k
  SPECTRAL_PTR pSpectralCoefficient =
628
400k
      pAacDecoderChannelInfo->pSpectralCoefficient;
629
630
400k
  FDK_ASSERT(BandOffsets != NULL);
631
632
400k
  FDKmemclear(pSpectralCoefficient, sizeof(SPECTRUM));
633
634
400k
  if ((flags & AC_ER_HCR) == 0) {
635
389k
    int group;
636
389k
    int groupoffset;
637
389k
    UCHAR *pCodeBook = pAacDecoderChannelInfo->pDynData->aCodeBook;
638
389k
    int ScaleFactorBandsTransmitted =
639
389k
        GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
640
389k
    int granuleLength = pAacDecoderChannelInfo->granuleLength;
641
642
389k
    groupoffset = 0;
643
644
    /* plain huffman decoder  short */
645
389k
    int max_group = GetWindowGroups(&pAacDecoderChannelInfo->icsInfo);
646
647
1.04M
    for (group = 0; group < max_group; group++) {
648
660k
      int max_groupwin =
649
660k
          GetWindowGroupLength(&pAacDecoderChannelInfo->icsInfo, group);
650
660k
      int band;
651
652
660k
      int bnds = group * 16;
653
654
660k
      int bandOffset1 = BandOffsets[0];
655
1.75M
      for (band = 0; band < ScaleFactorBandsTransmitted; band++, bnds++) {
656
1.09M
        UCHAR currentCB = pCodeBook[bnds];
657
1.09M
        int bandOffset0 = bandOffset1;
658
1.09M
        bandOffset1 = BandOffsets[band + 1];
659
660
        /* patch to run plain-huffman-decoder with vcb11 input codebooks
661
         * (LAV-checking might be possible below using the virtual cb and a
662
         * LAV-table) */
663
1.09M
        if ((currentCB >= 16) && (currentCB <= 31)) {
664
78.2k
          pCodeBook[bnds] = currentCB = 11;
665
78.2k
        }
666
1.09M
        if (((currentCB != ZERO_HCB) && (currentCB != NOISE_HCB) &&
667
704k
             (currentCB != INTENSITY_HCB) && (currentCB != INTENSITY_HCB2))) {
668
566k
          const CodeBookDescription *hcb =
669
566k
              &AACcodeBookDescriptionTable[currentCB];
670
566k
          int step = hcb->Dimension;
671
566k
          int offset = hcb->Offset;
672
566k
          int bits = hcb->numBits;
673
566k
          int mask = (1 << bits) - 1;
674
566k
          const USHORT(*CodeBook)[HuffmanEntries] = hcb->CodeBook;
675
566k
          int groupwin;
676
677
566k
          FIXP_DBL *mdctSpectrum =
678
566k
              &pSpectralCoefficient[groupoffset * granuleLength];
679
680
566k
          if (offset == 0) {
681
741k
            for (groupwin = 0; groupwin < max_groupwin; groupwin++) {
682
1.18M
              for (index = bandOffset0; index < bandOffset1; index += step) {
683
796k
                int idx = CBlock_DecodeHuffmanWordCB(bs, CodeBook);
684
2.67M
                for (i = 0; i < step; i++, idx >>= bits) {
685
1.87M
                  FIXP_DBL tmp = (FIXP_DBL)((idx & mask) - offset);
686
1.87M
                  if (tmp != FIXP_DBL(0)) tmp = (FDKreadBit(bs)) ? -tmp : tmp;
687
1.87M
                  mdctSpectrum[index + i] = tmp;
688
1.87M
                }
689
690
796k
                if (currentCB == ESCBOOK) {
691
822k
                  for (int j = 0; j < 2; j++)
692
548k
                    mdctSpectrum[index + j] = (FIXP_DBL)CBlock_GetEscape(
693
548k
                        bs, (LONG)mdctSpectrum[index + j]);
694
274k
                }
695
796k
              }
696
390k
              mdctSpectrum += granuleLength;
697
390k
            }
698
351k
          } else {
699
438k
            for (groupwin = 0; groupwin < max_groupwin; groupwin++) {
700
588k
              for (index = bandOffset0; index < bandOffset1; index += step) {
701
365k
                int idx = CBlock_DecodeHuffmanWordCB(bs, CodeBook);
702
1.45M
                for (i = 0; i < step; i++, idx >>= bits) {
703
1.08M
                  mdctSpectrum[index + i] = (FIXP_DBL)((idx & mask) - offset);
704
1.08M
                }
705
365k
                if (currentCB == ESCBOOK) {
706
0
                  for (int j = 0; j < 2; j++)
707
0
                    mdctSpectrum[index + j] = (FIXP_DBL)CBlock_GetEscape(
708
0
                        bs, (LONG)mdctSpectrum[index + j]);
709
0
                }
710
365k
              }
711
223k
              mdctSpectrum += granuleLength;
712
223k
            }
713
215k
          }
714
566k
        }
715
1.09M
      }
716
660k
      groupoffset += max_groupwin;
717
660k
    }
718
    /* plain huffman decoding (short) finished */
719
389k
  }
720
721
  /* HCR - Huffman Codeword Reordering  short */
722
11.5k
  else /* if ( flags & AC_ER_HCR ) */
723
724
11.5k
  {
725
11.5k
    H_HCR_INFO hHcr = &pAacDecoderChannelInfo->pComData->overlay.aac.erHcrInfo;
726
727
11.5k
    int hcrStatus = 0;
728
729
    /* advanced Huffman decoding starts here (HCR decoding :) */
730
11.5k
    if (pAacDecoderChannelInfo->pDynData->specificTo.aac
731
11.5k
            .lenOfReorderedSpectralData != 0) {
732
      /* HCR initialization short */
733
11.2k
      hcrStatus = HcrInit(hHcr, pAacDecoderChannelInfo, pSamplingRateInfo, bs);
734
735
11.2k
      if (hcrStatus != 0) {
736
45
        return AAC_DEC_DECODE_FRAME_ERROR;
737
45
      }
738
739
      /* HCR decoding short */
740
11.2k
      hcrStatus =
741
11.2k
          HcrDecoder(hHcr, pAacDecoderChannelInfo, pSamplingRateInfo, bs);
742
743
11.2k
      if (hcrStatus != 0) {
744
8.15k
#if HCR_ERROR_CONCEALMENT
745
8.15k
        HcrMuteErroneousLines(hHcr);
746
#else
747
        return AAC_DEC_DECODE_FRAME_ERROR;
748
#endif /* HCR_ERROR_CONCEALMENT */
749
8.15k
      }
750
751
11.2k
      FDKpushFor(bs, pAacDecoderChannelInfo->pDynData->specificTo.aac
752
11.2k
                         .lenOfReorderedSpectralData);
753
11.2k
    }
754
11.5k
  }
755
  /* HCR - Huffman Codeword Reordering short finished */
756
757
400k
  if (IsLongBlock(&pAacDecoderChannelInfo->icsInfo) &&
758
332k
      !(flags & (AC_ELD | AC_SCALABLE))) {
759
    /* apply pulse data */
760
24.2k
    CPulseData_Apply(
761
24.2k
        &pAacDecoderChannelInfo->pDynData->specificTo.aac.PulseData,
762
24.2k
        GetScaleFactorBandOffsets(&pAacDecoderChannelInfo->icsInfo,
763
24.2k
                                  pSamplingRateInfo),
764
24.2k
        SPEC_LONG(pSpectralCoefficient));
765
24.2k
  }
766
767
400k
  return AAC_DEC_OK;
768
400k
}
769
770
static const FIXP_SGL noise_level_tab[8] = {
771
    /* FDKpow(2, (float)(noise_level-14)/3.0f) * 2; (*2 to compensate for
772
       fMultDiv2) noise_level_tab(noise_level==0) == 0 by definition
773
    */
774
    FX_DBL2FXCONST_SGL(0x00000000 /*0x0a145173*/),
775
    FX_DBL2FXCONST_SGL(0x0cb2ff5e),
776
    FX_DBL2FXCONST_SGL(0x10000000),
777
    FX_DBL2FXCONST_SGL(0x1428a2e7),
778
    FX_DBL2FXCONST_SGL(0x1965febd),
779
    FX_DBL2FXCONST_SGL(0x20000000),
780
    FX_DBL2FXCONST_SGL(0x28514606),
781
    FX_DBL2FXCONST_SGL(0x32cbfd33)};
782
783
void CBlock_ApplyNoise(CAacDecoderChannelInfo *pAacDecoderChannelInfo,
784
                       SamplingRateInfo *pSamplingRateInfo, ULONG *nfRandomSeed,
785
13.3k
                       UCHAR *band_is_noise) {
786
13.3k
  const SHORT *swb_offset = GetScaleFactorBandOffsets(
787
13.3k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
788
13.3k
  int g, win, gwin, sfb, noiseFillingStartOffset, nfStartOffset_sfb;
789
790
  /* Obtain noise level and scale factor offset. */
791
13.3k
  int noise_level = pAacDecoderChannelInfo->pDynData->specificTo.usac
792
13.3k
                        .fd_noise_level_and_offset >>
793
13.3k
                    5;
794
13.3k
  const FIXP_SGL noiseVal_pos = noise_level_tab[noise_level];
795
796
  /* noise_offset can change even when noise_level=0. Neccesary for IGF stereo
797
   * filling */
798
13.3k
  const int noise_offset = (pAacDecoderChannelInfo->pDynData->specificTo.usac
799
13.3k
                                .fd_noise_level_and_offset &
800
13.3k
                            0x1f) -
801
13.3k
                           16;
802
803
13.3k
  int max_sfb =
804
13.3k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
805
806
13.3k
  noiseFillingStartOffset =
807
13.3k
      (GetWindowSequence(&pAacDecoderChannelInfo->icsInfo) == BLOCK_SHORT)
808
13.3k
          ? 20
809
13.3k
          : 160;
810
13.3k
  if (pAacDecoderChannelInfo->granuleLength == 96) {
811
4.77k
    noiseFillingStartOffset =
812
4.77k
        (3 * noiseFillingStartOffset) /
813
4.77k
        4; /* scale offset with 3/4 for coreCoderFrameLength == 768 */
814
4.77k
  }
815
816
  /* determine sfb from where on noise filling is applied */
817
149k
  for (sfb = 0; swb_offset[sfb] < noiseFillingStartOffset; sfb++)
818
136k
    ;
819
13.3k
  nfStartOffset_sfb = sfb;
820
821
  /* if (noise_level!=0) */
822
13.3k
  {
823
68.1k
    for (g = 0, win = 0; g < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo);
824
54.7k
         g++) {
825
54.7k
      int windowGroupLength =
826
54.7k
          GetWindowGroupLength(&pAacDecoderChannelInfo->icsInfo, g);
827
63.6k
      for (sfb = nfStartOffset_sfb; sfb < max_sfb; sfb++) {
828
8.86k
        int bin_start = swb_offset[sfb];
829
8.86k
        int bin_stop = swb_offset[sfb + 1];
830
831
8.86k
        int flagN = band_is_noise[g * 16 + sfb];
832
833
        /* if all bins of one sfb in one window group are zero modify the scale
834
         * factor by noise_offset */
835
8.86k
        if (flagN) {
836
          /* Change scaling factors for empty signal bands */
837
5.13k
          pAacDecoderChannelInfo->pDynData->aScaleFactor[g * 16 + sfb] +=
838
5.13k
              noise_offset;
839
          /* scale factor "sf" implied gain "g" is g = 2^(sf/4) */
840
11.1k
          for (gwin = 0; gwin < windowGroupLength; gwin++) {
841
6.02k
            pAacDecoderChannelInfo->pDynData
842
6.02k
                ->aSfbScale[(win + gwin) * 16 + sfb] += (noise_offset >> 2);
843
6.02k
          }
844
5.13k
        }
845
846
8.86k
        ULONG seed = *nfRandomSeed;
847
        /* + 1 because exponent of MantissaTable[lsb][0] is always 1. */
848
8.86k
        int scale =
849
8.86k
            (pAacDecoderChannelInfo->pDynData->aScaleFactor[g * 16 + sfb] >>
850
8.86k
             2) +
851
8.86k
            1;
852
8.86k
        int lsb =
853
8.86k
            pAacDecoderChannelInfo->pDynData->aScaleFactor[g * 16 + sfb] & 3;
854
8.86k
        FIXP_DBL mantissa = MantissaTable[lsb][0];
855
856
20.6k
        for (gwin = 0; gwin < windowGroupLength; gwin++) {
857
11.8k
          FIXP_DBL *pSpec =
858
11.8k
              SPEC(pAacDecoderChannelInfo->pSpectralCoefficient, win + gwin,
859
11.8k
                   pAacDecoderChannelInfo->granuleLength);
860
861
11.8k
          int scale1 = scale - pAacDecoderChannelInfo->pDynData
862
11.8k
                                   ->aSfbScale[(win + gwin) * 16 + sfb];
863
11.8k
          FIXP_DBL scaled_noiseVal_pos =
864
11.8k
              scaleValue(fMultDiv2(noiseVal_pos, mantissa), scale1);
865
11.8k
          FIXP_DBL scaled_noiseVal_neg = -scaled_noiseVal_pos;
866
867
          /* If the whole band is zero, just fill without checking */
868
11.8k
          if (flagN) {
869
102k
            for (int bin = bin_start; bin < bin_stop; bin++) {
870
96.0k
              seed = (ULONG)(
871
96.0k
                  (UINT64)seed * 69069 +
872
96.0k
                  5); /* Inlined: UsacRandomSign - origin in usacdec_lpd.h */
873
96.0k
              pSpec[bin] =
874
96.0k
                  (seed & 0x10000) ? scaled_noiseVal_neg : scaled_noiseVal_pos;
875
96.0k
            } /* for (bin...) */
876
6.02k
          }
877
          /*If band is sparsely filled, check for 0 and fill */
878
5.79k
          else {
879
61.7k
            for (int bin = bin_start; bin < bin_stop; bin++) {
880
55.9k
              if (pSpec[bin] == (FIXP_DBL)0) {
881
39.8k
                seed = (ULONG)(
882
39.8k
                    (UINT64)seed * 69069 +
883
39.8k
                    5); /* Inlined: UsacRandomSign - origin in usacdec_lpd.h */
884
39.8k
                pSpec[bin] = (seed & 0x10000) ? scaled_noiseVal_neg
885
39.8k
                                              : scaled_noiseVal_pos;
886
39.8k
              }
887
55.9k
            } /* for (bin...) */
888
5.79k
          }
889
890
11.8k
        } /* for (gwin...) */
891
8.86k
        *nfRandomSeed = seed;
892
8.86k
      } /* for (sfb...) */
893
54.7k
      win += windowGroupLength;
894
54.7k
    } /* for (g...) */
895
896
13.3k
  } /* ... */
897
13.3k
}
898
899
AAC_DECODER_ERROR CBlock_ReadAcSpectralData(
900
    HANDLE_FDK_BITSTREAM hBs, CAacDecoderChannelInfo *pAacDecoderChannelInfo,
901
    CAacDecoderStaticChannelInfo *pAacDecoderStaticChannelInfo,
902
    const SamplingRateInfo *pSamplingRateInfo, const UINT frame_length,
903
376k
    const UINT flags) {
904
376k
  AAC_DECODER_ERROR errorAAC = AAC_DEC_OK;
905
376k
  ARITH_CODING_ERROR error = ARITH_CODER_OK;
906
376k
  int arith_reset_flag, lg, numWin, win, winLen;
907
376k
  const SHORT *RESTRICT BandOffsets;
908
909
  /* number of transmitted spectral coefficients */
910
376k
  BandOffsets = GetScaleFactorBandOffsets(&pAacDecoderChannelInfo->icsInfo,
911
376k
                                          pSamplingRateInfo);
912
376k
  lg = BandOffsets[GetScaleFactorBandsTransmitted(
913
376k
      &pAacDecoderChannelInfo->icsInfo)];
914
915
376k
  numWin = GetWindowsPerFrame(&pAacDecoderChannelInfo->icsInfo);
916
376k
  winLen = (IsLongBlock(&pAacDecoderChannelInfo->icsInfo))
917
376k
               ? (int)frame_length
918
376k
               : (int)frame_length / numWin;
919
920
376k
  if (flags & AC_INDEP) {
921
274k
    arith_reset_flag = 1;
922
274k
  } else {
923
101k
    arith_reset_flag = (USHORT)FDKreadBits(hBs, 1);
924
101k
  }
925
926
1.32M
  for (win = 0; win < numWin; win++) {
927
949k
    error =
928
949k
        CArco_DecodeArithData(pAacDecoderStaticChannelInfo->hArCo, hBs,
929
949k
                              SPEC(pAacDecoderChannelInfo->pSpectralCoefficient,
930
949k
                                   win, pAacDecoderChannelInfo->granuleLength),
931
949k
                              lg, winLen, arith_reset_flag && (win == 0));
932
949k
    if (error != ARITH_CODER_OK) {
933
1.39k
      goto bail;
934
1.39k
    }
935
949k
  }
936
937
376k
bail:
938
376k
  if (error == ARITH_CODER_ERROR) {
939
1.39k
    errorAAC = AAC_DEC_PARSE_ERROR;
940
1.39k
  }
941
942
376k
  return errorAAC;
943
376k
}
944
945
void ApplyTools(CAacDecoderChannelInfo *pAacDecoderChannelInfo[],
946
                const SamplingRateInfo *pSamplingRateInfo, const UINT flags,
947
                const UINT elFlags, const int channel,
948
686k
                const int common_window) {
949
686k
  if (!(flags & (AC_USAC | AC_RSVD50 | AC_MPEGD_RES | AC_RSV603DA))) {
950
389k
    CPns_Apply(&pAacDecoderChannelInfo[channel]->data.aac.PnsData,
951
389k
               &pAacDecoderChannelInfo[channel]->icsInfo,
952
389k
               pAacDecoderChannelInfo[channel]->pSpectralCoefficient,
953
389k
               pAacDecoderChannelInfo[channel]->specScale,
954
389k
               pAacDecoderChannelInfo[channel]->pDynData->aScaleFactor,
955
389k
               pSamplingRateInfo,
956
389k
               pAacDecoderChannelInfo[channel]->granuleLength, channel);
957
389k
  }
958
959
686k
  UCHAR nbands =
960
686k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo[channel]->icsInfo);
961
962
686k
  CTns_Apply(&pAacDecoderChannelInfo[channel]->pDynData->TnsData,
963
686k
             &pAacDecoderChannelInfo[channel]->icsInfo,
964
686k
             pAacDecoderChannelInfo[channel]->pSpectralCoefficient,
965
686k
             pSamplingRateInfo, pAacDecoderChannelInfo[channel]->granuleLength,
966
686k
             nbands, (elFlags & AC_EL_ENHANCED_NOISE) ? 1 : 0, flags);
967
686k
}
968
969
241k
static int getWindow2Nr(int length, int shape) {
970
241k
  int nr = 0;
971
972
241k
  if (shape == 2) {
973
    /* Low Overlap, 3/4 zeroed */
974
138
    nr = (length * 3) >> 2;
975
138
  }
976
977
241k
  return nr;
978
241k
}
979
980
302k
FIXP_DBL get_gain(const FIXP_DBL *x, const FIXP_DBL *y, int n) {
981
302k
  FIXP_DBL corr = (FIXP_DBL)0;
982
302k
  FIXP_DBL ener = (FIXP_DBL)1;
983
984
302k
  int headroom_x = getScalefactor(x, n);
985
302k
  int headroom_y = getScalefactor(y, n);
986
987
  /*Calculate the normalization necessary due to addition*/
988
  /* Check for power of two /special case */
989
302k
  INT width_shift = (INT)(fNormz((FIXP_DBL)n));
990
  /* Get the number of bits necessary minus one, because we need one sign bit
991
   * only */
992
302k
  width_shift = 31 - width_shift;
993
994
19.6M
  for (int i = 0; i < n; i++) {
995
19.3M
    corr +=
996
19.3M
        fMultDiv2((x[i] << headroom_x), (y[i] << headroom_y)) >> width_shift;
997
19.3M
    ener += fPow2Div2((y[i] << headroom_y)) >> width_shift;
998
19.3M
  }
999
1000
302k
  int exp_corr = (17 - headroom_x) + (17 - headroom_y) + width_shift + 1;
1001
302k
  int exp_ener = ((17 - headroom_y) << 1) + width_shift + 1;
1002
1003
302k
  int temp_exp = 0;
1004
302k
  FIXP_DBL output = fDivNormSigned(corr, ener, &temp_exp);
1005
1006
302k
  int output_exp = (exp_corr - exp_ener) + temp_exp;
1007
1008
302k
  INT output_shift = 17 - output_exp;
1009
302k
  output_shift = fMin(output_shift, 31);
1010
1011
302k
  output = scaleValue(output, -output_shift);
1012
1013
302k
  return output;
1014
302k
}
1015
1016
void CBlock_FrequencyToTime(
1017
    CAacDecoderStaticChannelInfo *pAacDecoderStaticChannelInfo,
1018
    CAacDecoderChannelInfo *pAacDecoderChannelInfo, PCM_DEC outSamples[],
1019
    const SHORT frameLen, const int frameOk, FIXP_DBL *pWorkBuffer1,
1020
488k
    const INT aacOutDataHeadroom, UINT elFlags, INT elCh) {
1021
488k
  int fr, fl, tl, nSpec;
1022
1023
488k
#if defined(FDK_ASSERT_ENABLE)
1024
488k
  LONG nSamples;
1025
488k
#endif
1026
1027
  /* Determine left slope length (fl), right slope length (fr) and transform
1028
     length (tl). USAC: The slope length may mismatch with the previous frame in
1029
     case of LPD / FD transitions. The adjustment is handled by the imdct
1030
     implementation.
1031
  */
1032
488k
  tl = frameLen;
1033
488k
  nSpec = 1;
1034
1035
488k
  switch (pAacDecoderChannelInfo->icsInfo.WindowSequence) {
1036
0
    default:
1037
241k
    case BLOCK_LONG:
1038
241k
      fl = frameLen;
1039
241k
      fr = frameLen -
1040
241k
           getWindow2Nr(frameLen,
1041
241k
                        GetWindowShape(&pAacDecoderChannelInfo->icsInfo));
1042
      /* New startup needs differentiation between sine shape and low overlap
1043
         shape. This is a special case for the LD-AAC transformation windows,
1044
         because the slope length can be different while using the same window
1045
         sequence. */
1046
241k
      if (pAacDecoderStaticChannelInfo->IMdct.prev_tl == 0) {
1047
22.5k
        fl = fr;
1048
22.5k
      }
1049
241k
      break;
1050
42.4k
    case BLOCK_STOP:
1051
42.4k
      fl = frameLen >> 3;
1052
42.4k
      fr = frameLen;
1053
42.4k
      break;
1054
57.4k
    case BLOCK_START: /* or StopStartSequence */
1055
57.4k
      fl = frameLen;
1056
57.4k
      fr = frameLen >> 3;
1057
57.4k
      break;
1058
147k
    case BLOCK_SHORT:
1059
147k
      fl = fr = frameLen >> 3;
1060
147k
      tl >>= 3;
1061
147k
      nSpec = 8;
1062
147k
      break;
1063
488k
  }
1064
1065
488k
  {
1066
488k
    int last_frame_lost = pAacDecoderStaticChannelInfo->last_lpc_lost;
1067
1068
488k
    if (pAacDecoderStaticChannelInfo->last_core_mode == LPD) {
1069
29.5k
      INT fac_FB = 1;
1070
29.5k
      if (elFlags & AC_EL_FULLBANDLPD) {
1071
0
        fac_FB = 2;
1072
0
      }
1073
1074
29.5k
      FIXP_DBL *synth;
1075
1076
      /* Keep some free space at the beginning of the buffer. To be used for
1077
       * past data */
1078
29.5k
      if (!(elFlags & AC_EL_LPDSTEREOIDX)) {
1079
29.5k
        synth = pWorkBuffer1 + ((PIT_MAX_MAX - (1 * L_SUBFR)) * fac_FB);
1080
29.5k
      } else {
1081
0
        synth = pWorkBuffer1 + PIT_MAX_MAX * fac_FB;
1082
0
      }
1083
1084
29.5k
      int fac_length =
1085
29.5k
          (pAacDecoderChannelInfo->icsInfo.WindowSequence == BLOCK_SHORT)
1086
29.5k
              ? (frameLen >> 4)
1087
29.5k
              : (frameLen >> 3);
1088
1089
29.5k
      INT pitch[NB_SUBFR_SUPERFR + SYN_SFD];
1090
29.5k
      FIXP_DBL pit_gain[NB_SUBFR_SUPERFR + SYN_SFD];
1091
1092
29.5k
      int nbDiv = (elFlags & AC_EL_FULLBANDLPD) ? 2 : 4;
1093
29.5k
      int lFrame = (elFlags & AC_EL_FULLBANDLPD) ? frameLen / 2 : frameLen;
1094
29.5k
      int nbSubfr =
1095
29.5k
          lFrame / (nbDiv * L_SUBFR); /* number of subframes per division */
1096
29.5k
      int LpdSfd = (nbDiv * nbSubfr) >> 1;
1097
29.5k
      int SynSfd = LpdSfd - BPF_SFD;
1098
1099
29.5k
      FDKmemclear(
1100
29.5k
          pitch,
1101
29.5k
          sizeof(
1102
29.5k
              pitch));  // added to prevent ferret errors in bass_pf_1sf_delay
1103
29.5k
      FDKmemclear(pit_gain, sizeof(pit_gain));
1104
1105
      /* FAC case */
1106
29.5k
      if (pAacDecoderStaticChannelInfo->last_lpd_mode == 0 ||
1107
23.3k
          pAacDecoderStaticChannelInfo->last_lpd_mode == 4) {
1108
23.3k
        FIXP_DBL fac_buf[LFAC];
1109
23.3k
        FIXP_LPC *A = pAacDecoderChannelInfo->data.usac.lp_coeff[0];
1110
1111
23.3k
        if (!frameOk || last_frame_lost ||
1112
23.3k
            (pAacDecoderChannelInfo->data.usac.fac_data[0] == NULL)) {
1113
5
          FDKmemclear(fac_buf,
1114
5
                      pAacDecoderChannelInfo->granuleLength * sizeof(FIXP_DBL));
1115
5
          pAacDecoderChannelInfo->data.usac.fac_data[0] = fac_buf;
1116
5
          pAacDecoderChannelInfo->data.usac.fac_data_e[0] = 0;
1117
5
        }
1118
1119
23.3k
        INT A_exp; /* linear prediction coefficients exponent */
1120
23.3k
        {
1121
396k
          for (int i = 0; i < M_LP_FILTER_ORDER; i++) {
1122
372k
            A[i] = FX_DBL2FX_LPC(fixp_cos(
1123
372k
                fMult(pAacDecoderStaticChannelInfo->lpc4_lsf[i],
1124
372k
                      FL2FXCONST_SGL((1 << LSPARG_SCALE) * M_PI / 6400.0)),
1125
372k
                LSF_SCALE - LSPARG_SCALE));
1126
372k
          }
1127
1128
23.3k
          E_LPC_f_lsp_a_conversion(A, A, &A_exp);
1129
23.3k
        }
1130
1131
23.3k
#if defined(FDK_ASSERT_ENABLE)
1132
23.3k
        nSamples =
1133
23.3k
#endif
1134
23.3k
            CLpd_FAC_Acelp2Mdct(
1135
23.3k
                &pAacDecoderStaticChannelInfo->IMdct, synth,
1136
23.3k
                SPEC_LONG(pAacDecoderChannelInfo->pSpectralCoefficient),
1137
23.3k
                pAacDecoderChannelInfo->specScale, nSpec,
1138
23.3k
                pAacDecoderChannelInfo->data.usac.fac_data[0],
1139
23.3k
                pAacDecoderChannelInfo->data.usac.fac_data_e[0], fac_length,
1140
23.3k
                frameLen, tl,
1141
23.3k
                FDKgetWindowSlope(
1142
23.3k
                    fr, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1143
23.3k
                fr, A, A_exp, &pAacDecoderStaticChannelInfo->acelp,
1144
23.3k
                (FIXP_DBL)0, /* FAC gain has already been applied. */
1145
23.3k
                (last_frame_lost || !frameOk), 1,
1146
23.3k
                pAacDecoderStaticChannelInfo->last_lpd_mode, 0,
1147
23.3k
                pAacDecoderChannelInfo->currAliasingSymmetry);
1148
1149
23.3k
      } else {
1150
6.19k
#if defined(FDK_ASSERT_ENABLE)
1151
6.19k
        nSamples =
1152
6.19k
#endif
1153
6.19k
            imlt_block(
1154
6.19k
                &pAacDecoderStaticChannelInfo->IMdct, synth,
1155
6.19k
                SPEC_LONG(pAacDecoderChannelInfo->pSpectralCoefficient),
1156
6.19k
                pAacDecoderChannelInfo->specScale, nSpec, frameLen, tl,
1157
6.19k
                FDKgetWindowSlope(
1158
6.19k
                    fl, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1159
6.19k
                fl,
1160
6.19k
                FDKgetWindowSlope(
1161
6.19k
                    fr, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1162
6.19k
                fr, (FIXP_DBL)0,
1163
6.19k
                pAacDecoderChannelInfo->currAliasingSymmetry
1164
6.19k
                    ? MLT_FLAG_CURR_ALIAS_SYMMETRY
1165
6.19k
                    : 0);
1166
6.19k
      }
1167
29.5k
      FDK_ASSERT(nSamples == frameLen);
1168
1169
      /* The "if" clause is entered both for fullbandLpd mono and
1170
       * non-fullbandLpd*. The "else"-> just for fullbandLpd stereo*/
1171
29.5k
      if (!(elFlags & AC_EL_LPDSTEREOIDX)) {
1172
29.5k
        FDKmemcpy(pitch, pAacDecoderStaticChannelInfo->old_T_pf,
1173
29.5k
                  SynSfd * sizeof(INT));
1174
29.5k
        FDKmemcpy(pit_gain, pAacDecoderStaticChannelInfo->old_gain_pf,
1175
29.5k
                  SynSfd * sizeof(FIXP_DBL));
1176
1177
147k
        for (int i = SynSfd; i < LpdSfd + 3; i++) {
1178
118k
          pitch[i] = L_SUBFR;
1179
118k
          pit_gain[i] = (FIXP_DBL)0;
1180
118k
        }
1181
1182
29.5k
        if (pAacDecoderStaticChannelInfo->last_lpd_mode == 0) {
1183
23.3k
          pitch[SynSfd] = pitch[SynSfd - 1];
1184
23.3k
          pit_gain[SynSfd] = pit_gain[SynSfd - 1];
1185
23.3k
          if (IsLongBlock(&pAacDecoderChannelInfo->icsInfo)) {
1186
5.52k
            pitch[SynSfd + 1] = pitch[SynSfd];
1187
5.52k
            pit_gain[SynSfd + 1] = pit_gain[SynSfd];
1188
5.52k
          }
1189
23.3k
        }
1190
1191
        /* Copy old data to the beginning of the buffer */
1192
29.5k
        {
1193
29.5k
          FDKmemcpy(
1194
29.5k
              pWorkBuffer1, pAacDecoderStaticChannelInfo->old_synth,
1195
29.5k
              ((PIT_MAX_MAX - (1 * L_SUBFR)) * fac_FB) * sizeof(FIXP_DBL));
1196
29.5k
        }
1197
1198
29.5k
        FIXP_DBL *p2_synth = pWorkBuffer1 + (PIT_MAX_MAX * fac_FB);
1199
1200
        /* recalculate pitch gain to allow postfilering on FAC area */
1201
266k
        for (int i = 0; i < SynSfd + 2; i++) {
1202
237k
          int T = pitch[i];
1203
237k
          FIXP_DBL gain = pit_gain[i];
1204
1205
237k
          if (gain > (FIXP_DBL)0) {
1206
98.3k
            gain = get_gain(&p2_synth[i * L_SUBFR * fac_FB],
1207
98.3k
                            &p2_synth[(i * L_SUBFR * fac_FB) - fac_FB * T],
1208
98.3k
                            L_SUBFR * fac_FB);
1209
98.3k
            pit_gain[i] = gain;
1210
98.3k
          }
1211
237k
        }
1212
1213
29.5k
        bass_pf_1sf_delay(p2_synth, pitch, pit_gain, frameLen,
1214
29.5k
                          (LpdSfd + 2) * L_SUBFR + BPF_SFD * L_SUBFR,
1215
29.5k
                          frameLen - (LpdSfd + 4) * L_SUBFR, outSamples,
1216
29.5k
                          aacOutDataHeadroom,
1217
29.5k
                          pAacDecoderStaticChannelInfo->mem_bpf);
1218
29.5k
      }
1219
1220
29.5k
    } else /* last_core_mode was not LPD */
1221
459k
    {
1222
459k
      FIXP_DBL *tmp =
1223
459k
          pAacDecoderChannelInfo->pComStaticData->pWorkBufferCore1->mdctOutTemp;
1224
459k
#if defined(FDK_ASSERT_ENABLE)
1225
459k
      nSamples =
1226
459k
#endif
1227
459k
          imlt_block(&pAacDecoderStaticChannelInfo->IMdct, tmp,
1228
459k
                     SPEC_LONG(pAacDecoderChannelInfo->pSpectralCoefficient),
1229
459k
                     pAacDecoderChannelInfo->specScale, nSpec, frameLen, tl,
1230
459k
                     FDKgetWindowSlope(
1231
459k
                         fl, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1232
459k
                     fl,
1233
459k
                     FDKgetWindowSlope(
1234
459k
                         fr, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1235
459k
                     fr, (FIXP_DBL)0,
1236
459k
                     pAacDecoderChannelInfo->currAliasingSymmetry
1237
459k
                         ? MLT_FLAG_CURR_ALIAS_SYMMETRY
1238
459k
                         : 0);
1239
1240
459k
      scaleValuesSaturate(outSamples, tmp, frameLen,
1241
459k
                          MDCT_OUT_HEADROOM - aacOutDataHeadroom);
1242
459k
    }
1243
488k
  }
1244
1245
488k
  FDK_ASSERT(nSamples == frameLen);
1246
1247
488k
  pAacDecoderStaticChannelInfo->last_core_mode =
1248
488k
      (pAacDecoderChannelInfo->icsInfo.WindowSequence == BLOCK_SHORT) ? FD_SHORT
1249
488k
                                                                      : FD_LONG;
1250
488k
  pAacDecoderStaticChannelInfo->last_lpd_mode = 255;
1251
488k
}
1252
1253
#include "ldfiltbank.h"
1254
void CBlock_FrequencyToTimeLowDelay(
1255
    CAacDecoderStaticChannelInfo *pAacDecoderStaticChannelInfo,
1256
    CAacDecoderChannelInfo *pAacDecoderChannelInfo, PCM_DEC outSamples[],
1257
287k
    const short frameLen) {
1258
287k
  InvMdctTransformLowDelay_fdk(
1259
287k
      SPEC_LONG(pAacDecoderChannelInfo->pSpectralCoefficient),
1260
287k
      pAacDecoderChannelInfo->specScale[0], outSamples,
1261
287k
      pAacDecoderStaticChannelInfo->pOverlapBuffer, frameLen);
1262
287k
}