Coverage Report

Created: 2025-10-13 06:42

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
487k
{
141
487k
  if (fAbs(q) != 16) return (q);
142
143
27.5k
  LONG i, off;
144
35.8k
  for (i = 4; i < 13; i++) {
145
35.7k
    if (FDKreadBit(bs) == 0) break;
146
35.7k
  }
147
148
27.5k
  if (i == 13) return (MAX_QUANTIZED_VALUE + 1);
149
150
27.4k
  off = FDKreadBits(bs, i);
151
27.4k
  i = off + (1 << i);
152
153
27.4k
  if (q < 0) i = -i;
154
155
27.4k
  return i;
156
27.5k
}
157
158
AAC_DECODER_ERROR CBlock_ReadScaleFactorData(
159
    CAacDecoderChannelInfo *pAacDecoderChannelInfo, HANDLE_FDK_BITSTREAM bs,
160
480k
    UINT flags) {
161
480k
  int temp;
162
480k
  int band;
163
480k
  int group;
164
480k
  int position = 0; /* accu for intensity delta coding */
165
480k
  int factor = pAacDecoderChannelInfo->pDynData->RawDataInfo
166
480k
                   .GlobalGain; /* accu for scale factor delta coding */
167
480k
  UCHAR *pCodeBook = pAacDecoderChannelInfo->pDynData->aCodeBook;
168
480k
  SHORT *pScaleFactor = pAacDecoderChannelInfo->pDynData->aScaleFactor;
169
480k
  const CodeBookDescription *hcb = &AACcodeBookDescriptionTable[BOOKSCL];
170
171
480k
  const USHORT(*CodeBook)[HuffmanEntries] = hcb->CodeBook;
172
173
480k
  int ScaleFactorBandsTransmitted =
174
480k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
175
1.47M
  for (group = 0; group < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo);
176
991k
       group++) {
177
3.25M
    for (band = 0; band < ScaleFactorBandsTransmitted; band++) {
178
2.26M
      switch (pCodeBook[band]) {
179
69.3k
        case ZERO_HCB: /* zero book */
180
69.3k
          pScaleFactor[band] = 0;
181
69.3k
          break;
182
183
2.13M
        default: /* decode scale factor */
184
2.13M
          if (!((flags & (AC_USAC | AC_RSVD50 | AC_RSV603DA)) && band == 0 &&
185
1.99M
                group == 0)) {
186
1.99M
            temp = CBlock_DecodeHuffmanWordCB(bs, CodeBook);
187
1.99M
            factor += temp - 60; /* MIDFAC 1.5 dB */
188
1.99M
          }
189
2.13M
          pScaleFactor[band] = factor - 100;
190
2.13M
          break;
191
192
27.1k
        case INTENSITY_HCB: /* intensity steering */
193
40.8k
        case INTENSITY_HCB2:
194
40.8k
          temp = CBlock_DecodeHuffmanWordCB(bs, CodeBook);
195
40.8k
          position += temp - 60;
196
40.8k
          pScaleFactor[band] = position - 100;
197
40.8k
          break;
198
199
15.0k
        case NOISE_HCB: /* PNS */
200
15.0k
          if (flags & (AC_MPEGD_RES | AC_USAC | AC_RSVD50 | AC_RSV603DA)) {
201
0
            return AAC_DEC_PARSE_ERROR;
202
0
          }
203
15.0k
          CPns_Read(&pAacDecoderChannelInfo->data.aac.PnsData, bs, hcb,
204
15.0k
                    pAacDecoderChannelInfo->pDynData->aScaleFactor,
205
15.0k
                    pAacDecoderChannelInfo->pDynData->RawDataInfo.GlobalGain,
206
15.0k
                    band, group);
207
15.0k
          break;
208
2.26M
      }
209
2.26M
    }
210
991k
    pCodeBook += 16;
211
991k
    pScaleFactor += 16;
212
991k
  }
213
214
480k
  return AAC_DEC_OK;
