Coverage Report

Created: 2025-11-24 06:13

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