215
480k
}
216
217
void CBlock_ScaleSpectralData(CAacDecoderChannelInfo *pAacDecoderChannelInfo,
218
                              UCHAR maxSfbs,
219
598k
                              SamplingRateInfo *pSamplingRateInfo) {
220
598k
  int band;
221
598k
  int window;
222
598k
  const SHORT *RESTRICT pSfbScale = pAacDecoderChannelInfo->pDynData->aSfbScale;
223
598k
  SHORT *RESTRICT pSpecScale = pAacDecoderChannelInfo->specScale;
224
598k
  int groupwin, group;
225
598k
  const SHORT *RESTRICT BandOffsets = GetScaleFactorBandOffsets(
226
598k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
227
598k
  SPECTRAL_PTR RESTRICT pSpectralCoefficient =
228
598k
      pAacDecoderChannelInfo->pSpectralCoefficient;
229
230
598k
  FDKmemclear(pSpecScale, 8 * sizeof(SHORT));
231
232
598k
  for (window = 0, group = 0;
233
1.76M
       group < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo); group++) {
234
2.60M
    for (groupwin = 0; groupwin < GetWindowGroupLength(
235
2.60M
                                      &pAacDecoderChannelInfo->icsInfo, group);
236
1.44M
         groupwin++, window++) {
237
1.44M
      int SpecScale_window = pSpecScale[window];
238
1.44M
      FIXP_DBL *pSpectrum = SPEC(pSpectralCoefficient, window,
239
1.44M
                                 pAacDecoderChannelInfo->granuleLength);
240
241
      /* find scaling for current window */
242
4.94M
      for (band = 0; band < maxSfbs; band++) {
243
3.50M
        SpecScale_window =
244
3.50M
            fMax(SpecScale_window, (int)pSfbScale[window * 16 + band]);
245
3.50M
      }
246
247
1.44M
      if (pAacDecoderChannelInfo->pDynData->TnsData.Active &&
248
524k
          pAacDecoderChannelInfo->pDynData->TnsData.NumberOfFilters[window] >
249
524k
              0) {
250
219k
        int filter_index, SpecScale_window_tns;
251
219k
        int tns_start, tns_stop;
252
253
        /* Find max scale of TNS bands */
254
219k
        SpecScale_window_tns = 0;
255
219k
        tns_start = GetMaximumTnsBands(&pAacDecoderChannelInfo->icsInfo,
256
219k
                                       pSamplingRateInfo->samplingRateIndex);
257
219k
        tns_stop = 0;
258
219k
        for (filter_index = 0;
259
456k
             filter_index < (int)pAacDecoderChannelInfo->pDynData->TnsData
260
456k
                                .NumberOfFilters[window];
261
236k
             filter_index++) {
262
236k
          for (band = pAacDecoderChannelInfo->pDynData->TnsData
263
236k
                          .Filter[window][filter_index]
264
236k
                          .StartBand;
265
2.40M
               band < pAacDecoderChannelInfo->pDynData->TnsData
266
2.40M
                          .Filter[window][filter_index]
267
2.40M
                          .StopBand;
268
2.16M
               band++) {
269
2.16M
            SpecScale_window_tns =
270
2.16M
                fMax(SpecScale_window_tns, (int)pSfbScale[window * 16 + band]);
271
2.16M
          }
272
          /* Find TNS line boundaries for all TNS filters */
273
236k
          tns_start =
274
236k
              fMin(tns_start, (int)pAacDecoderChannelInfo->pDynData->TnsData
275
236k
                                  .Filter[window][filter_index]
276
236k
                                  .StartBand);
277
236k
          tns_stop =
278
236k
              fMax(tns_stop, (int)pAacDecoderChannelInfo->pDynData->TnsData
279
236k
                                 .Filter[window][filter_index]
280
236k
                                 .StopBand);
281
236k
        }
282
219k
        SpecScale_window_tns = SpecScale_window_tns +
283
219k
                               pAacDecoderChannelInfo->pDynData->TnsData.GainLd;
284
219k
        FDK_ASSERT(tns_stop >= tns_start);
285
        /* Consider existing headroom of all MDCT lines inside the TNS bands. */
286
219k
        SpecScale_window_tns -=
287
219k
            getScalefactor(pSpectrum + BandOffsets[tns_start],
288
219k
                           BandOffsets[tns_stop] - BandOffsets[tns_start]);
289
219k
        if (SpecScale_window <= 17) {
290
205k
          SpecScale_window_tns++;
291
205k
        }
292
        /* Add enough mantissa head room such that the spectrum is still
293
           representable after applying TNS. */
294
219k
        SpecScale_window = fMax(SpecScale_window, SpecScale_window_tns);
295
219k
      }
296
297
      /* store scaling of current window */
298
1.44M
      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
4.94M
      for (band = 0; band < maxSfbs; band++) {
307
3.50M
        int scale = fMin(DFRACT_BITS - 1,
308
3.50M
                         SpecScale_window - pSfbScale[window * 16 + band]);
309
3.50M
        if (scale) {
310
2.39M
          FDK_ASSERT(scale > 0);
311
312
          /* following relation can be used for optimizations:
313
           * (BandOffsets[i]%4) == 0 for all i */
314
2.39M
          int max_index = BandOffsets[band + 1];
315
2.39M
          DWORD_ALIGNED(pSpectrum);
316
21.8M
          for (int index = BandOffsets[band]; index < max_index; index++) {
317
19.4M
            pSpectrum[index] >>= scale;
318
19.4M
          }
319
2.39M
        }
320
3.50M
      }
321
1.44M
#endif /* FUNCTION_CBlock_ScaleSpectralData_func1 */
322
1.44M
    }
323
1.16M
  }
324
598k
}
325
326
AAC_DECODER_ERROR CBlock_ReadSectionData(
327
    HANDLE_FDK_BITSTREAM bs, CAacDecoderChannelInfo *pAacDecoderChannelInfo,
328
340k
    const SamplingRateInfo *pSamplingRateInfo, const UINT flags) {
329
340k
  int top, band;
330
340k
  int sect_len, sect_len_incr;
331
340k
  int group;
332
340k
  UCHAR sect_cb;
333
340k
  UCHAR *pCodeBook = pAacDecoderChannelInfo->pDynData->aCodeBook;
334
  /* HCR input (long) */
335
340k
  SHORT *pNumLinesInSec =
336
340k
      pAacDecoderChannelInfo->pDynData->specificTo.aac.aNumLineInSec4Hcr;
337
340k
  int numLinesInSecIdx = 0;
338
340k
  UCHAR *pHcrCodeBook =
339
340k
      pAacDecoderChannelInfo->pDynData->specificTo.aac.aCodeBooks4Hcr;
340
340k
  const SHORT *BandOffsets = GetScaleFactorBandOffsets(
341
340k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
342
340k
  pAacDecoderChannelInfo->pDynData->specificTo.aac.numberSection = 0;
343
340k
  AAC_DECODER_ERROR ErrorStatus = AAC_DEC_OK;
344
345
340k
  FDKmemclear(pCodeBook, sizeof(UCHAR) * (8 * 16));
346
347
340k
  const int nbits =
348
340k
      (IsLongBlock(&pAacDecoderChannelInfo->icsInfo) == 1) ? 5 : 3;
349
350
340k
  int sect_esc_val = (1 << nbits) - 1;
351
352
340k
  UCHAR ScaleFactorBandsTransmitted =
353
340k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
354
957k
  for (group = 0; group < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo);
355
617k
       group++) {
356
81.1M
    for (band = 0; band < ScaleFactorBandsTransmitted;) {
357
80.5M
      sect_len = 0;
358
80.5M
      if (flags & AC_ER_VCB11) {
359
53.6M
        sect_cb = (UCHAR)FDKreadBits(bs, 5);
360
53.6M
      } else
361
26.9M
        sect_cb = (UCHAR)FDKreadBits(bs, 4);
362
363
80.5M
      if (((flags & AC_ER_VCB11) == 0) || (sect_cb < 11) ||
364
80.4M
          ((sect_cb > 11) && (sect_cb < 16))) {
365
80.4M
        sect_len_incr = FDKreadBits(bs, nbits);
366
80.6M
        while (sect_len_incr == sect_esc_val) {
367
175k
          sect_len += sect_esc_val;
368
175k
          sect_len_incr = FDKreadBits(bs, nbits);
369
175k
        }
370
80.4M
      } else {
371
80.6k
        sect_len_incr = 1;
372
80.6k
      }
373
374
80.5M
      sect_len += sect_len_incr;
375
376
80.5M
      top = band + sect_len;
377
378
80.5M
      if (flags & AC_ER_HCR) {
379
        /* HCR input (long) -- collecting sideinfo (for HCR-_long_ only) */
380
146k
        if (numLinesInSecIdx >= MAX_SFB_HCR) {
381
264
          return AAC_DEC_PARSE_ERROR;
382
264
        }
383
145k
        if (top > (int)GetNumberOfScaleFactorBands(
384
145k
                      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo)) {
385
12
          return AAC_DEC_PARSE_ERROR;
386
12
        }
387
145k
        pNumLinesInSec[numLinesInSecIdx] = BandOffsets[top] - BandOffsets[band];
388
145k
        numLinesInSecIdx++;
389
145k
        if (sect_cb == BOOKSCL) {
390
2
          return AAC_DEC_INVALID_CODE_BOOK;
391
145k
        } else {
392
145k
          *pHcrCodeBook++ = sect_cb;
393
145k
        }
394
145k
        pAacDecoderChannelInfo->pDynData->specificTo.aac.numberSection++;
395
145k
      }
396
397
      /* Check spectral line limits */
398
80.5M
      if (IsLongBlock(&(pAacDecoderChannelInfo->icsInfo))) {
399
19.7M
        if (top > 64) {
400
11
          return AAC_DEC_DECODE_FRAME_ERROR;
401
11
        }
402
60.7M
      } else { /* short block */
403
60.7M
        if (top + group * 16 > (8 * 16)) {
404
27
          return AAC_DEC_DECODE_FRAME_ERROR;
405
27
        }
406
60.7M
      }
407
408
      /* Check if decoded codebook index is feasible */
409
80.5M
      if ((sect_cb == BOOKSCL) ||
410
80.5M
          ((sect_cb == INTENSITY_HCB || sect_cb == INTENSITY_HCB2) &&
411
39.2k
           pAacDecoderChannelInfo->pDynData->RawDataInfo.CommonWindow == 0)) {
412
169
        return AAC_DEC_INVALID_CODE_BOOK;
413
169
      }
414
415
      /* Store codebook index */
416
83.5M
      for (; band < top; band++) {
417
2.93M
        pCodeBook[group * 16 + band] = sect_cb;
418
2.93M
      }
419
80.5M
    }
420
617k
  }
421
422
339k
  return ErrorStatus;
423
340k
}
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.52M
    const SCHAR *RESTRICT ExponentTabler, INT noLines, INT scale) {
440
1.52M
  scale = scale + 1; /* +1 to compensate fMultDiv2 shift-right in loop */
441
442
1.52M
  FIXP_DBL *RESTRICT ptr = spectrum;
443
1.52M
  FIXP_DBL signedValue;
444
445
10.8M
  for (INT i = noLines; i--;) {
446
9.34M
    if ((signedValue = *ptr++) != FL2FXCONST_DBL(0)) {
447
4.40M
      FIXP_DBL value = fAbs(signedValue);
448
4.40M
      UINT freeBits = CntLeadingZeros(value);
449
4.40M
      UINT exponent = 32 - freeBits;
450
451
4.40M
      UINT x = (UINT)(LONG)value << (INT)freeBits;
452
4.40M
      x <<= 1; /* shift out sign bit to avoid masking later on */
453
4.40M
      UINT tableIndex = x >> 24;
454
4.40M
      x = (x >> 20) & 0x0F;
455
456
4.40M
      UINT r0 = (UINT)(LONG)InverseQuantTabler[tableIndex + 0];
457
4.40M
      UINT r1 = (UINT)(LONG)InverseQuantTabler[tableIndex + 1];
458
4.40M
      UINT temp = (r1 - r0) * x + (r0 << 4);
459
460
4.40M
      value = fMultDiv2((FIXP_DBL)temp, MantissaTabler[exponent]);
461
462
      /* + 1 compensates fMultDiv2() */
463
4.40M
      scaleValueInPlace(&value, scale + ExponentTabler[exponent]);
464
465
4.40M
      signedValue = (signedValue < (FIXP_DBL)0) ? -value : value;
466
4.40M
      ptr[-1] = signedValue;
467
4.40M
    }
468
9.34M
  }
469
1.52M
}
470
471
static inline FIXP_DBL maxabs_D(const FIXP_DBL *pSpectralCoefficient,
472
2.80M
                                const int noLines) {
473
  /* Find max spectral line value of the current sfb */
474
2.80M
  FIXP_DBL locMax = (FIXP_DBL)0;
475
2.80M
  int i;
476
477
2.80M
  DWORD_ALIGNED(pSpectralCoefficient);
478
479
25.0M
  for (i = noLines; i-- > 0;) {
480
    /* Expensive memory access */
481
22.2M
    locMax = fMax(fixp_abs(pSpectralCoefficient[i]), locMax);
482
22.2M
  }
483
484
2.80M
  return locMax;
485
2.80M
}
486
487
AAC_DECODER_ERROR CBlock_InverseQuantizeSpectralData(
488
    CAacDecoderChannelInfo *pAacDecoderChannelInfo,
489
    SamplingRateInfo *pSamplingRateInfo, UCHAR *band_is_noise,
490
618k
    UCHAR active_band_search) {
491
618k
  int window, group, groupwin, band;
492
618k
  int ScaleFactorBandsTransmitted =
493
618k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
494
618k
  UCHAR *RESTRICT pCodeBook = pAacDecoderChannelInfo->pDynData->aCodeBook;
495
618k
  SHORT *RESTRICT pSfbScale = pAacDecoderChannelInfo->pDynData->aSfbScale;
496
618k
  SHORT *RESTRICT pScaleFactor = pAacDecoderChannelInfo->pDynData->aScaleFactor;
497
618k
  const SHORT *RESTRICT BandOffsets = GetScaleFactorBandOffsets(
498
618k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
499
618k
  const SHORT total_bands =
500
618k
      GetScaleFactorBandsTotal(&pAacDecoderChannelInfo->icsInfo);
501
502
618k
  FDKmemclear(pAacDecoderChannelInfo->pDynData->aSfbScale,
503
618k
              (8 * 16) * sizeof(SHORT));
504
505
618k
  for (window = 0, group = 0;
506
1.83M
       group < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo); group++) {
507
2.72M
    for (groupwin = 0; groupwin < GetWindowGroupLength(
508
2.72M
                                      &pAacDecoderChannelInfo->icsInfo, group);
509
1.50M
         groupwin++, window++) {
510
      /* inverse quantization */
511
5.03M
      for (band = 0; band < ScaleFactorBandsTransmitted; band++) {
512
3.53M
        FIXP_DBL *pSpectralCoefficient =
513
3.53M
            SPEC(pAacDecoderChannelInfo->pSpectralCoefficient, window,
514
3.53M
                 pAacDecoderChannelInfo->granuleLength) +
515
3.53M
            BandOffsets[band];
516
3.53M
        FIXP_DBL locMax;
517
518
3.53M
        const int noLines = BandOffsets[band + 1] - BandOffsets[band];
519
3.53M
        const int bnds = group * 16 + band;
520
521
3.53M
        if ((pCodeBook[bnds] == ZERO_HCB) ||
522
3.08M
            (pCodeBook[bnds] == INTENSITY_HCB) ||
523
2.98M
            (pCodeBook[bnds] == INTENSITY_HCB2))
524
626k
          continue;
525
526
2.90M
        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
96.6k
          pSfbScale[window * 16 + band] = (pScaleFactor[bnds] >> 2) + 1;
531
96.6k
          continue;
532
96.6k
        }
533
534
2.80M
        locMax = maxabs_D(pSpectralCoefficient, noLines);
535
536
2.80M
        if (active_band_search) {
537
2.80M
          if (locMax != FIXP_DBL(0)) {
538
1.52M
            band_is_noise[group * 16 + band] = 0;
539
1.52M
          }
540
2.80M
        }
541
542
        /* Cheap robustness improvement - Do not remove!!! */
543
2.80M
        if (fixp_abs(locMax) > (FIXP_DBL)MAX_QUANTIZED_VALUE) {
544
29
          return AAC_DEC_PARSE_ERROR;
545
29
        }
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
2.80M
        int msb = pScaleFactor[bnds] >> 2;
582
583
        /* Inverse quantize band only if it is not empty */
584
2.80M
        if (locMax != FIXP_DBL(0)) {
585
1.52M
          int lsb = pScaleFactor[bnds] & 0x03;
586
587
1.52M
          int scale = EvaluatePower43(&locMax, lsb);
588
589
1.52M
          scale = CntLeadingZeros(locMax) - scale - 2;
590
591
1.52M
          pSfbScale[window * 16 + band] = msb - scale;
592
1.52M
          InverseQuantizeBand(pSpectralCoefficient, InverseQuantTable,
593
1.52M
                              MantissaTable[lsb], ExponentTable[lsb], noLines,
594
1.52M
                              scale);
595
1.52M
        } else {
596
1.28M
          pSfbScale[window * 16 + band] = msb;
597
1.28M
        }
598
599
2.80M
      } /* for (band=0; band < ScaleFactorBandsTransmitted; band++) */
600
601
      /* Make sure the array is cleared to the end */
602
1.50M
      SHORT start_clear = BandOffsets[ScaleFactorBandsTransmitted];
603
1.50M
      SHORT end_clear = BandOffsets[total_bands];
604
1.50M
      int diff_clear = (int)(end_clear - start_clear);
605
1.50M
      FIXP_DBL *pSpectralCoefficient =
606
1.50M
          SPEC(pAacDecoderChannelInfo->pSpectralCoefficient, window,
607
1.50M
               pAacDecoderChannelInfo->granuleLength) +
608
1.50M
          start_clear;
609
1.50M
      FDKmemclear(pSpectralCoefficient, diff_clear * sizeof(FIXP_DBL));
610
611
1.50M
    } /* for (groupwin=0; groupwin <
612
         GetWindowGroupLength(&pAacDecoderChannelInfo->icsInfo,group);
613
         groupwin++, window++) */
614
1.21M
  }   /* for (window=0, group=0; group <
615
         GetWindowGroups(&pAacDecoderChannelInfo->icsInfo); group++)*/
616
617
618k
  return AAC_DEC_OK;
618
618k
}
619
620
AAC_DECODER_ERROR CBlock_ReadSpectralData(
621
    HANDLE_FDK_BITSTREAM bs, CAacDecoderChannelInfo *pAacDecoderChannelInfo,
622
339k
    const SamplingRateInfo *pSamplingRateInfo, const UINT flags) {
623
339k
  int index, i;
624
339k
  const SHORT *RESTRICT BandOffsets = GetScaleFactorBandOffsets(
625
339k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
626
627
339k
  SPECTRAL_PTR pSpectralCoefficient =
628
339k
      pAacDecoderChannelInfo->pSpectralCoefficient;
629
630
339k
  FDK_ASSERT(BandOffsets != NULL);
631
632
339k
  FDKmemclear(pSpectralCoefficient, sizeof(SPECTRUM));
633
634
339k
  if ((flags & AC_ER_HCR) == 0) {
635
328k
    int group;
636
328k
    int groupoffset;
637
328k
    UCHAR *pCodeBook = pAacDecoderChannelInfo->pDynData->aCodeBook;
638
328k
    int ScaleFactorBandsTransmitted =
639
328k
        GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
640
328k
    int granuleLength = pAacDecoderChannelInfo->granuleLength;
641
642
328k
    groupoffset = 0;
643
644
    /* plain huffman decoder  short */
645
328k
    int max_group = GetWindowGroups(&pAacDecoderChannelInfo->icsInfo);
646
647
914k
    for (group = 0; group < max_group; group++) {
648
585k
      int max_groupwin =
649
585k
          GetWindowGroupLength(&pAacDecoderChannelInfo->icsInfo, group);
650
585k
      int band;
651
652
585k
      int bnds = group * 16;
653
654
585k
      int bandOffset1 = BandOffsets[0];
655
1.55M
      for (band = 0; band < ScaleFactorBandsTransmitted; band++, bnds++) {
656
971k
        UCHAR currentCB = pCodeBook[bnds];
657
971k
        int bandOffset0 = bandOffset1;
658
971k
        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
971k
        if ((currentCB >= 16) && (currentCB <= 31)) {
664
56.5k
          pCodeBook[bnds] = currentCB = 11;
665
56.5k
        }
666
971k
        if (((currentCB != ZERO_HCB) && (currentCB != NOISE_HCB) &&
667
626k
             (currentCB != INTENSITY_HCB) && (currentCB != INTENSITY_HCB2))) {
668
509k
          const CodeBookDescription *hcb =
669
509k
              &AACcodeBookDescriptionTable[currentCB];
670
509k
          int step = hcb->Dimension;
671
509k
          int offset = hcb->Offset;
672
509k
          int bits = hcb->numBits;
673
509k
          int mask = (1 << bits) - 1;
674
509k
          const USHORT(*CodeBook)[HuffmanEntries] = hcb->CodeBook;
675
509k
          int groupwin;
676
677
509k
          FIXP_DBL *mdctSpectrum =
678
509k
              &pSpectralCoefficient[groupoffset * granuleLength];
679
680
509k
          if (offset == 0) {
681
668k
            for (groupwin = 0; groupwin < max_groupwin; groupwin++) {
682
1.05M
              for (index = bandOffset0; index < bandOffset1; index += step) {
683
706k
                int idx = CBlock_DecodeHuffmanWordCB(bs, CodeBook);
684
2.35M
                for (i = 0; i < step; i++, idx >>= bits) {
685
1.64M
                  FIXP_DBL tmp = (FIXP_DBL)((idx & mask) - offset);
686
1.64M
                  if (tmp != FIXP_DBL(0)) tmp = (FDKreadBit(bs)) ? -tmp : tmp;
687
1.64M
                  mdctSpectrum[index + i] = tmp;
688
1.64M
                }
689
690
706k
                if (currentCB == ESCBOOK) {
691
731k
                  for (int j = 0; j < 2; j++)
692
487k
                    mdctSpectrum[index + j] = (FIXP_DBL)CBlock_GetEscape(
693
487k
                        bs, (LONG)mdctSpectrum[index + j]);
694
243k
                }
695
706k
              }
696
352k
              mdctSpectrum += granuleLength;
697
352k
            }
698
316k
          } else {
699
393k
            for (groupwin = 0; groupwin < max_groupwin; groupwin++) {
700
522k
              for (index = bandOffset0; index < bandOffset1; index += step) {
701
322k
                int idx = CBlock_DecodeHuffmanWordCB(bs, CodeBook);
702
1.26M
                for (i = 0; i < step; i++, idx >>= bits) {
703
941k
                  mdctSpectrum[index + i] = (FIXP_DBL)((idx & mask) - offset);
704
941k
                }
705
322k
                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
322k
              }
711
200k
              mdctSpectrum += granuleLength;
712
200k
            }
713
193k
          }
714
509k
        }
715
971k
      }
716
585k
      groupoffset += max_groupwin;
717
585k
    }
718
    /* plain huffman decoding (short) finished */
719
328k
  }
720
721
  /* HCR - Huffman Codeword Reordering  short */
722
11.3k
  else /* if ( flags & AC_ER_HCR ) */
723
724
11.3k
  {
725
11.3k
    H_HCR_INFO hHcr = &pAacDecoderChannelInfo->pComData->overlay.aac.erHcrInfo;
726
727
11.3k
    int hcrStatus = 0;
728
729
    /* advanced Huffman decoding starts here (HCR decoding :) */
730
11.3k
    if (pAacDecoderChannelInfo->pDynData->specificTo.aac
731
11.3k
            .lenOfReorderedSpectralData != 0) {
732
      /* HCR initialization short */
733
11.2k
      hcrStatus = HcrInit(hHcr, pAacDecoderChannelInfo, pSamplingRateInfo, bs);
734
735
11.2k
      if (hcrStatus != 0) {
736
38
        return AAC_DEC_DECODE_FRAME_ERROR;
737
38
      }
738
739
      /* HCR decoding short */
740
11.1k
      hcrStatus =
741
11.1k
          HcrDecoder(hHcr, pAacDecoderChannelInfo, pSamplingRateInfo, bs);
742
743
11.1k
      if (hcrStatus != 0) {
744
8.04k
#if HCR_ERROR_CONCEALMENT
745
8.04k
        HcrMuteErroneousLines(hHcr);
746
#else
747
        return AAC_DEC_DECODE_FRAME_ERROR;
748
#endif /* HCR_ERROR_CONCEALMENT */
749
8.04k
      }
750
751
11.1k
      FDKpushFor(bs, pAacDecoderChannelInfo->pDynData->specificTo.aac
752
11.1k
                         .lenOfReorderedSpectralData);
753
11.1k
    }
754
11.3k
  }
755
  /* HCR - Huffman Codeword Reordering short finished */
756
757
339k
  if (IsLongBlock(&pAacDecoderChannelInfo->icsInfo) &&
758
274k
      !(flags & (AC_ELD | AC_SCALABLE))) {
759
    /* apply pulse data */
760
19.0k
    CPulseData_Apply(
761
19.0k
        &pAacDecoderChannelInfo->pDynData->specificTo.aac.PulseData,
762
19.0k
        GetScaleFactorBandOffsets(&pAacDecoderChannelInfo->icsInfo,
763
19.0k
                                  pSamplingRateInfo),
764
19.0k
        SPEC_LONG(pSpectralCoefficient));
765
19.0k
  }
766
767
339k
  return AAC_DEC_OK;
768
339k
}
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.2k
                       UCHAR *band_is_noise) {
786
13.2k
  const SHORT *swb_offset = GetScaleFactorBandOffsets(
787
13.2k
      &pAacDecoderChannelInfo->icsInfo, pSamplingRateInfo);
788
13.2k
  int g, win, gwin, sfb, noiseFillingStartOffset, nfStartOffset_sfb;
789
790
  /* Obtain noise level and scale factor offset. */
791
13.2k
  int noise_level = pAacDecoderChannelInfo->pDynData->specificTo.usac
792
13.2k
                        .fd_noise_level_and_offset >>
793
13.2k
                    5;
794
13.2k
  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.2k
  const int noise_offset = (pAacDecoderChannelInfo->pDynData->specificTo.usac
799
13.2k
                                .fd_noise_level_and_offset &
800
13.2k
                            0x1f) -
801
13.2k
                           16;
802
803
13.2k
  int max_sfb =
804
13.2k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo->icsInfo);
805
806
13.2k
  noiseFillingStartOffset =
807
13.2k
      (GetWindowSequence(&pAacDecoderChannelInfo->icsInfo) == BLOCK_SHORT)
808
13.2k
          ? 20
809
13.2k
          : 160;
810
13.2k
  if (pAacDecoderChannelInfo->granuleLength == 96) {
811
3.94k
    noiseFillingStartOffset =
812
3.94k
        (3 * noiseFillingStartOffset) /
813
3.94k
        4; /* scale offset with 3/4 for coreCoderFrameLength == 768 */
814
3.94k
  }
815
816
  /* determine sfb from where on noise filling is applied */
817
128k
  for (sfb = 0; swb_offset[sfb] < noiseFillingStartOffset; sfb++)
818
115k
    ;
819
13.2k
  nfStartOffset_sfb = sfb;
820
821
  /* if (noise_level!=0) */
822
13.2k
  {
823
72.7k
    for (g = 0, win = 0; g < GetWindowGroups(&pAacDecoderChannelInfo->icsInfo);
824
59.5k
         g++) {
825
59.5k
      int windowGroupLength =
826
59.5k
          GetWindowGroupLength(&pAacDecoderChannelInfo->icsInfo, g);
827
68.3k
      for (sfb = nfStartOffset_sfb; sfb < max_sfb; sfb++) {
828
8.77k
        int bin_start = swb_offset[sfb];
829
8.77k
        int bin_stop = swb_offset[sfb + 1];
830
831
8.77k
        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.77k
        if (flagN) {
836
          /* Change scaling factors for empty signal bands */
837
5.01k
          pAacDecoderChannelInfo->pDynData->aScaleFactor[g * 16 + sfb] +=
838
5.01k
              noise_offset;
839
          /* scale factor "sf" implied gain "g" is g = 2^(sf/4) */
840
10.6k
          for (gwin = 0; gwin < windowGroupLength; gwin++) {
841
5.67k
            pAacDecoderChannelInfo->pDynData
842
5.67k
                ->aSfbScale[(win + gwin) * 16 + sfb] += (noise_offset >> 2);
843
5.67k
          }
844
5.01k
        }
845
846
8.77k
        ULONG seed = *nfRandomSeed;
847
        /* + 1 because exponent of MantissaTable[lsb][0] is always 1. */
848
8.77k
        int scale =
849
8.77k
            (pAacDecoderChannelInfo->pDynData->aScaleFactor[g * 16 + sfb] >>
850
8.77k
             2) +
851
8.77k
            1;
852
8.77k
        int lsb =
853
8.77k
            pAacDecoderChannelInfo->pDynData->aScaleFactor[g * 16 + sfb] & 3;
854
8.77k
        FIXP_DBL mantissa = MantissaTable[lsb][0];
855
856
19.8k
        for (gwin = 0; gwin < windowGroupLength; gwin++) {
857
11.0k
          FIXP_DBL *pSpec =
858
11.0k
              SPEC(pAacDecoderChannelInfo->pSpectralCoefficient, win + gwin,
859
11.0k
                   pAacDecoderChannelInfo->granuleLength);
860
861
11.0k
          int scale1 = scale - pAacDecoderChannelInfo->pDynData
862
11.0k
                                   ->aSfbScale[(win + gwin) * 16 + sfb];
863
11.0k
          FIXP_DBL scaled_noiseVal_pos =
864
11.0k
              scaleValue(fMultDiv2(noiseVal_pos, mantissa), scale1);
865
11.0k
          FIXP_DBL scaled_noiseVal_neg = -scaled_noiseVal_pos;
866
867
          /* If the whole band is zero, just fill without checking */
868
11.0k
          if (flagN) {
869
99.3k
            for (int bin = bin_start; bin < bin_stop; bin++) {
870
93.6k
              seed = (ULONG)(
871
93.6k
                  (UINT64)seed * 69069 +
872
93.6k
                  5); /* Inlined: UsacRandomSign - origin in usacdec_lpd.h */
873
93.6k
              pSpec[bin] =
874
93.6k
                  (seed & 0x10000) ? scaled_noiseVal_neg : scaled_noiseVal_pos;
875
93.6k
            } /* for (bin...) */
876
5.67k
          }
877
          /*If band is sparsely filled, check for 0 and fill */
878
5.41k
          else {
879
67.7k
            for (int bin = bin_start; bin < bin_stop; bin++) {
880
62.3k
              if (pSpec[bin] == (FIXP_DBL)0) {
881
43.7k
                seed = (ULONG)(
882
43.7k
                    (UINT64)seed * 69069 +
883
43.7k
                    5); /* Inlined: UsacRandomSign - origin in usacdec_lpd.h */
884
43.7k
                pSpec[bin] = (seed & 0x10000) ? scaled_noiseVal_neg
885
43.7k
                                              : scaled_noiseVal_pos;
886
43.7k
              }
887
62.3k
            } /* for (bin...) */
888
5.41k
          }
889
890
11.0k
        } /* for (gwin...) */
891
8.77k
        *nfRandomSeed = seed;
892
8.77k
      } /* for (sfb...) */
893
59.5k
      win += windowGroupLength;
894
59.5k
    } /* for (g...) */
895
896
13.2k
  } /* ... */
897
13.2k
}
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
281k
    const UINT flags) {
904
281k
  AAC_DECODER_ERROR errorAAC = AAC_DEC_OK;
905
281k
  ARITH_CODING_ERROR error = ARITH_CODER_OK;
906
281k
  int arith_reset_flag, lg, numWin, win, winLen;
907
281k
  const SHORT *RESTRICT BandOffsets;
908
909
  /* number of transmitted spectral coefficients */
910
281k
  BandOffsets = GetScaleFactorBandOffsets(&pAacDecoderChannelInfo->icsInfo,
911
281k
                                          pSamplingRateInfo);
912
281k
  lg = BandOffsets[GetScaleFactorBandsTransmitted(
913
281k
      &pAacDecoderChannelInfo->icsInfo)];
914
915
281k
  numWin = GetWindowsPerFrame(&pAacDecoderChannelInfo->icsInfo);
916
281k
  winLen = (IsLongBlock(&pAacDecoderChannelInfo->icsInfo))
917
281k
               ? (int)frame_length
918
281k
               : (int)frame_length / numWin;
919
920
281k
  if (flags & AC_INDEP) {
921
210k
    arith_reset_flag = 1;
922
210k
  } else {
923
70.8k
    arith_reset_flag = (USHORT)FDKreadBits(hBs, 1);
924
70.8k
  }
925
926
991k
  for (win = 0; win < numWin; win++) {
927
711k
    error =
928
711k
        CArco_DecodeArithData(pAacDecoderStaticChannelInfo->hArCo, hBs,
929
711k
                              SPEC(pAacDecoderChannelInfo->pSpectralCoefficient,
930
711k
                                   win, pAacDecoderChannelInfo->granuleLength),
931
711k
                              lg, winLen, arith_reset_flag && (win == 0));
932
711k
    if (error != ARITH_CODER_OK) {
933
1.25k
      goto bail;
934
1.25k
    }
935
711k
  }
936
937
281k
bail:
938
281k
  if (error == ARITH_CODER_ERROR) {
939
1.25k
    errorAAC = AAC_DEC_PARSE_ERROR;
940
1.25k
  }
941
942
281k
  return errorAAC;
943
281k
}
944
945
void ApplyTools(CAacDecoderChannelInfo *pAacDecoderChannelInfo[],
946
                const SamplingRateInfo *pSamplingRateInfo, const UINT flags,
947
                const UINT elFlags, const int channel,
948
551k
                const int common_window) {
949
551k
  if (!(flags & (AC_USAC | AC_RSVD50 | AC_MPEGD_RES | AC_RSV603DA))) {
950
330k
    CPns_Apply(&pAacDecoderChannelInfo[channel]->data.aac.PnsData,
951
330k
               &pAacDecoderChannelInfo[channel]->icsInfo,
952
330k
               pAacDecoderChannelInfo[channel]->pSpectralCoefficient,
953
330k
               pAacDecoderChannelInfo[channel]->specScale,
954
330k
               pAacDecoderChannelInfo[channel]->pDynData->aScaleFactor,
955
330k
               pSamplingRateInfo,
956
330k
               pAacDecoderChannelInfo[channel]->granuleLength, channel);
957
330k
  }
958
959
551k
  UCHAR nbands =
960
551k
      GetScaleFactorBandsTransmitted(&pAacDecoderChannelInfo[channel]->icsInfo);
961
962
551k
  CTns_Apply(&pAacDecoderChannelInfo[channel]->pDynData->TnsData,
963
551k
             &pAacDecoderChannelInfo[channel]->icsInfo,
964
551k
             pAacDecoderChannelInfo[channel]->pSpectralCoefficient,
965
551k
             pSamplingRateInfo, pAacDecoderChannelInfo[channel]->granuleLength,
966
551k
             nbands, (elFlags & AC_EL_ENHANCED_NOISE) ? 1 : 0, flags);
967
551k
}
968
969
184k
static int getWindow2Nr(int length, int shape) {
970
184k
  int nr = 0;
971
972
184k
  if (shape == 2) {
973
    /* Low Overlap, 3/4 zeroed */
974
151
    nr = (length * 3) >> 2;
975
151
  }
976
977
184k
  return nr;
978
184k
}
979
980
293k
FIXP_DBL get_gain(const FIXP_DBL *x, const FIXP_DBL *y, int n) {
981
293k
  FIXP_DBL corr = (FIXP_DBL)0;
982
293k
  FIXP_DBL ener = (FIXP_DBL)1;
983
984
293k
  int headroom_x = getScalefactor(x, n);
985
293k
  int headroom_y = getScalefactor(y, n);
986
987
  /*Calculate the normalization necessary due to addition*/
988
  /* Check for power of two /special case */
989
293k
  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
293k
  width_shift = 31 - width_shift;
993
994
19.0M
  for (int i = 0; i < n; i++) {
995
18.7M
    corr +=
996
18.7M
        fMultDiv2((x[i] << headroom_x), (y[i] << headroom_y)) >> width_shift;
997
18.7M
    ener += fPow2Div2((y[i] << headroom_y)) >> width_shift;
998
18.7M
  }
999
1000
293k
  int exp_corr = (17 - headroom_x) + (17 - headroom_y) + width_shift + 1;
1001
293k
  int exp_ener = ((17 - headroom_y) << 1) + width_shift + 1;
1002
1003
293k
  int temp_exp = 0;
1004
293k
  FIXP_DBL output = fDivNormSigned(corr, ener, &temp_exp);
1005
1006
293k
  int output_exp = (exp_corr - exp_ener) + temp_exp;
1007
1008
293k
  INT output_shift = 17 - output_exp;
1009
293k
  output_shift = fMin(output_shift, 31);
1010
1011
293k
  output = scaleValue(output, -output_shift);
1012
1013
293k
  return output;
1014
293k
}
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
386k
    const INT aacOutDataHeadroom, UINT elFlags, INT elCh) {
1021
386k
  int fr, fl, tl, nSpec;
1022
1023
386k
#if defined(FDK_ASSERT_ENABLE)
1024
386k
  LONG nSamples;
1025
386k
#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
386k
  tl = frameLen;
1033
386k
  nSpec = 1;
1034
1035
386k
  switch (pAacDecoderChannelInfo->icsInfo.WindowSequence) {
1036
0
    default:
1037
184k
    case BLOCK_LONG:
1038
184k
      fl = frameLen;
1039
184k
      fr = frameLen -
1040
184k
           getWindow2Nr(frameLen,
1041
184k
                        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
184k
      if (pAacDecoderStaticChannelInfo->IMdct.prev_tl == 0) {
1047
19.7k
        fl = fr;
1048
19.7k
      }
1049
184k
      break;
1050
29.2k
    case BLOCK_STOP:
1051
29.2k
      fl = frameLen >> 3;
1052
29.2k
      fr = frameLen;
1053
29.2k
      break;
1054
46.6k
    case BLOCK_START: /* or StopStartSequence */
1055
46.6k
      fl = frameLen;
1056
46.6k
      fr = frameLen >> 3;
1057
46.6k
      break;
1058
125k
    case BLOCK_SHORT:
1059
125k
      fl = fr = frameLen >> 3;
1060
125k
      tl >>= 3;
1061
125k
      nSpec = 8;
1062
125k
      break;
1063
386k
  }
1064
1065
386k
  {
1066
386k
    int last_frame_lost = pAacDecoderStaticChannelInfo->last_lpc_lost;
1067
1068
386k
    if (pAacDecoderStaticChannelInfo->last_core_mode == LPD) {
1069
24.1k
      INT fac_FB = 1;
1070
24.1k
      if (elFlags & AC_EL_FULLBANDLPD) {
1071
0
        fac_FB = 2;
1072
0
      }
1073
1074
24.1k
      FIXP_DBL *synth;
1075
1076
      /* Keep some free space at the beginning of the buffer. To be used for
1077
       * past data */
1078
24.1k
      if (!(elFlags & AC_EL_LPDSTEREOIDX)) {
1079
24.1k
        synth = pWorkBuffer1 + ((PIT_MAX_MAX - (1 * L_SUBFR)) * fac_FB);
1080
24.1k
      } else {
1081
0
        synth = pWorkBuffer1 + PIT_MAX_MAX * fac_FB;
1082
0
      }
1083
1084
24.1k
      int fac_length =
1085
24.1k
          (pAacDecoderChannelInfo->icsInfo.WindowSequence == BLOCK_SHORT)
1086
24.1k
              ? (frameLen >> 4)
1087
24.1k
              : (frameLen >> 3);
1088
1089
24.1k
      INT pitch[NB_SUBFR_SUPERFR + SYN_SFD];
1090
24.1k
      FIXP_DBL pit_gain[NB_SUBFR_SUPERFR + SYN_SFD];
1091
1092
24.1k
      int nbDiv = (elFlags & AC_EL_FULLBANDLPD) ? 2 : 4;
1093
24.1k
      int lFrame = (elFlags & AC_EL_FULLBANDLPD) ? frameLen / 2 : frameLen;
1094
24.1k
      int nbSubfr =
1095
24.1k
          lFrame / (nbDiv * L_SUBFR); /* number of subframes per division */
1096
24.1k
      int LpdSfd = (nbDiv * nbSubfr) >> 1;
1097
24.1k
      int SynSfd = LpdSfd - BPF_SFD;
1098
1099
24.1k
      FDKmemclear(
1100
24.1k
          pitch,
1101
24.1k
          sizeof(
1102
24.1k
              pitch));  // added to prevent ferret errors in bass_pf_1sf_delay
1103
24.1k
      FDKmemclear(pit_gain, sizeof(pit_gain));
1104
1105
      /* FAC case */
1106
24.1k
      if (pAacDecoderStaticChannelInfo->last_lpd_mode == 0 ||
1107
19.6k
          pAacDecoderStaticChannelInfo->last_lpd_mode == 4) {
1108
19.6k
        FIXP_DBL fac_buf[LFAC];
1109
19.6k
        FIXP_LPC *A = pAacDecoderChannelInfo->data.usac.lp_coeff[0];
1110
1111
19.6k
        if (!frameOk || last_frame_lost ||
1112
19.6k
            (pAacDecoderChannelInfo->data.usac.fac_data[0] == NULL)) {
1113
2
          FDKmemclear(fac_buf,
1114
2
                      pAacDecoderChannelInfo->granuleLength * sizeof(FIXP_DBL));
1115
2
          pAacDecoderChannelInfo->data.usac.fac_data[0] = fac_buf;
1116
2
          pAacDecoderChannelInfo->data.usac.fac_data_e[0] = 0;
1117
2
        }
1118
1119
19.6k
        INT A_exp; /* linear prediction coefficients exponent */
1120
19.6k
        {
1121
333k
          for (int i = 0; i < M_LP_FILTER_ORDER; i++) {
1122
313k
            A[i] = FX_DBL2FX_LPC(fixp_cos(
1123
313k
                fMult(pAacDecoderStaticChannelInfo->lpc4_lsf[i],
1124
313k
                      FL2FXCONST_SGL((1 << LSPARG_SCALE) * M_PI / 6400.0)),
1125
313k
                LSF_SCALE - LSPARG_SCALE));
1126
313k
          }
1127
1128
19.6k
          E_LPC_f_lsp_a_conversion(A, A, &A_exp);
1129
19.6k
        }
1130
1131
19.6k
#if defined(FDK_ASSERT_ENABLE)
1132
19.6k
        nSamples =
1133
19.6k
#endif
1134
19.6k
            CLpd_FAC_Acelp2Mdct(
1135
19.6k
                &pAacDecoderStaticChannelInfo->IMdct, synth,
1136
19.6k
                SPEC_LONG(pAacDecoderChannelInfo->pSpectralCoefficient),
1137
19.6k
                pAacDecoderChannelInfo->specScale, nSpec,
1138
19.6k
                pAacDecoderChannelInfo->data.usac.fac_data[0],
1139
19.6k
                pAacDecoderChannelInfo->data.usac.fac_data_e[0], fac_length,
1140
19.6k
                frameLen, tl,
1141
19.6k
                FDKgetWindowSlope(
1142
19.6k
                    fr, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1143
19.6k
                fr, A, A_exp, &pAacDecoderStaticChannelInfo->acelp,
1144
19.6k
                (FIXP_DBL)0, /* FAC gain has already been applied. */
1145
19.6k
                (last_frame_lost || !frameOk), 1,
1146
19.6k
                pAacDecoderStaticChannelInfo->last_lpd_mode, 0,
1147
19.6k
                pAacDecoderChannelInfo->currAliasingSymmetry);
1148
1149
19.6k
      } else {
1150
4.51k
#if defined(FDK_ASSERT_ENABLE)
1151
4.51k
        nSamples =
1152
4.51k
#endif
1153
4.51k
            imlt_block(
1154
4.51k
                &pAacDecoderStaticChannelInfo->IMdct, synth,
1155
4.51k
                SPEC_LONG(pAacDecoderChannelInfo->pSpectralCoefficient),
1156
4.51k
                pAacDecoderChannelInfo->specScale, nSpec, frameLen, tl,
1157
4.51k
                FDKgetWindowSlope(
1158
4.51k
                    fl, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1159
4.51k
                fl,
1160
4.51k
                FDKgetWindowSlope(
1161
4.51k
                    fr, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1162
4.51k
                fr, (FIXP_DBL)0,
1163
4.51k
                pAacDecoderChannelInfo->currAliasingSymmetry
1164
4.51k
                    ? MLT_FLAG_CURR_ALIAS_SYMMETRY
1165
4.51k
                    : 0);
1166
4.51k
      }
1167
24.1k
      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
24.1k
      if (!(elFlags & AC_EL_LPDSTEREOIDX)) {
1172
24.1k
        FDKmemcpy(pitch, pAacDecoderStaticChannelInfo->old_T_pf,
1173
24.1k
                  SynSfd * sizeof(INT));
1174
24.1k
        FDKmemcpy(pit_gain, pAacDecoderStaticChannelInfo->old_gain_pf,
1175
24.1k
                  SynSfd * sizeof(FIXP_DBL));
1176
1177
120k
        for (int i = SynSfd; i < LpdSfd + 3; i++) {
1178
96.5k
          pitch[i] = L_SUBFR;
1179
96.5k
          pit_gain[i] = (FIXP_DBL)0;
1180
96.5k
        }
1181
1182
24.1k
        if (pAacDecoderStaticChannelInfo->last_lpd_mode == 0) {
1183
19.6k
          pitch[SynSfd] = pitch[SynSfd - 1];
1184
19.6k
          pit_gain[SynSfd] = pit_gain[SynSfd - 1];
1185
19.6k
          if (IsLongBlock(&pAacDecoderChannelInfo->icsInfo)) {
1186
5.16k
            pitch[SynSfd + 1] = pitch[SynSfd];
1187
5.16k
            pit_gain[SynSfd + 1] = pit_gain[SynSfd];
1188
5.16k
          }
1189
19.6k
        }
1190
1191
        /* Copy old data to the beginning of the buffer */
1192
24.1k
        {
1193
24.1k
          FDKmemcpy(
1194
24.1k
              pWorkBuffer1, pAacDecoderStaticChannelInfo->old_synth,
1195
24.1k
              ((PIT_MAX_MAX - (1 * L_SUBFR)) * fac_FB) * sizeof(FIXP_DBL));
1196
24.1k
        }
1197
1198
24.1k
        FIXP_DBL *p2_synth = pWorkBuffer1 + (PIT_MAX_MAX * fac_FB);
1199
1200
        /* recalculate pitch gain to allow postfilering on FAC area */
1201
223k
        for (int i = 0; i < SynSfd + 2; i++) {
1202
199k
          int T = pitch[i];
1203
199k
          FIXP_DBL gain = pit_gain[i];
1204
1205
199k
          if (gain > (FIXP_DBL)0) {
1206
100k
            gain = get_gain(&p2_synth[i * L_SUBFR * fac_FB],
1207
100k
                            &p2_synth[(i * L_SUBFR * fac_FB) - fac_FB * T],
1208
100k
                            L_SUBFR * fac_FB);
1209
100k
            pit_gain[i] = gain;
1210
100k
          }
1211
199k
        }
1212
1213
24.1k
        bass_pf_1sf_delay(p2_synth, pitch, pit_gain, frameLen,
1214
24.1k
                          (LpdSfd + 2) * L_SUBFR + BPF_SFD * L_SUBFR,
1215
24.1k
                          frameLen - (LpdSfd + 4) * L_SUBFR, outSamples,
1216
24.1k
                          aacOutDataHeadroom,
1217
24.1k
                          pAacDecoderStaticChannelInfo->mem_bpf);
1218
24.1k
      }
1219
1220
24.1k
    } else /* last_core_mode was not LPD */
1221
361k
    {
1222
361k
      FIXP_DBL *tmp =
1223
361k
          pAacDecoderChannelInfo->pComStaticData->pWorkBufferCore1->mdctOutTemp;
1224
361k
#if defined(FDK_ASSERT_ENABLE)
1225
361k
      nSamples =
1226
361k
#endif
1227
361k
          imlt_block(&pAacDecoderStaticChannelInfo->IMdct, tmp,
1228
361k
                     SPEC_LONG(pAacDecoderChannelInfo->pSpectralCoefficient),
1229
361k
                     pAacDecoderChannelInfo->specScale, nSpec, frameLen, tl,
1230
361k
                     FDKgetWindowSlope(
1231
361k
                         fl, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1232
361k
                     fl,
1233
361k
                     FDKgetWindowSlope(
1234
361k
                         fr, GetWindowShape(&pAacDecoderChannelInfo->icsInfo)),
1235
361k
                     fr, (FIXP_DBL)0,
1236
361k
                     pAacDecoderChannelInfo->currAliasingSymmetry
1237
361k
                         ? MLT_FLAG_CURR_ALIAS_SYMMETRY
1238
361k
                         : 0);
1239
1240
361k
      scaleValuesSaturate(outSamples, tmp, frameLen,
1241
361k
                          MDCT_OUT_HEADROOM - aacOutDataHeadroom);
1242
361k
    }
1243
386k
  }
1244
1245
386k
  FDK_ASSERT(nSamples == frameLen);
1246
1247
386k
  pAacDecoderStaticChannelInfo->last_core_mode =
1248
386k
      (pAacDecoderChannelInfo->icsInfo.WindowSequence == BLOCK_SHORT) ? FD_SHORT
1249
386k
                                                                      : FD_LONG;
1250
386k
  pAacDecoderStaticChannelInfo->last_lpd_mode = 255;
1251
386k
}
1252
1253
#include "ldfiltbank.h"
1254
void CBlock_FrequencyToTimeLowDelay(
1255
    CAacDecoderStaticChannelInfo *pAacDecoderStaticChannelInfo,
1256
    CAacDecoderChannelInfo *pAacDecoderChannelInfo, PCM_DEC outSamples[],
1257
234k
    const short frameLen) {
1258
234k
  InvMdctTransformLowDelay_fdk(
1259
234k
      SPEC_LONG(pAacDecoderChannelInfo->pSpectralCoefficient),
1260
234k
      pAacDecoderChannelInfo->specScale[0], outSamples,
1261
234k
      pAacDecoderStaticChannelInfo->pOverlapBuffer, frameLen);
1262
234k
}