Coverage Report

Created: 2026-01-13 06:51

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/aac/libAACdec/src/aacdecoder_lib.cpp
Line
Count
Source
1
/* -----------------------------------------------------------------------------
2
Software License for The Fraunhofer FDK AAC Codec Library for Android
3
4
© Copyright  1995 - 2023 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):   Manuel Jander
98
99
   Description:
100
101
*******************************************************************************/
102
103
#include "aacdecoder_lib.h"
104
105
#include "aac_ram.h"
106
#include "aacdecoder.h"
107
#include "tpdec_lib.h"
108
#include "FDK_core.h" /* FDK_tools version info */
109
110
#include "sbrdecoder.h"
111
112
#include "conceal.h"
113
114
#include "aacdec_drc.h"
115
116
#include "sac_dec_lib.h"
117
118
#include "pcm_utils.h"
119
120
/* Decoder library info */
121
#define AACDECODER_LIB_VL0 3
122
#define AACDECODER_LIB_VL1 2
123
#define AACDECODER_LIB_VL2 0
124
0
#define AACDECODER_LIB_TITLE "AAC Decoder Lib"
125
#ifdef SUPPRESS_BUILD_DATE_INFO
126
#define AACDECODER_LIB_BUILD_DATE ""
127
#define AACDECODER_LIB_BUILD_TIME ""
128
#else
129
0
#define AACDECODER_LIB_BUILD_DATE __DATE__
130
0
#define AACDECODER_LIB_BUILD_TIME __TIME__
131
#endif
132
133
static AAC_DECODER_ERROR setConcealMethod(const HANDLE_AACDECODER self,
134
                                          const INT method);
135
136
static void aacDecoder_setMetadataExpiry(const HANDLE_AACDECODER self,
137
464k
                                         const INT value) {
138
  /* check decoder handle */
139
464k
  if (self != NULL) {
140
464k
    INT mdExpFrame = 0; /* default: disable */
141
142
464k
    if ((value > 0) &&
143
0
        (self->streamInfo.aacSamplesPerFrame >
144
0
         0)) { /* Determine the corresponding number of frames: */
145
0
      FIXP_DBL frameTime = fDivNorm(self->streamInfo.aacSampleRate,
146
0
                                    self->streamInfo.aacSamplesPerFrame * 1000);
147
0
      mdExpFrame = fMultIceil(frameTime, value);
148
0
    }
149
150
    /* Configure DRC module */
151
464k
    aacDecoder_drcSetParam(self->hDrcInfo, DRC_DATA_EXPIRY_FRAME, mdExpFrame);
152
153
    /* Configure PCM downmix module */
154
464k
    pcmDmx_SetParam(self->hPcmUtils, DMX_BS_DATA_EXPIRY_FRAME, mdExpFrame);
155
464k
  }
156
464k
}
157
158
LINKSPEC_CPP AAC_DECODER_ERROR
159
0
aacDecoder_GetFreeBytes(const HANDLE_AACDECODER self, UINT *pFreeBytes) {
160
  /* reset free bytes */
161
0
  *pFreeBytes = 0;
162
163
  /* check handle */
164
0
  if (!self) return AAC_DEC_INVALID_HANDLE;
165
166
  /* return nr of free bytes */
167
0
  HANDLE_FDK_BITSTREAM hBs = transportDec_GetBitstream(self->hInput, 0);
168
0
  *pFreeBytes = FDKgetFreeBits(hBs) >> 3;
169
170
  /* success */
171
0
  return AAC_DEC_OK;
172
0
}
173
174
/**
175
 * Config Decoder using a CSAudioSpecificConfig struct.
176
 */
177
static LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_Config(
178
    HANDLE_AACDECODER self, const CSAudioSpecificConfig *pAscStruct,
179
475k
    UCHAR configMode, UCHAR *configChanged) {
180
475k
  AAC_DECODER_ERROR err;
181
182
  /* Initialize AAC core decoder, and update self->streaminfo */
183
475k
  err = CAacDecoder_Init(self, pAscStruct, configMode, configChanged);
184
185
475k
  if (!FDK_chMapDescr_isValid(&self->mapDescr)) {
186
0
    return AAC_DEC_UNSUPPORTED_CHANNELCONFIG;
187
0
  }
188
189
475k
  return err;
190
475k
}
191
192
LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_ConfigRaw(HANDLE_AACDECODER self,
193
                                                    UCHAR *conf[],
194
0
                                                    const UINT length[]) {
195
0
  AAC_DECODER_ERROR err = AAC_DEC_OK;
196
0
  TRANSPORTDEC_ERROR errTp;
197
0
  UINT layer, nrOfLayers = self->nrOfLayers;
198
199
0
  for (layer = 0; layer < nrOfLayers; layer++) {
200
0
    if (length[layer] > 0) {
201
0
      errTp = transportDec_OutOfBandConfig(self->hInput, conf[layer],
202
0
                                           length[layer], layer);
203
0
      if (errTp != TRANSPORTDEC_OK) {
204
0
        switch (errTp) {
205
0
          case TRANSPORTDEC_NEED_TO_RESTART:
206
0
            err = AAC_DEC_NEED_TO_RESTART;
207
0
            break;
208
0
          case TRANSPORTDEC_UNSUPPORTED_FORMAT:
209
0
            err = AAC_DEC_UNSUPPORTED_FORMAT;
210
0
            break;
211
0
          default:
212
0
            err = AAC_DEC_UNKNOWN;
213
0
            break;
214
0
        }
215
        /* if baselayer is OK we continue decoding */
216
0
        if (layer >= 1) {
217
0
          self->nrOfLayers = layer;
218
0
          err = AAC_DEC_OK;
219
0
        }
220
0
        break;
221
0
      }
222
0
    }
223
0
  }
224
225
0
  return err;
226
0
}
227
228
LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_RawISOBMFFData(HANDLE_AACDECODER self,
229
                                                         UCHAR *buffer,
230
0
                                                         UINT length) {
231
0
  FDK_BITSTREAM bs;
232
0
  HANDLE_FDK_BITSTREAM hBs = &bs;
233
0
  AAC_DECODER_ERROR err = AAC_DEC_OK;
234
235
0
  if (length < 8) return AAC_DEC_UNKNOWN;
236
237
0
  while (length >= 8) {
238
0
    UINT size =
239
0
        (buffer[0] << 24) | (buffer[1] << 16) | (buffer[2] << 8) | buffer[3];
240
0
    DRC_DEC_ERROR uniDrcErr = DRC_DEC_OK;
241
242
0
    if (length < size) return AAC_DEC_UNKNOWN;
243
0
    if (size <= 8) return AAC_DEC_UNKNOWN;
244
245
0
    FDKinitBitStream(hBs, buffer + 8, 0x10000000, (size - 8) * 8);
246
247
0
    if ((buffer[4] == 'l') && (buffer[5] == 'u') && (buffer[6] == 'd') &&
248
0
        (buffer[7] == 't')) {
249
0
      uniDrcErr = FDK_drcDec_ReadLoudnessBox(self->hUniDrcDecoder, hBs);
250
0
    } else if ((buffer[4] == 'd') && (buffer[5] == 'm') && (buffer[6] == 'i') &&
251
0
               (buffer[7] == 'x')) {
252
0
      uniDrcErr =
253
0
          FDK_drcDec_ReadDownmixInstructions_Box(self->hUniDrcDecoder, hBs);
254
0
    } else if ((buffer[4] == 'u') && (buffer[5] == 'd') && (buffer[6] == 'i') &&
255
0
               (buffer[7] == '2')) {
256
0
      uniDrcErr =
257
0
          FDK_drcDec_ReadUniDrcInstructions_Box(self->hUniDrcDecoder, hBs);
258
0
    } else if ((buffer[4] == 'u') && (buffer[5] == 'd') && (buffer[6] == 'c') &&
259
0
               (buffer[7] == '2')) {
260
0
      uniDrcErr =
261
0
          FDK_drcDec_ReadUniDrcCoefficients_Box(self->hUniDrcDecoder, hBs);
262
0
    }
263
264
0
    if (uniDrcErr != DRC_DEC_OK) err = AAC_DEC_UNKNOWN;
265
266
0
    buffer += size;
267
0
    length -= size;
268
0
  }
269
270
0
  return err;
271
0
}
272
273
static INT aacDecoder_ConfigCallback(void *handle,
274
                                     const CSAudioSpecificConfig *pAscStruct,
275
475k
                                     UCHAR configMode, UCHAR *configChanged) {
276
475k
  HANDLE_AACDECODER self = (HANDLE_AACDECODER)handle;
277
475k
  AAC_DECODER_ERROR err = AAC_DEC_OK;
278
475k
  TRANSPORTDEC_ERROR errTp;
279
280
475k
  FDK_ASSERT(self != NULL);
281
475k
  {
282
475k
    { err = aacDecoder_Config(self, pAscStruct, configMode, configChanged); }
283
475k
  }
284
475k
  if (err == AAC_DEC_OK) {
285
    /*
286
    revert concealment method if either
287
       - Interpolation concealment might not be meaningful
288
       - Interpolation concealment is not implemented
289
    */
290
464k
    if ((self->flags[0] & (AC_LD | AC_ELD) &&
291
131k
         (self->concealMethodUser == ConcealMethodNone) &&
292
131k
         CConcealment_GetDelay(&self->concealCommonData) >
293
131k
             0) /* might not be meaningful but allow if user has set it
294
                   expicitly */
295
459k
        || (self->flags[0] & (AC_USAC | AC_RSVD50 | AC_RSV603DA) &&
296
145k
            CConcealment_GetDelay(&self->concealCommonData) >
297
145k
                0) /* not implemented */
298
464k
    ) {
299
      /* Revert to error concealment method Noise Substitution.
300
         Because interpolation is not implemented for USAC or
301
         the additional delay is unwanted for low delay codecs. */
302
16.2k
      setConcealMethod(self, 1);
303
16.2k
    }
304
464k
    aacDecoder_setMetadataExpiry(self, self->metadataExpiry);
305
464k
    errTp = TRANSPORTDEC_OK;
306
464k
  } else {
307
10.3k
    if (err == AAC_DEC_NEED_TO_RESTART) {
308
0
      errTp = TRANSPORTDEC_NEED_TO_RESTART;
309
10.3k
    } else if (IS_INIT_ERROR(err)) {
310
10.3k
      errTp = TRANSPORTDEC_UNSUPPORTED_FORMAT;
311
10.3k
    } /* Fatal errors */
312
0
    else {
313
0
      errTp = TRANSPORTDEC_UNKOWN_ERROR;
314
0
    }
315
10.3k
  }
316
317
475k
  return errTp;
318
475k
}
319
320
static INT aacDecoder_FreeMemCallback(void *handle,
321
160k
                                      const CSAudioSpecificConfig *pAscStruct) {
322
160k
  TRANSPORTDEC_ERROR errTp = TRANSPORTDEC_OK;
323
160k
  HANDLE_AACDECODER self = (HANDLE_AACDECODER)handle;
324
325
160k
  const int subStreamIndex = 0;
326
327
160k
  FDK_ASSERT(self != NULL);
328
329
160k
  if (CAacDecoder_FreeMem(self, subStreamIndex) != AAC_DEC_OK) {
330
0
    errTp = TRANSPORTDEC_UNKOWN_ERROR;
331
0
  }
332
333
  /* free Ram_SbrDecoder and Ram_SbrDecChannel */
334
160k
  if (self->hSbrDecoder != NULL) {
335
160k
    if (sbrDecoder_FreeMem(&self->hSbrDecoder) != SBRDEC_OK) {
336
0
      errTp = TRANSPORTDEC_UNKOWN_ERROR;
337
0
    }
338
160k
  }
339
340
  /* free pSpatialDec and mpsData */
341
160k
  if (self->pMpegSurroundDecoder != NULL) {
342
160k
    if (mpegSurroundDecoder_FreeMem(
343
160k
            (CMpegSurroundDecoder *)self->pMpegSurroundDecoder) != MPS_OK) {
344
0
      errTp = TRANSPORTDEC_UNKOWN_ERROR;
345
0
    }
346
160k
  }
347
348
  /* free persistent qmf domain buffer, QmfWorkBufferCore3, QmfWorkBufferCore4,
349
   * QmfWorkBufferCore5 and configuration variables */
350
160k
  FDK_QmfDomain_FreeMem(&self->qmfDomain);
351
352
160k
  return errTp;
353
160k
}
354
355
static INT aacDecoder_CtrlCFGChangeCallback(
356
91
    void *handle, const CCtrlCFGChange *pCtrlCFGChangeStruct) {
357
91
  TRANSPORTDEC_ERROR errTp = TRANSPORTDEC_OK;
358
91
  HANDLE_AACDECODER self = (HANDLE_AACDECODER)handle;
359
360
91
  if (self != NULL) {
361
91
    CAacDecoder_CtrlCFGChange(
362
91
        self, pCtrlCFGChangeStruct->flushStatus, pCtrlCFGChangeStruct->flushCnt,
363
91
        pCtrlCFGChangeStruct->buildUpStatus, pCtrlCFGChangeStruct->buildUpCnt);
364
91
  } else {
365
0
    errTp = TRANSPORTDEC_UNKOWN_ERROR;
366
0
  }
367
368
91
  return errTp;
369
91
}
370
371
static INT aacDecoder_SbrCallback(
372
    void *handle, HANDLE_FDK_BITSTREAM hBs, const INT sampleRateIn,
373
    const INT sampleRateOut, const INT samplesPerFrame,
374
    const AUDIO_OBJECT_TYPE coreCodec, const MP4_ELEMENT_ID elementID,
375
    const INT elementIndex, const UCHAR harmonicSBR,
376
    const UCHAR stereoConfigIndex, const UCHAR configMode, UCHAR *configChanged,
377
582k
    const INT downscaleFactor) {
378
582k
  HANDLE_SBRDECODER self = (HANDLE_SBRDECODER)handle;
379
380
582k
  INT errTp = sbrDecoder_Header(self, hBs, sampleRateIn, sampleRateOut,
381
582k
                                samplesPerFrame, coreCodec, elementID,
382
582k
                                elementIndex, harmonicSBR, stereoConfigIndex,
383
582k
                                configMode, configChanged, downscaleFactor);
384
385
582k
  return errTp;
386
582k
}
387
388
static INT aacDecoder_SscCallback(
389
    void *handle, HANDLE_FDK_BITSTREAM hBs, const AUDIO_OBJECT_TYPE coreCodec,
390
    const INT samplingRate, const INT frameSize, const INT numChannels,
391
    const INT stereoConfigIndex, const INT coreSbrFrameLengthIndex,
392
180k
    const INT configBytes, const UCHAR configMode, UCHAR *configChanged) {
393
180k
  SACDEC_ERROR err;
394
180k
  TRANSPORTDEC_ERROR errTp;
395
180k
  HANDLE_AACDECODER hAacDecoder = (HANDLE_AACDECODER)handle;
396
397
180k
  err = mpegSurroundDecoder_Config(
398
180k
      (CMpegSurroundDecoder *)hAacDecoder->pMpegSurroundDecoder, hBs, coreCodec,
399
180k
      samplingRate, frameSize, numChannels, stereoConfigIndex,
400
180k
      coreSbrFrameLengthIndex, configBytes, configMode, configChanged);
401
402
180k
  switch (err) {
403
38.6k
    case MPS_UNSUPPORTED_CONFIG:
404
      /* MPS found but invalid or not decodable by this instance            */
405
      /* We switch off MPS and keep going                                   */
406
38.6k
      hAacDecoder->mpsEnableCurr = 0;
407
38.6k
      hAacDecoder->mpsApplicable = 0;
408
38.6k
      errTp = TRANSPORTDEC_OK;
409
38.6k
      break;
410
21.8k
    case MPS_PARSE_ERROR:
411
      /* MPS found but invalid or not decodable by this instance            */
412
21.8k
      hAacDecoder->mpsEnableCurr = 0;
413
21.8k
      hAacDecoder->mpsApplicable = 0;
414
21.8k
      if ((coreCodec == AOT_USAC) || (coreCodec == AOT_DRM_USAC) ||
415
21.8k
          IS_LOWDELAY(coreCodec)) {
416
21.8k
        errTp = TRANSPORTDEC_PARSE_ERROR;
417
21.8k
      } else {
418
0
        errTp = TRANSPORTDEC_OK;
419
0
      }
420
21.8k
      break;
421
119k
    case MPS_OK:
422
119k
      hAacDecoder->mpsApplicable = 1;
423
119k
      errTp = TRANSPORTDEC_OK;
424
119k
      break;
425
891
    default:
426
      /* especially Parsing error is critical for transport layer          */
427
891
      hAacDecoder->mpsApplicable = 0;
428
891
      errTp = TRANSPORTDEC_UNKOWN_ERROR;
429
180k
  }
430
431
180k
  return (INT)errTp;
432
180k
}
433
434
static INT aacDecoder_UniDrcCallback(void *handle, HANDLE_FDK_BITSTREAM hBs,
435
                                     const INT fullPayloadLength,
436
                                     const INT payloadType,
437
                                     const INT subStreamIndex,
438
                                     const INT payloadStart,
439
568k
                                     const AUDIO_OBJECT_TYPE aot) {
440
568k
  DRC_DEC_ERROR err = DRC_DEC_OK;
441
568k
  TRANSPORTDEC_ERROR errTp;
442
568k
  HANDLE_AACDECODER hAacDecoder = (HANDLE_AACDECODER)handle;
443
568k
  DRC_DEC_CODEC_MODE drcDecCodecMode = DRC_DEC_CODEC_MODE_UNDEFINED;
444
568k
  UCHAR dummyBuffer[4] = {0};
445
568k
  FDK_BITSTREAM dummyBs;
446
568k
  HANDLE_FDK_BITSTREAM hReadBs;
447
448
568k
  if (subStreamIndex != 0) {
449
0
    return TRANSPORTDEC_OK;
450
0
  }
451
452
568k
  if (hBs == NULL) {
453
    /* use dummy zero payload to clear memory */
454
367k
    hReadBs = &dummyBs;
455
367k
    FDKinitBitStream(hReadBs, dummyBuffer, 4, 24);
456
367k
  } else {
457
201k
    hReadBs = hBs;
458
201k
  }
459
460
568k
  if (aot == AOT_USAC) {
461
568k
    drcDecCodecMode = DRC_DEC_MPEG_D_USAC;
462
568k
  }
463
464
568k
  err = FDK_drcDec_SetCodecMode(hAacDecoder->hUniDrcDecoder, drcDecCodecMode);
465
568k
  if (err) return (INT)TRANSPORTDEC_UNKOWN_ERROR;
466
467
568k
  if (payloadType == 0) /* uniDrcConfig */
468
356k
  {
469
356k
    err = FDK_drcDec_ReadUniDrcConfig(hAacDecoder->hUniDrcDecoder, hReadBs);
470
356k
  } else /* loudnessInfoSet */
471
211k
  {
472
211k
    err = FDK_drcDec_ReadLoudnessInfoSet(hAacDecoder->hUniDrcDecoder, hReadBs);
473
211k
    hAacDecoder->loudnessInfoSetPosition[1] = payloadStart;
474
211k
    hAacDecoder->loudnessInfoSetPosition[2] = fullPayloadLength;
475
211k
  }
476
477
568k
  if (err == DRC_DEC_OK)
478
568k
    errTp = TRANSPORTDEC_OK;
479
0
  else
480
0
    errTp = TRANSPORTDEC_UNKOWN_ERROR;
481
482
568k
  return (INT)errTp;
483
568k
}
484
485
LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_AncDataInit(HANDLE_AACDECODER self,
486
0
                                                      UCHAR *buffer, int size) {
487
0
  CAncData *ancData = &self->ancData;
488
489
0
  return CAacDecoder_AncDataInit(ancData, buffer, size);
490
0
}
491
492
LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_AncDataGet(HANDLE_AACDECODER self,
493
                                                     int index, UCHAR **ptr,
494
0
                                                     int *size) {
495
0
  CAncData *ancData = &self->ancData;
496
497
0
  return CAacDecoder_AncDataGet(ancData, index, ptr, size);
498
0
}
499
500
/* If MPS is present in stream, but not supported by this instance, we'll
501
   have to switch off MPS and use QMF synthesis in the SBR module if required */
502
static int isSupportedMpsConfig(AUDIO_OBJECT_TYPE aot,
503
                                unsigned int numInChannels,
504
0
                                unsigned int fMpsPresent) {
505
0
  LIB_INFO libInfo[FDK_MODULE_LAST];
506
0
  UINT mpsCaps;
507
0
  int isSupportedCfg = 1;
508
509
0
  FDKinitLibInfo(libInfo);
510
511
0
  mpegSurroundDecoder_GetLibInfo(libInfo);
512
513
0
  mpsCaps = FDKlibInfo_getCapabilities(libInfo, FDK_MPSDEC);
514
515
0
  if (!(mpsCaps & CAPF_MPS_LD) && IS_LOWDELAY(aot)) {
516
    /* We got an LD AOT but MPS decoder does not support LD. */
517
0
    isSupportedCfg = 0;
518
0
  }
519
0
  if ((mpsCaps & CAPF_MPS_LD) && IS_LOWDELAY(aot) && !fMpsPresent) {
520
    /* We got an LD AOT and the MPS decoder supports it.
521
     * But LD-MPS is not explicitly signaled. */
522
0
    isSupportedCfg = 0;
523
0
  }
524
0
  if (!(mpsCaps & CAPF_MPS_USAC) && IS_USAC(aot)) {
525
    /* We got an USAC AOT but MPS decoder does not support USAC. */
526
0
    isSupportedCfg = 0;
527
0
  }
528
0
  if (!(mpsCaps & CAPF_MPS_STD) && !IS_LOWDELAY(aot) && !IS_USAC(aot)) {
529
    /* We got an GA AOT but MPS decoder does not support it. */
530
0
    isSupportedCfg = 0;
531
0
  }
532
  /* Check whether the MPS modul supports the given number of input channels: */
533
0
  switch (numInChannels) {
534
0
    case 1:
535
0
      if (!(mpsCaps & CAPF_MPS_1CH_IN)) {
536
        /* We got a one channel input to MPS decoder but it does not support it.
537
         */
538
0
        isSupportedCfg = 0;
539
0
      }
540
0
      break;
541
0
    case 2:
542
0
      if (!(mpsCaps & CAPF_MPS_2CH_IN)) {
543
        /* We got a two channel input to MPS decoder but it does not support it.
544
         */
545
0
        isSupportedCfg = 0;
546
0
      }
547
0
      break;
548
0
    case 5:
549
0
    case 6:
550
0
      if (!(mpsCaps & CAPF_MPS_6CH_IN)) {
551
        /* We got a six channel input to MPS decoder but it does not support it.
552
         */
553
0
        isSupportedCfg = 0;
554
0
      }
555
0
      break;
556
0
    default:
557
0
      isSupportedCfg = 0;
558
0
  }
559
560
0
  return (isSupportedCfg);
561
0
}
562
563
static AAC_DECODER_ERROR setConcealMethod(
564
    const HANDLE_AACDECODER self, /*!< Handle of the decoder instance */
565
40.3k
    const INT method) {
566
40.3k
  AAC_DECODER_ERROR errorStatus = AAC_DEC_OK;
567
40.3k
  CConcealParams *pConcealData = NULL;
568
40.3k
  int method_revert = 0;
569
40.3k
  HANDLE_SBRDECODER hSbrDec = NULL;
570
40.3k
  HANDLE_AAC_DRC hDrcInfo = NULL;
571
40.3k
  HANDLE_PCM_DOWNMIX hPcmDmx = NULL;
572
40.3k
  CConcealmentMethod backupMethod = ConcealMethodNone;
573
40.3k
  int backupDelay = 0;
574
40.3k
  int bsDelay = 0;
575
576
  /* check decoder handle */
577
40.3k
  if (self != NULL) {
578
40.3k
    pConcealData = &self->concealCommonData;
579
40.3k
    hSbrDec = self->hSbrDecoder;
580
40.3k
    hDrcInfo = self->hDrcInfo;
581
40.3k
    hPcmDmx = self->hPcmUtils;
582
40.3k
    if (self->flags[0] & (AC_USAC | AC_RSVD50 | AC_RSV603DA) && method >= 2) {
583
      /* Interpolation concealment is not implemented for USAC/RSVD50 */
584
      /* errorStatus = AAC_DEC_SET_PARAM_FAIL;
585
         goto bail; */
586
0
      method_revert = 1;
587
0
    }
588
40.3k
    if (self->flags[0] & (AC_USAC | AC_RSVD50 | AC_RSV603DA) && method >= 2) {
589
      /* Interpolation concealment is not implemented for USAC/RSVD50 */
590
0
      errorStatus = AAC_DEC_SET_PARAM_FAIL;
591
0
      goto bail;
592
0
    }
593
40.3k
  }
594
595
  /* Get current method/delay */
596
40.3k
  backupMethod = CConcealment_GetMethod(pConcealData);
597
40.3k
  backupDelay = CConcealment_GetDelay(pConcealData);
598
599
  /* Be sure to set AAC and SBR concealment method simultaneously! */
600
40.3k
  errorStatus = CConcealment_SetParams(
601
40.3k
      pConcealData,
602
40.3k
      (method_revert == 0) ? (int)method : (int)1,  // concealMethod
603
40.3k
      AACDEC_CONCEAL_PARAM_NOT_SPECIFIED,           // concealFadeOutSlope
604
40.3k
      AACDEC_CONCEAL_PARAM_NOT_SPECIFIED,           // concealFadeInSlope
605
40.3k
      AACDEC_CONCEAL_PARAM_NOT_SPECIFIED,           // concealMuteRelease
606
40.3k
      AACDEC_CONCEAL_PARAM_NOT_SPECIFIED            // concealComfNoiseLevel
607
40.3k
  );
608
40.3k
  if ((errorStatus != AAC_DEC_OK) && (errorStatus != AAC_DEC_INVALID_HANDLE)) {
609
0
    goto bail;
610
0
  }
611
612
  /* Get new delay */
613
40.3k
  bsDelay = CConcealment_GetDelay(pConcealData);
614
615
40.3k
  {
616
40.3k
    SBR_ERROR sbrErr = SBRDEC_OK;
617
618
    /* set SBR bitstream delay */
619
40.3k
    sbrErr = sbrDecoder_SetParam(hSbrDec, SBR_SYSTEM_BITSTREAM_DELAY, bsDelay);
620
621
40.3k
    switch (sbrErr) {
622
40.3k
      case SBRDEC_OK:
623
40.3k
      case SBRDEC_NOT_INITIALIZED:
624
40.3k
        if (self != NULL) {
625
          /* save the param value and set later
626
             (when SBR has been initialized) */
627
40.3k
          self->sbrParams.bsDelay = bsDelay;
628
40.3k
        }
629
40.3k
        break;
630
0
      default:
631
0
        errorStatus = AAC_DEC_SET_PARAM_FAIL;
632
0
        goto bail;
633
40.3k
    }
634
40.3k
  }
635
636
40.3k
  errorStatus = aacDecoder_drcSetParam(hDrcInfo, DRC_BS_DELAY, bsDelay);
637
40.3k
  if ((errorStatus != AAC_DEC_OK) && (errorStatus != AAC_DEC_INVALID_HANDLE)) {
638
0
    goto bail;
639
0
  }
640
641
40.3k
  if (errorStatus == AAC_DEC_OK) {
642
40.3k
    PCMDMX_ERROR err = pcmDmx_SetParam(hPcmDmx, DMX_BS_DATA_DELAY, bsDelay);
643
40.3k
    switch (err) {
644
0
      case PCMDMX_INVALID_HANDLE:
645
0
        errorStatus = AAC_DEC_INVALID_HANDLE;
646
0
        break;
647
40.3k
      case PCMDMX_OK:
648
40.3k
        break;
649
0
      default:
650
0
        errorStatus = AAC_DEC_SET_PARAM_FAIL;
651
0
        goto bail;
652
40.3k
    }
653
40.3k
  }
654
655
40.3k
bail:
656
40.3k
  if ((errorStatus != AAC_DEC_OK) && (errorStatus != AAC_DEC_INVALID_HANDLE)) {
657
    /* Revert to the initial state */
658
0
    CConcealment_SetParams(
659
0
        pConcealData, (int)backupMethod, AACDEC_CONCEAL_PARAM_NOT_SPECIFIED,
660
0
        AACDEC_CONCEAL_PARAM_NOT_SPECIFIED, AACDEC_CONCEAL_PARAM_NOT_SPECIFIED,
661
0
        AACDEC_CONCEAL_PARAM_NOT_SPECIFIED);
662
    /* Revert SBR bitstream delay */
663
0
    sbrDecoder_SetParam(hSbrDec, SBR_SYSTEM_BITSTREAM_DELAY, backupDelay);
664
    /* Revert DRC bitstream delay */
665
0
    aacDecoder_drcSetParam(hDrcInfo, DRC_BS_DELAY, backupDelay);
666
    /* Revert PCM mixdown bitstream delay */
667
0
    pcmDmx_SetParam(hPcmDmx, DMX_BS_DATA_DELAY, backupDelay);
668
0
  }
669
670
40.3k
  return errorStatus;
671
40.3k
}
672
673
LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_SetParam(
674
    const HANDLE_AACDECODER self, /*!< Handle of the decoder instance */
675
    const AACDEC_PARAM param,     /*!< Parameter to set               */
676
    const INT value)              /*!< Parameter valued               */
677
0
{
678
0
  AAC_DECODER_ERROR errorStatus = AAC_DEC_OK;
679
0
  HANDLE_TRANSPORTDEC hTpDec = NULL;
680
0
  TRANSPORTDEC_ERROR errTp = TRANSPORTDEC_OK;
681
0
  HANDLE_AAC_DRC hDrcInfo = NULL;
682
0
  HANDLE_PCM_DOWNMIX hPcmDmx = NULL;
683
0
  PCMDMX_ERROR dmxErr = PCMDMX_OK;
684
0
  TDLimiterPtr hPcmTdl = NULL;
685
0
  DRC_DEC_ERROR uniDrcErr = DRC_DEC_OK;
686
687
  /* check decoder handle */
688
0
  if (self != NULL) {
689
0
    hTpDec = self->hInput;
690
0
    hDrcInfo = self->hDrcInfo;
691
0
    hPcmDmx = self->hPcmUtils;
692
0
    hPcmTdl = self->hLimiter;
693
0
  } else {
694
0
    errorStatus = AAC_DEC_INVALID_HANDLE;
695
0
    goto bail;
696
0
  }
697
698
  /* configure the subsystems */
699
0
  switch (param) {
700
0
    case AAC_PCM_MIN_OUTPUT_CHANNELS:
701
0
      if (value < -1 || value > (8)) {
702
0
        return AAC_DEC_SET_PARAM_FAIL;
703
0
      }
704
0
      dmxErr = pcmDmx_SetParam(hPcmDmx, MIN_NUMBER_OF_OUTPUT_CHANNELS, value);
705
0
      break;
706
707
0
    case AAC_PCM_MAX_OUTPUT_CHANNELS:
708
0
      if (value < -1 || value > (8)) {
709
0
        return AAC_DEC_SET_PARAM_FAIL;
710
0
      }
711
0
      dmxErr = pcmDmx_SetParam(hPcmDmx, MAX_NUMBER_OF_OUTPUT_CHANNELS, value);
712
713
0
      if (dmxErr != PCMDMX_OK) {
714
0
        goto bail;
715
0
      }
716
0
      errorStatus =
717
0
          aacDecoder_drcSetParam(hDrcInfo, MAX_OUTPUT_CHANNELS, value);
718
0
      if (value > 0) {
719
0
        uniDrcErr = FDK_drcDec_SetParam(self->hUniDrcDecoder,
720
0
                                        DRC_DEC_TARGET_CHANNEL_COUNT_REQUESTED,
721
0
                                        (FIXP_DBL)value);
722
0
      }
723
0
      break;
724
725
0
    case AAC_PCM_DUAL_CHANNEL_OUTPUT_MODE:
726
0
      dmxErr = pcmDmx_SetParam(hPcmDmx, DMX_DUAL_CHANNEL_MODE, value);
727
0
      break;
728
729
0
    case AAC_PCM_LIMITER_ENABLE:
730
0
      if (value < -2 || value > 1) {
731
0
        return AAC_DEC_SET_PARAM_FAIL;
732
0
      }
733
0
      self->limiterEnableUser = value;
734
0
      break;
735
736
0
    case AAC_PCM_LIMITER_ATTACK_TIME:
737
0
      if (value <= 0) { /* module function converts value to unsigned */
738
0
        return AAC_DEC_SET_PARAM_FAIL;
739
0
      }
740
0
      switch (pcmLimiter_SetAttack(hPcmTdl, value)) {
741
0
        case TDLIMIT_OK:
742
0
          break;
743
0
        case TDLIMIT_INVALID_HANDLE:
744
0
          return AAC_DEC_INVALID_HANDLE;
745
0
        case TDLIMIT_INVALID_PARAMETER:
746
0
        default:
747
0
          return AAC_DEC_SET_PARAM_FAIL;
748
0
      }
749
0
      break;
750
751
0
    case AAC_PCM_LIMITER_RELEAS_TIME:
752
0
      if (value <= 0) { /* module function converts value to unsigned */
753
0
        return AAC_DEC_SET_PARAM_FAIL;
754
0
      }
755
0
      switch (pcmLimiter_SetRelease(hPcmTdl, value)) {
756
0
        case TDLIMIT_OK:
757
0
          break;
758
0
        case TDLIMIT_INVALID_HANDLE:
759
0
          return AAC_DEC_INVALID_HANDLE;
760
0
        case TDLIMIT_INVALID_PARAMETER:
761
0
        default:
762
0
          return AAC_DEC_SET_PARAM_FAIL;
763
0
      }
764
0
      break;
765
766
0
    case AAC_METADATA_PROFILE: {
767
0
      DMX_PROFILE_TYPE dmxProfile;
768
0
      INT mdExpiry = -1; /* in ms (-1: don't change) */
769
770
0
      switch ((AAC_MD_PROFILE)value) {
771
0
        case AAC_MD_PROFILE_MPEG_STANDARD:
772
0
          dmxProfile = DMX_PRFL_STANDARD;
773
0
          break;
774
0
        case AAC_MD_PROFILE_MPEG_LEGACY:
775
0
          dmxProfile = DMX_PRFL_MATRIX_MIX;
776
0
          break;
777
0
        case AAC_MD_PROFILE_MPEG_LEGACY_PRIO:
778
0
          dmxProfile = DMX_PRFL_FORCE_MATRIX_MIX;
779
0
          break;
780
0
        case AAC_MD_PROFILE_ARIB_JAPAN:
781
0
          dmxProfile = DMX_PRFL_ARIB_JAPAN;
782
0
          mdExpiry = 550; /* ms */
783
0
          break;
784
0
        default:
785
0
          return AAC_DEC_SET_PARAM_FAIL;
786
0
      }
787
0
      dmxErr = pcmDmx_SetParam(hPcmDmx, DMX_PROFILE_SETTING, (INT)dmxProfile);
788
0
      if (dmxErr != PCMDMX_OK) {
789
0
        goto bail;
790
0
      }
791
0
      if ((self != NULL) && (mdExpiry >= 0)) {
792
0
        self->metadataExpiry = mdExpiry;
793
        /* Determine the corresponding number of frames and configure all
794
         * related modules. */
795
0
        aacDecoder_setMetadataExpiry(self, mdExpiry);
796
0
      }
797
0
    } break;
798
799
0
    case AAC_METADATA_EXPIRY_TIME:
800
0
      if (value < 0) {
801
0
        return AAC_DEC_SET_PARAM_FAIL;
802
0
      }
803
0
      if (self != NULL) {
804
0
        self->metadataExpiry = value;
805
        /* Determine the corresponding number of frames and configure all
806
         * related modules. */
807
0
        aacDecoder_setMetadataExpiry(self, value);
808
0
      }
809
0
      break;
810
811
0
    case AAC_PCM_OUTPUT_CHANNEL_MAPPING:
812
0
      if (value < 0 || value > 1) {
813
0
        return AAC_DEC_SET_PARAM_FAIL;
814
0
      }
815
      /* CAUTION: The given value must be inverted to match the logic! */
816
0
      FDK_chMapDescr_setPassThrough(&self->mapDescr, !value);
817
0
      break;
818
819
0
    case AAC_QMF_LOWPOWER:
820
0
      if (value < -1 || value > 1) {
821
0
        return AAC_DEC_SET_PARAM_FAIL;
822
0
      }
823
824
      /**
825
       * Set QMF mode (might be overriden)
826
       *  0:HQ (complex)
827
       *  1:LP (partially complex)
828
       */
829
0
      self->qmfModeUser = (QMF_MODE)value;
830
0
      break;
831
832
0
    case AAC_DRC_ATTENUATION_FACTOR:
833
      /* DRC compression factor (where 0 is no and 127 is max compression) */
834
0
      if ((value < 0) || (value > 127)) {
835
0
        return AAC_DEC_SET_PARAM_FAIL;
836
0
      }
837
0
      errorStatus = aacDecoder_drcSetParam(hDrcInfo, DRC_CUT_SCALE, value);
838
0
      uniDrcErr = FDK_drcDec_SetParam(self->hUniDrcDecoder, DRC_DEC_COMPRESS,
839
0
                                      value * (FL2FXCONST_DBL(0.5f / 127.0f)));
840
0
      break;
841
842
0
    case AAC_DRC_BOOST_FACTOR:
843
      /* DRC boost factor (where 0 is no and 127 is max boost) */
844
0
      if ((value < 0) || (value > 127)) {
845
0
        return AAC_DEC_SET_PARAM_FAIL;
846
0
      }
847
0
      errorStatus = aacDecoder_drcSetParam(hDrcInfo, DRC_BOOST_SCALE, value);
848
0
      uniDrcErr = FDK_drcDec_SetParam(self->hUniDrcDecoder, DRC_DEC_BOOST,
849
0
                                      value * (FL2FXCONST_DBL(0.5f / 127.0f)));
850
0
      break;
851
852
0
    case AAC_DRC_REFERENCE_LEVEL:
853
0
      if ((value >= 0) &&
854
0
          ((value < 40) || (value > 127))) /* allowed range: -10 to -31.75 dB */
855
0
        return AAC_DEC_SET_PARAM_FAIL;
856
      /* DRC target reference level quantized in 0.25dB steps using values
857
         [40..127]. Negative values switch off loudness normalisation. Negative
858
         values also switch off MPEG-4 DRC, while MPEG-D DRC can be separately
859
         switched on/off with AAC_UNIDRC_SET_EFFECT */
860
0
      errorStatus = aacDecoder_drcSetParam(hDrcInfo, TARGET_REF_LEVEL, value);
861
0
      uniDrcErr = FDK_drcDec_SetParam(self->hUniDrcDecoder,
862
0
                                      DRC_DEC_LOUDNESS_NORMALIZATION_ON,
863
0
                                      (FIXP_DBL)(value >= 0));
864
      /* set target loudness also for MPEG-D DRC */
865
0
      self->defaultTargetLoudness = (SCHAR)value;
866
0
      break;
867
868
0
    case AAC_DRC_HEAVY_COMPRESSION:
869
      /* Don't need to overwrite cut/boost values */
870
0
      errorStatus =
871
0
          aacDecoder_drcSetParam(hDrcInfo, APPLY_HEAVY_COMPRESSION, value);
872
0
      break;
873
874
0
    case AAC_DRC_DEFAULT_PRESENTATION_MODE:
875
      /* DRC default presentation mode */
876
0
      errorStatus =
877
0
          aacDecoder_drcSetParam(hDrcInfo, DEFAULT_PRESENTATION_MODE, value);
878
0
      break;
879
880
0
    case AAC_DRC_ENC_TARGET_LEVEL:
881
      /* Encoder target level for light (i.e. not heavy) compression:
882
         Target reference level assumed at encoder for deriving limiting gains
883
       */
884
0
      errorStatus =
885
0
          aacDecoder_drcSetParam(hDrcInfo, ENCODER_TARGET_LEVEL, value);
886
0
      break;
887
888
0
    case AAC_UNIDRC_SET_EFFECT:
889
0
      if ((value < -1) || (value > 6)) return AAC_DEC_SET_PARAM_FAIL;
890
0
      uniDrcErr = FDK_drcDec_SetParam(self->hUniDrcDecoder, DRC_DEC_EFFECT_TYPE,
891
0
                                      (FIXP_DBL)value);
892
0
      break;
893
0
    case AAC_UNIDRC_ALBUM_MODE:
894
0
      uniDrcErr = FDK_drcDec_SetParam(self->hUniDrcDecoder, DRC_DEC_ALBUM_MODE,
895
0
                                      (FIXP_DBL)value);
896
0
      break;
897
898
0
    case AAC_TPDEC_CLEAR_BUFFER:
899
0
      errTp = transportDec_SetParam(hTpDec, TPDEC_PARAM_RESET, 1);
900
0
      self->streamInfo.numLostAccessUnits = 0;
901
0
      self->streamInfo.numBadBytes = 0;
902
0
      self->streamInfo.numTotalBytes = 0;
903
      /* aacDecoder_SignalInterruption(self); */
904
0
      break;
905
0
    case AAC_CONCEAL_METHOD:
906
      /* Changing the concealment method can introduce additional bitstream
907
         delay. And that in turn affects sub libraries and modules which makes
908
         the whole thing quite complex.  So the complete changing routine is
909
         packed into a helper function which keeps all modules and libs in a
910
         consistent state even in the case an error occures. */
911
0
      errorStatus = setConcealMethod(self, value);
912
0
      if (errorStatus == AAC_DEC_OK) {
913
0
        self->concealMethodUser = (CConcealmentMethod)value;
914
0
      }
915
0
      break;
916
917
0
    default:
918
0
      return AAC_DEC_SET_PARAM_FAIL;
919
0
  } /* switch(param) */
920
921
0
bail:
922
923
0
  if (errorStatus == AAC_DEC_OK) {
924
    /* Check error code returned by DMX module library: */
925
0
    switch (dmxErr) {
926
0
      case PCMDMX_OK:
927
0
        break;
928
0
      case PCMDMX_INVALID_HANDLE:
929
0
        errorStatus = AAC_DEC_INVALID_HANDLE;
930
0
        break;
931
0
      default:
932
0
        errorStatus = AAC_DEC_SET_PARAM_FAIL;
933
0
    }
934
0
  }
935
936
0
  if (errTp != TRANSPORTDEC_OK && errorStatus == AAC_DEC_OK) {
937
0
    errorStatus = AAC_DEC_SET_PARAM_FAIL;
938
0
  }
939
940
0
  if (errorStatus == AAC_DEC_OK) {
941
    /* Check error code returned by MPEG-D DRC decoder library: */
942
0
    switch (uniDrcErr) {
943
0
      case 0:
944
0
        break;
945
0
      case -9998:
946
0
        errorStatus = AAC_DEC_INVALID_HANDLE;
947
0
        break;
948
0
      default:
949
0
        errorStatus = AAC_DEC_SET_PARAM_FAIL;
950
0
        break;
951
0
    }
952
0
  }
953
954
0
  return (errorStatus);
955
0
}
956
LINKSPEC_CPP HANDLE_AACDECODER aacDecoder_Open(TRANSPORT_TYPE transportFmt,
957
24.0k
                                               UINT nrOfLayers) {
958
24.0k
  AAC_DECODER_INSTANCE *aacDec = NULL;
959
24.0k
  HANDLE_TRANSPORTDEC pIn;
960
24.0k
  int err = 0;
961
24.0k
  int stereoConfigIndex = -1;
962
963
24.0k
  UINT nrOfLayers_min = fMin(nrOfLayers, (UINT)1);
964
965
  /* Allocate transport layer struct. */
966
24.0k
  pIn = transportDec_Open(transportFmt, TP_FLAG_MPEG4, nrOfLayers_min);
967
24.0k
  if (pIn == NULL) {
968
0
    return NULL;
969
0
  }
970
971
  /* Allocate AAC decoder core struct. */
972
24.0k
  aacDec = CAacDecoder_Open(transportFmt);
973
974
24.0k
  if (aacDec == NULL) {
975
0
    transportDec_Close(&pIn);
976
0
    goto bail;
977
0
  }
978
24.0k
  aacDec->hInput = pIn;
979
980
24.0k
  aacDec->nrOfLayers = nrOfLayers_min;
981
982
  /* Setup channel mapping descriptor. */
983
24.0k
  FDK_chMapDescr_init(&aacDec->mapDescr, NULL, 0, 0);
984
985
  /* Register Config Update callback. */
986
24.0k
  transportDec_RegisterAscCallback(pIn, aacDecoder_ConfigCallback,
987
24.0k
                                   (void *)aacDec);
988
989
  /* Register Free Memory callback. */
990
24.0k
  transportDec_RegisterFreeMemCallback(pIn, aacDecoder_FreeMemCallback,
991
24.0k
                                       (void *)aacDec);
992
993
  /* Register config switch control callback. */
994
24.0k
  transportDec_RegisterCtrlCFGChangeCallback(
995
24.0k
      pIn, aacDecoder_CtrlCFGChangeCallback, (void *)aacDec);
996
997
24.0k
  FDKmemclear(&aacDec->qmfDomain, sizeof(FDK_QMF_DOMAIN));
998
  /* open SBR decoder */
999
24.0k
  if (SBRDEC_OK != sbrDecoder_Open(&aacDec->hSbrDecoder, &aacDec->qmfDomain)) {
1000
0
    err = -1;
1001
0
    goto bail;
1002
0
  }
1003
24.0k
  aacDec->qmfModeUser = NOT_DEFINED;
1004
24.0k
  transportDec_RegisterSbrCallback(aacDec->hInput, aacDecoder_SbrCallback,
1005
24.0k
                                   (void *)aacDec->hSbrDecoder);
1006
1007
24.0k
  if (mpegSurroundDecoder_Open(
1008
24.0k
          (CMpegSurroundDecoder **)&aacDec->pMpegSurroundDecoder,
1009
24.0k
          stereoConfigIndex, &aacDec->qmfDomain)) {
1010
0
    err = -1;
1011
0
    goto bail;
1012
0
  }
1013
  /* Set MPEG Surround defaults */
1014
24.0k
  aacDec->mpsEnableUser = 0;
1015
24.0k
  aacDec->mpsEnableCurr = 0;
1016
24.0k
  aacDec->mpsApplicable = 0;
1017
24.0k
  aacDec->mpsOutputMode = (SCHAR)SACDEC_OUT_MODE_NORMAL;
1018
24.0k
  transportDec_RegisterSscCallback(pIn, aacDecoder_SscCallback, (void *)aacDec);
1019
1020
24.0k
  {
1021
24.0k
    if (FDK_drcDec_Open(&(aacDec->hUniDrcDecoder), DRC_DEC_ALL) != 0) {
1022
0
      err = -1;
1023
0
      goto bail;
1024
0
    }
1025
24.0k
  }
1026
1027
24.0k
  transportDec_RegisterUniDrcConfigCallback(pIn, aacDecoder_UniDrcCallback,
1028
24.0k
                                            (void *)aacDec,
1029
24.0k
                                            aacDec->loudnessInfoSetPosition);
1030
24.0k
  aacDec->defaultTargetLoudness = (SCHAR)96;
1031
1032
24.0k
  pcmDmx_Open(&aacDec->hPcmUtils);
1033
24.0k
  if (aacDec->hPcmUtils == NULL) {
1034
0
    err = -1;
1035
0
    goto bail;
1036
0
  }
1037
1038
24.0k
  aacDec->hLimiter =
1039
24.0k
      pcmLimiter_Create(TDL_ATTACK_DEFAULT_MS, TDL_RELEASE_DEFAULT_MS,
1040
24.0k
                        (FIXP_DBL)MAXVAL_DBL, (8), 96000);
1041
24.0k
  if (NULL == aacDec->hLimiter) {
1042
0
    err = -1;
1043
0
    goto bail;
1044
0
  }
1045
24.0k
  aacDec->limiterEnableUser = (UCHAR)-1;
1046
24.0k
  aacDec->limiterEnableCurr = 0;
1047
1048
  /* Assure that all modules have same delay */
1049
24.0k
  if (setConcealMethod(aacDec,
1050
24.0k
                       CConcealment_GetMethod(&aacDec->concealCommonData))) {
1051
0
    err = -1;
1052
0
    goto bail;
1053
0
  }
1054
1055
24.0k
bail:
1056
24.0k
  if (err == -1) {
1057
0
    aacDecoder_Close(aacDec);
1058
0
    aacDec = NULL;
1059
0
  }
1060
24.0k
  return aacDec;
1061
24.0k
}
1062
1063
LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_Fill(HANDLE_AACDECODER self,
1064
                                               UCHAR *pBuffer[],
1065
                                               const UINT bufferSize[],
1066
25.2k
                                               UINT *pBytesValid) {
1067
25.2k
  TRANSPORTDEC_ERROR tpErr;
1068
  /* loop counter for layers; if not TT_MP4_RAWPACKETS used as index for only
1069
     available layer */
1070
25.2k
  INT layer = 0;
1071
25.2k
  INT nrOfLayers = self->nrOfLayers;
1072
1073
25.2k
  {
1074
50.5k
    for (layer = 0; layer < nrOfLayers; layer++) {
1075
25.2k
      {
1076
25.2k
        tpErr = transportDec_FillData(self->hInput, pBuffer[layer],
1077
25.2k
                                      bufferSize[layer], &pBytesValid[layer],
1078
25.2k
                                      layer);
1079
25.2k
        if (tpErr != TRANSPORTDEC_OK) {
1080
0
          return AAC_DEC_UNKNOWN; /* Must be an internal error */
1081
0
        }
1082
25.2k
      }
1083
25.2k
    }
1084
25.2k
  }
1085
1086
25.2k
  return AAC_DEC_OK;
1087
25.2k
}
1088
1089
7.19k
static void aacDecoder_SignalInterruption(HANDLE_AACDECODER self) {
1090
7.19k
  CAacDecoder_SignalInterruption(self);
1091
1092
7.19k
  if (self->hSbrDecoder != NULL) {
1093
7.19k
    sbrDecoder_SetParam(self->hSbrDecoder, SBR_BS_INTERRUPTION, 1);
1094
7.19k
  }
1095
7.19k
  if (self->mpsEnableUser) {
1096
0
    mpegSurroundDecoder_SetParam(
1097
0
        (CMpegSurroundDecoder *)self->pMpegSurroundDecoder,
1098
0
        SACDEC_BS_INTERRUPTION, 1);
1099
0
  }
1100
7.19k
}
1101
1102
static void aacDecoder_UpdateBitStreamCounters(CStreamInfo *pSi,
1103
                                               HANDLE_FDK_BITSTREAM hBs,
1104
                                               INT nBits,
1105
398k
                                               AAC_DECODER_ERROR ErrorStatus) {
1106
  /* calculate bit difference (amount of bits moved forward) */
1107
398k
  nBits = nBits - (INT)FDKgetValidBits(hBs);
1108
1109
  /* Note: The amount of bits consumed might become negative when parsing a
1110
     bit stream with several sub frames, and we find out at the last sub frame
1111
     that the total frame length does not match the sum of sub frame length.
1112
     If this happens, the transport decoder might want to rewind to the supposed
1113
     ending of the transport frame, and this position might be before the last
1114
     access unit beginning. */
1115
1116
  /* Calc bitrate. */
1117
398k
  if (pSi->frameSize > 0) {
1118
    /* bitRate = nBits * sampleRate / frameSize */
1119
387k
    int ratio_e = 0;
1120
387k
    FIXP_DBL ratio_m = fDivNorm(pSi->sampleRate, pSi->frameSize, &ratio_e);
1121
387k
    pSi->bitRate = (INT)fMultNorm(nBits, DFRACT_BITS - 1, ratio_m, ratio_e,
1122
387k
                                  DFRACT_BITS - 1);
1123
387k
  }
1124
1125
  /* bit/byte counters */
1126
398k
  {
1127
398k
    INT nBytes;
1128
1129
398k
    nBytes = nBits >> 3;
1130
398k
    pSi->numTotalBytes += nBytes;
1131
398k
    if (IS_OUTPUT_VALID(ErrorStatus)) {
1132
378k
      pSi->numTotalAccessUnits++;
1133
378k
    }
1134
398k
    if (IS_DECODE_ERROR(ErrorStatus)) {
1135
5.82k
      pSi->numBadBytes += nBytes;
1136
5.82k
      pSi->numBadAccessUnits++;
1137
5.82k
    }
1138
398k
  }
1139
398k
}
1140
1141
7.17k
static INT aacDecoder_EstimateNumberOfLostFrames(HANDLE_AACDECODER self) {
1142
7.17k
  INT n;
1143
1144
7.17k
  transportDec_GetMissingAccessUnitCount(&n, self->hInput);
1145
1146
7.17k
  return n;
1147
7.17k
}
1148
1149
LINKSPEC_CPP AAC_DECODER_ERROR aacDecoder_DecodeFrame(HANDLE_AACDECODER self,
1150
                                                      INT_PCM *pTimeData,
1151
                                                      const INT timeDataSize,
1152
398k
                                                      const UINT flags) {
1153
398k
  AAC_DECODER_ERROR ErrorStatus;
1154
398k
  INT layer;
1155
398k
  INT nBits;
1156
398k
  INT timeData2Size;
1157
398k
  INT timeData3Size;
1158
398k
  INT timeDataHeadroom;
1159
398k
  HANDLE_FDK_BITSTREAM hBs;
1160
398k
  int fTpInterruption = 0; /* Transport originated interruption detection. */
1161
398k
  int fTpConceal = 0;      /* Transport originated concealment. */
1162
398k
  UINT accessUnit = 0;
1163
398k
  UINT numAccessUnits = 1;
1164
398k
  UINT numPrerollAU = 0;
1165
398k
  int fEndAuNotAdjusted = 0; /* The end of the access unit was not adjusted */
1166
398k
  int applyCrossfade = 1;    /* flag indicates if flushing was possible */
1167
398k
  PCM_DEC *pTimeData2;
1168
398k
  PCM_AAC *pTimeData3;
1169
398k
  INT pcmLimiterScale = 0;
1170
398k
  INT interleaved = 0;
1171
1172
398k
  if (self == NULL) {
1173
0
    return AAC_DEC_INVALID_HANDLE;
1174
0
  }
1175
1176
398k
  if (flags & AACDEC_INTR) {
1177
0
    self->streamInfo.numLostAccessUnits = 0;
1178
0
  }
1179
398k
  hBs = transportDec_GetBitstream(self->hInput, 0);
1180
1181
  /* Get current bits position for bitrate calculation. */
1182
398k
  nBits = FDKgetValidBits(hBs);
1183
1184
398k
  if (flags & AACDEC_CLRHIST) {
1185
0
    if (self->flags[0] & AC_USAC) {
1186
      /* 1) store AudioSpecificConfig always in AudioSpecificConfig_Parse() */
1187
      /* 2) free memory of dynamic allocated data */
1188
0
      CSAudioSpecificConfig asc;
1189
0
      transportDec_GetAsc(self->hInput, 0, &asc);
1190
0
      aacDecoder_FreeMemCallback(self, &asc);
1191
0
      self->streamInfo.numChannels = 0;
1192
      /* 3) restore AudioSpecificConfig */
1193
0
      if (asc.configBits <= (TP_USAC_MAX_CONFIG_LEN << 3)) {
1194
0
        transportDec_OutOfBandConfig(self->hInput, asc.config,
1195
0
                                     (asc.configBits + 7) >> 3, 0);
1196
0
      }
1197
0
    }
1198
0
  }
1199
1200
398k
  if (!((flags & (AACDEC_CONCEAL | AACDEC_FLUSH)) ||
1201
398k
        (self->flushStatus == AACDEC_RSV60_DASH_IPF_ATSC_FLUSH_ON) ||
1202
398k
        (self->flushStatus == AACDEC_USAC_DASH_IPF_FLUSH_ON) ||
1203
398k
        (self->buildUpStatus == AACDEC_RSV60_BUILD_UP_IDLE_IN_BAND))) {
1204
398k
    TRANSPORTDEC_ERROR err;
1205
1206
788k
    for (layer = 0; layer < self->nrOfLayers; layer++) {
1207
398k
      err = transportDec_ReadAccessUnit(self->hInput, layer);
1208
398k
      if (err != TRANSPORTDEC_OK) {
1209
15.5k
        switch (err) {
1210
8.37k
          case TRANSPORTDEC_NOT_ENOUGH_BITS:
1211
8.37k
            ErrorStatus = AAC_DEC_NOT_ENOUGH_BITS;
1212
8.37k
            goto bail;
1213
7.17k
          case TRANSPORTDEC_SYNC_ERROR:
1214
7.17k
            self->streamInfo.numLostAccessUnits =
1215
7.17k
                aacDecoder_EstimateNumberOfLostFrames(self);
1216
7.17k
            fTpInterruption = 1;
1217
7.17k
            break;
1218
0
          case TRANSPORTDEC_NEED_TO_RESTART:
1219
0
            ErrorStatus = AAC_DEC_NEED_TO_RESTART;
1220
0
            goto bail;
1221
0
          case TRANSPORTDEC_CRC_ERROR:
1222
0
            fTpConceal = 1;
1223
0
            break;
1224
0
          case TRANSPORTDEC_UNSUPPORTED_FORMAT:
1225
0
            ErrorStatus = AAC_DEC_UNSUPPORTED_FORMAT;
1226
0
            goto bail;
1227
0
          default:
1228
0
            ErrorStatus = AAC_DEC_UNKNOWN;
1229
0
            goto bail;
1230
15.5k
        }
1231
15.5k
      }
1232
398k
    }
1233
398k
  } else {
1234
0
    if (self->streamInfo.numLostAccessUnits > 0) {
1235
0
      self->streamInfo.numLostAccessUnits--;
1236
0
    }
1237
0
  }
1238
1239
389k
  self->frameOK = 1;
1240
1241
389k
  UINT prerollAUOffset[AACDEC_MAX_NUM_PREROLL_AU];
1242
389k
  UINT prerollAULength[AACDEC_MAX_NUM_PREROLL_AU];
1243
1.94M
  for (int i = 0; i < AACDEC_MAX_NUM_PREROLL_AU + 1; i++)
1244
1.55M
    self->prerollAULength[i] = 0;
1245
1246
389k
  INT auStartAnchor;
1247
389k
  HANDLE_FDK_BITSTREAM hBsAu;
1248
1249
  /* Process preroll frames and current frame */
1250
392k
  do {
1251
392k
    if (!(flags & (AACDEC_CONCEAL | AACDEC_FLUSH)) &&
1252
392k
        (self->flushStatus != AACDEC_RSV60_CFG_CHANGE_ATSC_FLUSH_ON) &&
1253
392k
        (accessUnit == 0) &&
1254
389k
        (self->hasAudioPreRoll ||
1255
385k
         (self->buildUpStatus == AACDEC_RSV60_BUILD_UP_IDLE_IN_BAND)) &&
1256
4.48k
        !fTpInterruption &&
1257
3.93k
        !fTpConceal /* Bit stream pointer needs to be at the beginning of a
1258
                       (valid) AU. */
1259
392k
    ) {
1260
3.93k
      ErrorStatus = CAacDecoder_PreRollExtensionPayloadParse(
1261
3.93k
          self, &numPrerollAU, prerollAUOffset, prerollAULength);
1262
1263
3.93k
      if (ErrorStatus != AAC_DEC_OK) {
1264
58
        switch (ErrorStatus) {
1265
7
          case AAC_DEC_NOT_ENOUGH_BITS:
1266
7
            goto bail;
1267
51
          case AAC_DEC_PARSE_ERROR:
1268
51
            self->frameOK = 0;
1269
51
            break;
1270
0
          default:
1271
0
            break;
1272
58
        }
1273
58
      }
1274
1275
3.92k
      numAccessUnits += numPrerollAU;
1276
3.92k
    }
1277
1278
392k
    hBsAu = transportDec_GetBitstream(self->hInput, 0);
1279
392k
    auStartAnchor = (INT)FDKgetValidBits(hBsAu);
1280
1281
392k
    self->accessUnit = accessUnit;
1282
392k
    if (accessUnit < numPrerollAU) {
1283
2.29k
      FDKpushFor(hBsAu, prerollAUOffset[accessUnit]);
1284
2.29k
    }
1285
1286
    /* Signal bit stream interruption to other modules if required. */
1287
392k
    if (fTpInterruption || ((flags & AACDEC_INTR) && (accessUnit == 0))) {
1288
7.17k
      aacDecoder_SignalInterruption(self);
1289
7.17k
      if (!((flags & AACDEC_INTR) && (accessUnit == 0))) {
1290
7.17k
        ErrorStatus = AAC_DEC_TRANSPORT_SYNC_ERROR;
1291
7.17k
        goto bail;
1292
7.17k
      }
1293
7.17k
    }
1294
1295
    /* Clearing core data will be done in CAacDecoder_DecodeFrame() below.
1296
       Tell other modules to clear states if required. */
1297
384k
    if (flags & AACDEC_CLRHIST) {
1298
0
      if (!(self->flags[0] & AC_USAC)) {
1299
0
        sbrDecoder_SetParam(self->hSbrDecoder, SBR_CLEAR_HISTORY, 1);
1300
0
        mpegSurroundDecoder_SetParam(
1301
0
            (CMpegSurroundDecoder *)self->pMpegSurroundDecoder,
1302
0
            SACDEC_CLEAR_HISTORY, 1);
1303
0
        if (FDK_QmfDomain_ClearPersistentMemory(&self->qmfDomain) != 0) {
1304
0
          ErrorStatus = AAC_DEC_UNKNOWN;
1305
0
          goto bail;
1306
0
        }
1307
0
      }
1308
0
    }
1309
1310
    /* Empty bit buffer in case of flush request. */
1311
384k
    if (flags & AACDEC_FLUSH && !(flags & AACDEC_CONCEAL)) {
1312
0
      if (!self->flushStatus) {
1313
0
        transportDec_SetParam(self->hInput, TPDEC_PARAM_RESET, 1);
1314
0
        self->streamInfo.numLostAccessUnits = 0;
1315
0
        self->streamInfo.numBadBytes = 0;
1316
0
        self->streamInfo.numTotalBytes = 0;
1317
0
      }
1318
0
    }
1319
    /* Reset the output delay field. The modules will add their figures one
1320
     * after another. */
1321
384k
    self->streamInfo.outputDelay = 0;
1322
1323
384k
    if (self->limiterEnableUser == (UCHAR)-2) {
1324
      /* Enable limiter only for RSVD60. */
1325
0
      self->limiterEnableCurr = (self->flags[0] & AC_RSV603DA) ? 1 : 0;
1326
384k
    } else if (self->limiterEnableUser == (UCHAR)-1) {
1327
      /* Enable limiter for all non-lowdelay AOT's. */
1328
384k
      self->limiterEnableCurr = (self->flags[0] & (AC_LD | AC_ELD)) ? 0 : 1;
1329
384k
    } else {
1330
      /* Use limiter configuration as requested. */
1331
0
      self->limiterEnableCurr = self->limiterEnableUser;
1332
0
    }
1333
1334
    /* reset DRC level normalization gain on a per frame basis */
1335
384k
    self->extGain[0] = AACDEC_DRC_GAIN_INIT_VALUE;
1336
1337
384k
    pTimeData2 = self->pTimeData2;
1338
384k
    timeData2Size = self->timeData2Size / sizeof(PCM_DEC);
1339
384k
    pTimeData3 = (PCM_AAC *)self->pTimeData2;
1340
384k
    timeData3Size = self->timeData2Size / sizeof(PCM_AAC);
1341
1342
384k
    ErrorStatus = CAacDecoder_DecodeFrame(
1343
384k
        self,
1344
384k
        flags | (fTpConceal ? AACDEC_CONCEAL : 0) |
1345
384k
            ((self->flushStatus && !(flags & AACDEC_CONCEAL)) ? AACDEC_FLUSH
1346
384k
                                                              : 0),
1347
384k
        pTimeData2 + 0, timeData2Size, self->streamInfo.aacSamplesPerFrame + 0);
1348
1349
384k
    timeDataHeadroom = self->aacOutDataHeadroom;
1350
1351
    /* if flushing for USAC DASH IPF was not possible go on with decoding
1352
     * preroll */
1353
384k
    if ((self->flags[0] & AC_USAC) &&
1354
249k
        (self->flushStatus == AACDEC_USAC_DASH_IPF_FLUSH_ON) &&
1355
25
        !(flags & AACDEC_CONCEAL) && (ErrorStatus != AAC_DEC_OK)) {
1356
0
      applyCrossfade = 0;
1357
0
    } else /* USAC DASH IPF flushing possible begin */
1358
384k
    {
1359
384k
      if (!((flags & (AACDEC_CONCEAL | AACDEC_FLUSH)) || fTpConceal ||
1360
384k
            self->flushStatus) &&
1361
384k
          (!(IS_OUTPUT_VALID(ErrorStatus)) || !(accessUnit < numPrerollAU))) {
1362
382k
        TRANSPORTDEC_ERROR tpErr;
1363
382k
        tpErr = transportDec_EndAccessUnit(self->hInput);
1364
382k
        if (tpErr != TRANSPORTDEC_OK) {
1365
96.3k
          self->frameOK = 0;
1366
96.3k
        }
1367
382k
      } else { /* while preroll processing later possibly an error in the
1368
                  renderer part occurrs */
1369
2.32k
        if (IS_OUTPUT_VALID(ErrorStatus)) {
1370
2.32k
          fEndAuNotAdjusted = 1;
1371
2.32k
        }
1372
2.32k
      }
1373
1374
      /* If the current pTimeData2 does not contain a valid signal, there
1375
       * nothing else we can do, so bail. */
1376
384k
      if (!IS_OUTPUT_VALID(ErrorStatus)) {
1377
3.86k
        goto bail;
1378
3.86k
      }
1379
1380
381k
      {
1381
381k
        self->streamInfo.sampleRate = self->streamInfo.aacSampleRate;
1382
381k
        self->streamInfo.frameSize = self->streamInfo.aacSamplesPerFrame;
1383
381k
      }
1384
1385
381k
      self->streamInfo.numChannels = self->streamInfo.aacNumChannels;
1386
1387
381k
      {
1388
381k
        FDK_Delay_Apply(
1389
381k
            &self->usacResidualDelay,
1390
381k
            pTimeData2 + 1 * (self->streamInfo.aacSamplesPerFrame + 0) + 0,
1391
381k
            self->streamInfo.frameSize, 0);
1392
381k
      }
1393
1394
      /* Setting of internal MPS state; may be reset in CAacDecoder_SyncQmfMode
1395
         if decoder is unable to decode with user defined qmfMode */
1396
381k
      if (!(self->flags[0] & (AC_USAC | AC_RSVD50 | AC_RSV603DA | AC_ELD))) {
1397
51.1k
        self->mpsEnableCurr =
1398
51.1k
            (self->mpsEnableUser &&
1399
0
             isSupportedMpsConfig(self->streamInfo.aot,
1400
0
                                  self->streamInfo.numChannels,
1401
0
                                  (self->flags[0] & AC_MPS_PRESENT) ? 1 : 0));
1402
51.1k
      }
1403
1404
381k
      if (!self->qmfDomain.globalConf.qmfDomainExplicitConfig &&
1405
116k
          self->mpsEnableCurr) {
1406
        /* if not done yet, allocate full MPEG Surround decoder instance */
1407
1.91k
        if (mpegSurroundDecoder_IsFullMpegSurroundDecoderInstanceAvailable(
1408
1.91k
                (CMpegSurroundDecoder *)self->pMpegSurroundDecoder) ==
1409
1.91k
            SAC_INSTANCE_NOT_FULL_AVAILABLE) {
1410
623
          if (mpegSurroundDecoder_Open(
1411
623
                  (CMpegSurroundDecoder **)&self->pMpegSurroundDecoder, -1,
1412
623
                  &self->qmfDomain)) {
1413
0
            return AAC_DEC_OUT_OF_MEMORY;
1414
0
          }
1415
623
        }
1416
1.91k
      }
1417
1418
381k
      CAacDecoder_SyncQmfMode(self);
1419
1420
381k
      if (!self->qmfDomain.globalConf.qmfDomainExplicitConfig &&
1421
116k
          self->mpsEnableCurr) {
1422
1.91k
        SAC_INPUT_CONFIG sac_interface = (self->sbrEnabled && self->hSbrDecoder)
1423
1.91k
                                             ? SAC_INTERFACE_QMF
1424
1.91k
                                             : SAC_INTERFACE_TIME;
1425
        /* needs to be done before first SBR apply. */
1426
1.91k
        mpegSurroundDecoder_ConfigureQmfDomain(
1427
1.91k
            (CMpegSurroundDecoder *)self->pMpegSurroundDecoder, sac_interface,
1428
1.91k
            (UINT)self->streamInfo.aacSampleRate, self->streamInfo.aot);
1429
1.91k
        if (self->qmfDomain.globalConf.nBandsAnalysis_requested > 0) {
1430
1.91k
          self->qmfDomain.globalConf.nQmfTimeSlots_requested =
1431
1.91k
              self->streamInfo.aacSamplesPerFrame /
1432
1.91k
              self->qmfDomain.globalConf.nBandsAnalysis_requested;
1433
1.91k
        } else {
1434
0
          self->qmfDomain.globalConf.nQmfTimeSlots_requested = 0;
1435
0
        }
1436
1.91k
      }
1437
1438
381k
      switch (FDK_QmfDomain_Configure(&self->qmfDomain)) {
1439
0
        default:
1440
4
        case QMF_DOMAIN_INIT_ERROR:
1441
4
          ErrorStatus = AAC_DEC_UNKNOWN;
1442
4
          goto bail;
1443
0
        case QMF_DOMAIN_OUT_OF_MEMORY:
1444
0
          ErrorStatus = AAC_DEC_OUT_OF_MEMORY;
1445
0
          goto bail;
1446
381k
        case QMF_DOMAIN_OK:
1447
381k
          break;
1448
381k
      }
1449
1450
      /* sbr decoder */
1451
1452
381k
      if ((ErrorStatus != AAC_DEC_OK) || (flags & AACDEC_CONCEAL) ||
1453
374k
          self->pAacDecoderStaticChannelInfo[0]->concealmentInfo.concealState >
1454
374k
              ConcealState_FadeIn) {
1455
6.22k
        self->frameOK = 0; /* if an error has occured do concealment in the SBR
1456
                              decoder too */
1457
6.22k
      }
1458
1459
381k
      if (self->sbrEnabled && (!(self->flags[0] & AC_USAC_SCFGI3))) {
1460
263k
        SBR_ERROR sbrError = SBRDEC_OK;
1461
263k
        int chIdx, numCoreChannel = self->streamInfo.numChannels;
1462
1463
        /* set params */
1464
263k
        sbrDecoder_SetParam(self->hSbrDecoder, SBR_SYSTEM_BITSTREAM_DELAY,
1465
263k
                            self->sbrParams.bsDelay);
1466
263k
        sbrDecoder_SetParam(
1467
263k
            self->hSbrDecoder, SBR_FLUSH_DATA,
1468
263k
            (flags & AACDEC_FLUSH) |
1469
263k
                ((self->flushStatus && !(flags & AACDEC_CONCEAL)) ? AACDEC_FLUSH
1470
263k
                                                                  : 0));
1471
1472
263k
        if (self->streamInfo.aot == AOT_ER_AAC_ELD) {
1473
          /* Configure QMF */
1474
28.8k
          sbrDecoder_SetParam(self->hSbrDecoder, SBR_LD_QMF_TIME_ALIGN,
1475
28.8k
                              (self->flags[0] & AC_MPS_PRESENT) ? 1 : 0);
1476
28.8k
        }
1477
1478
263k
        {
1479
263k
          PCMDMX_ERROR dmxErr;
1480
263k
          INT maxOutCh = 0;
1481
1482
263k
          dmxErr = pcmDmx_GetParam(self->hPcmUtils,
1483
263k
                                   MAX_NUMBER_OF_OUTPUT_CHANNELS, &maxOutCh);
1484
263k
          if ((dmxErr == PCMDMX_OK) && (maxOutCh == 1)) {
1485
            /* Disable PS processing if we have to create a mono output signal.
1486
             */
1487
0
            self->psPossible = 0;
1488
0
          }
1489
263k
        }
1490
1491
263k
        sbrDecoder_SetParam(self->hSbrDecoder, SBR_SKIP_QMF,
1492
263k
                            (self->mpsEnableCurr) ? 2 : 0);
1493
1494
263k
        PCM_AAC *input;
1495
263k
        input = (PCM_AAC *)self->workBufferCore2;
1496
263k
        FDKmemcpy(input, pTimeData3,
1497
263k
                  sizeof(PCM_AAC) * (self->streamInfo.numChannels) *
1498
263k
                      (self->streamInfo.frameSize));
1499
1500
        /* apply SBR processing */
1501
263k
        sbrError = sbrDecoder_Apply(
1502
263k
            self->hSbrDecoder, input, pTimeData3, timeData3Size,
1503
263k
            &self->streamInfo.numChannels, &self->streamInfo.sampleRate,
1504
263k
            &self->mapDescr, self->chMapIndex, self->frameOK, &self->psPossible,
1505
263k
            self->aacOutDataHeadroom, &timeDataHeadroom);
1506
1507
263k
        if (sbrError == SBRDEC_OK) {
1508
          /* Update data in streaminfo structure. Assume that the SBR upsampling
1509
             factor is either 1, 2, 8/3 or 4. Maximum upsampling factor is 4
1510
             (CELP+SBR or USAC 4:1 SBR) */
1511
263k
          self->flags[0] |= AC_SBR_PRESENT;
1512
263k
          if (self->streamInfo.aacSampleRate != self->streamInfo.sampleRate) {
1513
247k
            if (self->streamInfo.aacSampleRate >> 2 ==
1514
247k
                self->streamInfo.sampleRate) {
1515
0
              self->streamInfo.frameSize =
1516
0
                  self->streamInfo.aacSamplesPerFrame >> 2;
1517
0
              self->streamInfo.outputDelay = self->streamInfo.outputDelay >> 2;
1518
247k
            } else if (self->streamInfo.aacSampleRate >> 1 ==
1519
247k
                       self->streamInfo.sampleRate) {
1520
0
              self->streamInfo.frameSize =
1521
0
                  self->streamInfo.aacSamplesPerFrame >> 1;
1522
0
              self->streamInfo.outputDelay = self->streamInfo.outputDelay >> 1;
1523
247k
            } else if (self->streamInfo.aacSampleRate << 1 ==
1524
247k
                       self->streamInfo.sampleRate) {
1525
155k
              self->streamInfo.frameSize = self->streamInfo.aacSamplesPerFrame
1526
155k
                                           << 1;
1527
155k
              self->streamInfo.outputDelay = self->streamInfo.outputDelay << 1;
1528
155k
            } else if (self->streamInfo.aacSampleRate << 2 ==
1529
92.3k
                       self->streamInfo.sampleRate) {
1530
17.7k
              self->streamInfo.frameSize = self->streamInfo.aacSamplesPerFrame
1531
17.7k
                                           << 2;
1532
17.7k
              self->streamInfo.outputDelay = self->streamInfo.outputDelay << 2;
1533
74.5k
            } else if (self->streamInfo.frameSize == 768) {
1534
74.5k
              self->streamInfo.frameSize =
1535
74.5k
                  (self->streamInfo.aacSamplesPerFrame << 3) / 3;
1536
74.5k
              self->streamInfo.outputDelay =
1537
74.5k
                  (self->streamInfo.outputDelay << 3) / 3;
1538
74.5k
            } else {
1539
11
              ErrorStatus = AAC_DEC_SET_PARAM_FAIL;
1540
11
              goto bail;
1541
11
            }
1542
247k
          } else {
1543
15.4k
            self->streamInfo.frameSize = self->streamInfo.aacSamplesPerFrame;
1544
15.4k
          }
1545
263k
          self->streamInfo.outputDelay +=
1546
263k
              sbrDecoder_GetDelay(self->hSbrDecoder);
1547
1548
263k
          if (self->psPossible) {
1549
3.52k
            self->flags[0] |= AC_PS_PRESENT;
1550
3.52k
          }
1551
269k
          for (chIdx = numCoreChannel; chIdx < self->streamInfo.numChannels;
1552
263k
               chIdx += 1) {
1553
6.43k
            self->channelType[chIdx] = ACT_FRONT;
1554
6.43k
            self->channelIndices[chIdx] = chIdx;
1555
6.43k
          }
1556
263k
        }
1557
263k
        if (sbrError == SBRDEC_OUTPUT_BUFFER_TOO_SMALL) {
1558
0
          ErrorStatus = AAC_DEC_OUTPUT_BUFFER_TOO_SMALL;
1559
0
          goto bail;
1560
0
        }
1561
263k
      }
1562
1563
381k
      if (self->mpsEnableCurr) {
1564
186k
        int err, sac_interface, nChannels, frameSize;
1565
1566
186k
        nChannels = self->streamInfo.numChannels;
1567
186k
        frameSize = self->streamInfo.frameSize;
1568
186k
        sac_interface = SAC_INTERFACE_TIME;
1569
1570
186k
        if (self->sbrEnabled && self->hSbrDecoder)
1571
143k
          sac_interface = SAC_INTERFACE_QMF;
1572
186k
        if (self->streamInfo.aot == AOT_USAC) {
1573
142k
          if (self->flags[0] & AC_USAC_SCFGI3) {
1574
14.2k
            sac_interface = SAC_INTERFACE_TIME;
1575
14.2k
          }
1576
142k
        }
1577
186k
        err = mpegSurroundDecoder_SetParam(
1578
186k
            (CMpegSurroundDecoder *)self->pMpegSurroundDecoder,
1579
186k
            SACDEC_INTERFACE, sac_interface);
1580
1581
186k
        if (err == 0) {
1582
186k
          err = mpegSurroundDecoder_Apply(
1583
186k
              (CMpegSurroundDecoder *)self->pMpegSurroundDecoder,
1584
186k
              (PCM_AAC *)self->workBufferCore2, pTimeData3, timeData3Size,
1585
186k
              self->streamInfo.aacSamplesPerFrame, &nChannels, &frameSize,
1586
186k
              self->streamInfo.sampleRate, self->streamInfo.aot,
1587
186k
              self->channelType, self->channelIndices, &self->mapDescr,
1588
186k
              self->aacOutDataHeadroom, &timeDataHeadroom);
1589
186k
        }
1590
1591
186k
        if (err == MPS_OUTPUT_BUFFER_TOO_SMALL) {
1592
0
          ErrorStatus = AAC_DEC_OUTPUT_BUFFER_TOO_SMALL;
1593
0
          goto bail;
1594
0
        }
1595
186k
        if (err == 0) {
1596
          /* Update output parameter */
1597
186k
          self->streamInfo.numChannels = nChannels;
1598
186k
          self->streamInfo.frameSize = frameSize;
1599
186k
          self->streamInfo.outputDelay += mpegSurroundDecoder_GetDelay(
1600
186k
              (CMpegSurroundDecoder *)self->pMpegSurroundDecoder);
1601
          /* Save current parameter for possible concealment of next frame */
1602
186k
          self->mpsOutChannelsLast = nChannels;
1603
186k
          self->mpsFrameSizeLast = frameSize;
1604
186k
        } else if ((self->mpsOutChannelsLast > 0) &&
1605
2
                   (self->mpsFrameSizeLast > 0)) {
1606
          /* Restore parameters of last frame ... */
1607
2
          self->streamInfo.numChannels = self->mpsOutChannelsLast;
1608
2
          self->streamInfo.frameSize = self->mpsFrameSizeLast;
1609
          /* ... and clear output buffer so that potentially corrupted data does
1610
           * not reach the framework. */
1611
2
          FDKmemclear(pTimeData3, self->mpsOutChannelsLast *
1612
2
                                      self->mpsFrameSizeLast * sizeof(PCM_AAC));
1613
          /* Additionally proclaim that this frame had errors during decoding.
1614
           */
1615
2
          ErrorStatus = AAC_DEC_DECODE_FRAME_ERROR;
1616
2
        } else {
1617
0
          ErrorStatus = AAC_DEC_UNKNOWN; /* no output */
1618
0
        }
1619
186k
      }
1620
1621
      /* SBR decoder for Unified Stereo Config (stereoConfigIndex == 3) */
1622
1623
381k
      if (self->sbrEnabled && (self->flags[0] & AC_USAC_SCFGI3)) {
1624
14.2k
        SBR_ERROR sbrError = SBRDEC_OK;
1625
1626
        /* set params */
1627
14.2k
        sbrDecoder_SetParam(self->hSbrDecoder, SBR_SYSTEM_BITSTREAM_DELAY,
1628
14.2k
                            self->sbrParams.bsDelay);
1629
14.2k
        sbrDecoder_SetParam(
1630
14.2k
            self->hSbrDecoder, SBR_FLUSH_DATA,
1631
14.2k
            (flags & AACDEC_FLUSH) |
1632
14.2k
                ((self->flushStatus && !(flags & AACDEC_CONCEAL)) ? AACDEC_FLUSH
1633
14.2k
                                                                  : 0));
1634
1635
14.2k
        sbrDecoder_SetParam(self->hSbrDecoder, SBR_SKIP_QMF, 1);
1636
1637
        /* apply SBR processing */
1638
14.2k
        sbrError = sbrDecoder_Apply(
1639
14.2k
            self->hSbrDecoder, pTimeData3, pTimeData3, timeData3Size,
1640
14.2k
            &self->streamInfo.numChannels, &self->streamInfo.sampleRate,
1641
14.2k
            &self->mapDescr, self->chMapIndex, self->frameOK, &self->psPossible,
1642
14.2k
            self->aacOutDataHeadroom, &timeDataHeadroom);
1643
1644
14.2k
        if (sbrError == SBRDEC_OK) {
1645
          /* Update data in streaminfo structure. Assume that the SBR upsampling
1646
           * factor is either 1,2 or 4 */
1647
14.2k
          self->flags[0] |= AC_SBR_PRESENT;
1648
14.2k
          if (self->streamInfo.aacSampleRate != self->streamInfo.sampleRate) {
1649
14.2k
            if (self->streamInfo.frameSize == 768) {
1650
1.75k
              self->streamInfo.frameSize =
1651
1.75k
                  (self->streamInfo.aacSamplesPerFrame * 8) / 3;
1652
12.4k
            } else if (self->streamInfo.aacSampleRate << 2 ==
1653
12.4k
                       self->streamInfo.sampleRate) {
1654
10.8k
              self->streamInfo.frameSize = self->streamInfo.aacSamplesPerFrame
1655
10.8k
                                           << 2;
1656
10.8k
            } else {
1657
1.60k
              self->streamInfo.frameSize = self->streamInfo.aacSamplesPerFrame
1658
1.60k
                                           << 1;
1659
1.60k
            }
1660
14.2k
          }
1661
1662
14.2k
          self->flags[0] &= ~AC_PS_PRESENT;
1663
14.2k
        }
1664
14.2k
        if (sbrError == SBRDEC_OUTPUT_BUFFER_TOO_SMALL) {
1665
0
          ErrorStatus = AAC_DEC_OUTPUT_BUFFER_TOO_SMALL;
1666
0
          goto bail;
1667
0
        }
1668
14.2k
      }
1669
1670
381k
      {
1671
381k
        if ((INT)PCM_OUT_HEADROOM != timeDataHeadroom) {
1672
60.3k
          for (int i = ((self->streamInfo.frameSize *
1673
60.3k
                         self->streamInfo.numChannels) -
1674
60.3k
                        1);
1675
98.4M
               i >= 0; i--) {
1676
98.4M
            pTimeData2[i] =
1677
98.4M
                (PCM_DEC)pTimeData3[i] >> (PCM_OUT_HEADROOM - timeDataHeadroom);
1678
98.4M
          }
1679
60.3k
        }
1680
381k
      }
1681
1682
381k
      {
1683
381k
        if ((FDK_drcDec_GetParam(self->hUniDrcDecoder, DRC_DEC_IS_ACTIVE)) &&
1684
19.1k
            (self->flags[0] & AC_USAC)) {
1685
          /* Apply DRC gains*/
1686
17.0k
          int ch, drcDelay = 0;
1687
17.0k
          int needsDeinterleaving = 0;
1688
17.0k
          FIXP_DBL *drcWorkBuffer = NULL;
1689
17.0k
          FIXP_DBL channelGain[(8)];
1690
17.0k
          int reverseInChannelMap[(8)];
1691
17.0k
          int reverseOutChannelMap[(8)];
1692
17.0k
          FDKmemclear(channelGain, sizeof(channelGain));
1693
153k
          for (ch = 0; ch < (8); ch++) {
1694
136k
            reverseInChannelMap[ch] = ch;
1695
136k
            reverseOutChannelMap[ch] = ch;
1696
136k
          }
1697
1698
          /* Update sampleRate and frameSize. This may be necessary in case of
1699
           * implicit SBR signaling */
1700
17.0k
          FDK_drcDec_SetParam(self->hUniDrcDecoder, DRC_DEC_SAMPLE_RATE,
1701
17.0k
                              self->streamInfo.sampleRate);
1702
17.0k
          FDK_drcDec_SetParam(self->hUniDrcDecoder, DRC_DEC_FRAME_SIZE,
1703
17.0k
                              self->streamInfo.frameSize);
1704
1705
          /* If SBR and/or MPS is active, the DRC gains are aligned to the QMF
1706
             domain signal before the QMF synthesis. Therefore the DRC gains
1707
             need to be delayed by the QMF synthesis delay. */
1708
17.0k
          if (self->sbrEnabled) drcDelay = 257;
1709
17.0k
          if (self->mpsEnableCurr) drcDelay = 257;
1710
          /* Take into account concealment delay */
1711
17.0k
          drcDelay += CConcealment_GetDelay(&self->concealCommonData) *
1712
17.0k
                      self->streamInfo.frameSize;
1713
1714
          /* The output of SBR and MPS is interleaved. Deinterleaving may be
1715
           * necessary for FDK_drcDec_ProcessTime, which accepts deinterleaved
1716
           * audio only. */
1717
17.0k
          if ((self->streamInfo.numChannels > 1) &&
1718
2.03k
              (0 || (self->sbrEnabled) || (self->mpsEnableCurr))) {
1719
            /* interleaving/deinterleaving is performed on upper part of
1720
             * pTimeData2. Check if this buffer is large enough. */
1721
1.77k
            if (timeData2Size < (INT)(2 * self->streamInfo.numChannels *
1722
1.77k
                                      self->streamInfo.frameSize)) {
1723
0
              ErrorStatus = AAC_DEC_UNKNOWN;
1724
0
              goto bail;
1725
0
            }
1726
1.77k
            needsDeinterleaving = 1;
1727
1.77k
            drcWorkBuffer =
1728
1.77k
                (FIXP_DBL *)pTimeData2 +
1729
1.77k
                self->streamInfo.numChannels * self->streamInfo.frameSize;
1730
1.77k
            FDK_deinterleave(
1731
1.77k
                pTimeData2, drcWorkBuffer, self->streamInfo.numChannels,
1732
1.77k
                self->streamInfo.frameSize, self->streamInfo.frameSize);
1733
15.2k
          } else {
1734
15.2k
            drcWorkBuffer = pTimeData2;
1735
15.2k
          }
1736
1737
          /* prepare Loudness Normalisation gain */
1738
17.0k
          FDK_drcDec_SetParam(self->hUniDrcDecoder, DRC_DEC_TARGET_LOUDNESS,
1739
17.0k
                              (INT)-self->defaultTargetLoudness *
1740
17.0k
                                  FL2FXCONST_DBL(1.0f / (float)(1 << 9)));
1741
17.0k
          FDK_drcDec_SetChannelGains(self->hUniDrcDecoder,
1742
17.0k
                                     self->streamInfo.numChannels,
1743
17.0k
                                     self->streamInfo.frameSize, channelGain,
1744
17.0k
                                     drcWorkBuffer, self->streamInfo.frameSize);
1745
17.0k
          FDK_drcDec_Preprocess(self->hUniDrcDecoder);
1746
1747
          /* apply DRC1 gain sequence */
1748
17.0k
          FDK_drcDec_ProcessTime(self->hUniDrcDecoder, drcDelay, DRC_DEC_DRC1,
1749
17.0k
                                 0, 0, self->streamInfo.numChannels,
1750
17.0k
                                 drcWorkBuffer, self->streamInfo.frameSize);
1751
          /* apply downmix */
1752
17.0k
          FDK_drcDec_ApplyDownmix(
1753
17.0k
              self->hUniDrcDecoder, reverseInChannelMap, reverseOutChannelMap,
1754
17.0k
              drcWorkBuffer,
1755
17.0k
              &self->streamInfo.numChannels); /* self->streamInfo.numChannels
1756
                                                 may change here */
1757
          /* apply DRC2/3 gain sequence */
1758
17.0k
          FDK_drcDec_ProcessTime(self->hUniDrcDecoder, drcDelay,
1759
17.0k
                                 DRC_DEC_DRC2_DRC3, 0, 0,
1760
17.0k
                                 self->streamInfo.numChannels, drcWorkBuffer,
1761
17.0k
                                 self->streamInfo.frameSize);
1762
1763
17.0k
          if (needsDeinterleaving) {
1764
1.77k
            FDK_interleave(
1765
1.77k
                drcWorkBuffer, pTimeData2, self->streamInfo.numChannels,
1766
1.77k
                self->streamInfo.frameSize, self->streamInfo.frameSize);
1767
1.77k
          }
1768
17.0k
        }
1769
381k
      }
1770
381k
      if (FDK_drcDec_GetParam(self->hUniDrcDecoder, DRC_DEC_IS_ACTIVE)) {
1771
        /* return output loudness information for MPEG-D DRC */
1772
19.1k
        LONG outputLoudness =
1773
19.1k
            FDK_drcDec_GetParam(self->hUniDrcDecoder, DRC_DEC_OUTPUT_LOUDNESS);
1774
19.1k
        if (outputLoudness == DRC_DEC_LOUDNESS_NOT_PRESENT) {
1775
          /* no valid MPEG-D DRC loudness value contained */
1776
17.6k
          self->streamInfo.outputLoudness = -1;
1777
17.6k
        } else {
1778
1.48k
          if (outputLoudness > 0) {
1779
            /* positive output loudness values (very unusual) are limited to 0
1780
             * dB */
1781
647
            self->streamInfo.outputLoudness = 0;
1782
838
          } else {
1783
838
            self->streamInfo.outputLoudness =
1784
838
                -(INT)outputLoudness >>
1785
838
                22; /* negate and scale from e = 7 to e = (31-2) */
1786
838
          }
1787
1.48k
        }
1788
361k
      } else {
1789
        /* return output loudness information for MPEG-4 DRC */
1790
361k
        if (self->streamInfo.drcProgRefLev <
1791
361k
            0) { /* no MPEG-4 DRC loudness metadata contained */
1792
343k
          self->streamInfo.outputLoudness = -1;
1793
343k
        } else {
1794
18.6k
          if (self->defaultTargetLoudness <
1795
18.6k
              0) { /* loudness normalization is off */
1796
0
            self->streamInfo.outputLoudness = self->streamInfo.drcProgRefLev;
1797
18.6k
          } else {
1798
18.6k
            self->streamInfo.outputLoudness = self->defaultTargetLoudness;
1799
18.6k
          }
1800
18.6k
        }
1801
361k
      }
1802
1803
381k
      if (self->streamInfo.extAot != AOT_AAC_SLS) {
1804
381k
        interleaved = 0;
1805
381k
        interleaved |= (self->sbrEnabled) ? 1 : 0;
1806
381k
        interleaved |= (self->mpsEnableCurr) ? 1 : 0;
1807
381k
        PCMDMX_ERROR dmxErr = PCMDMX_OK;
1808
381k
        if ((flags & AACDEC_INTR) && (accessUnit == 0)) {
1809
          /* delete data from the past (e.g. mixdown coeficients) */
1810
0
          pcmDmx_Reset(self->hPcmUtils, PCMDMX_RESET_BS_DATA);
1811
0
        }
1812
381k
        if (flags & (AACDEC_CLRHIST)) {
1813
0
          if (!(self->flags[0] & AC_USAC)) {
1814
            /* delete data from the past (e.g. mixdown coeficients) */
1815
0
            pcmDmx_Reset(self->hPcmUtils, PCMDMX_RESET_BS_DATA);
1816
0
          }
1817
0
        }
1818
1819
        /* do PCM post processing */
1820
381k
        dmxErr = pcmDmx_ApplyFrame(self->hPcmUtils, pTimeData2, timeData2Size,
1821
381k
                                   self->streamInfo.frameSize,
1822
381k
                                   &self->streamInfo.numChannels, interleaved,
1823
381k
                                   self->channelType, self->channelIndices,
1824
381k
                                   &self->mapDescr, &pcmLimiterScale);
1825
381k
        if (dmxErr == PCMDMX_OUTPUT_BUFFER_TOO_SMALL) {
1826
0
          ErrorStatus = AAC_DEC_OUTPUT_BUFFER_TOO_SMALL;
1827
0
          goto bail;
1828
0
        }
1829
381k
        if ((ErrorStatus == AAC_DEC_OK) && (dmxErr == PCMDMX_INVALID_MODE)) {
1830
          /* Announce the framework that the current combination of channel
1831
           * configuration and downmix settings are not know to produce a
1832
           * predictable behavior and thus maybe produce strange output. */
1833
5
          ErrorStatus = AAC_DEC_DECODE_FRAME_ERROR;
1834
5
        }
1835
381k
      }
1836
1837
381k
      if (self->flags[0] & AC_USAC) {
1838
248k
        if (self->flushStatus == AACDEC_USAC_DASH_IPF_FLUSH_ON &&
1839
25
            !(flags & AACDEC_CONCEAL)) {
1840
25
          CAacDecoder_PrepareCrossFade(pTimeData2, self->pTimeDataFlush,
1841
25
                                       self->streamInfo.numChannels,
1842
25
                                       self->streamInfo.frameSize, interleaved);
1843
25
        }
1844
1845
        /* prepare crossfade buffer for fade in */
1846
248k
        if (!applyCrossfade &&
1847
0
            (self->applyCrossfade != AACDEC_CROSSFADE_BITMASK_OFF) &&
1848
0
            !(flags & AACDEC_CONCEAL)) {
1849
0
          for (int ch = 0; ch < self->streamInfo.numChannels; ch++) {
1850
0
            for (int i = 0; i < TIME_DATA_FLUSH_SIZE; i++) {
1851
0
              self->pTimeDataFlush[ch][i] = (PCM_DEC)0;
1852
0
            }
1853
0
          }
1854
0
          applyCrossfade = 1;
1855
0
        }
1856
1857
248k
        if (applyCrossfade &&
1858
248k
            (self->applyCrossfade != AACDEC_CROSSFADE_BITMASK_OFF) &&
1859
669
            !(accessUnit < numPrerollAU) &&
1860
220
            (self->buildUpStatus == AACDEC_USAC_BUILD_UP_ON)) {
1861
220
          CAacDecoder_ApplyCrossFade(pTimeData2, self->pTimeDataFlush,
1862
220
                                     self->streamInfo.numChannels,
1863
220
                                     self->streamInfo.frameSize, interleaved);
1864
220
          self->applyCrossfade =
1865
220
              AACDEC_CROSSFADE_BITMASK_OFF; /* disable cross-fade between frames
1866
                                               at nect config change */
1867
220
        }
1868
248k
      }
1869
1870
      /* Signal interruption to take effect in next frame. */
1871
381k
      if ((flags & AACDEC_FLUSH || self->flushStatus) &&
1872
25
          !(flags & AACDEC_CONCEAL)) {
1873
25
        aacDecoder_SignalInterruption(self);
1874
25
      }
1875
1876
      /* Update externally visible copy of flags */
1877
381k
      self->streamInfo.flags = self->flags[0];
1878
1879
381k
    } /* USAC DASH IPF flushing possible end */
1880
381k
    if (accessUnit < numPrerollAU) {
1881
2.29k
      FDKpushBack(hBsAu, auStartAnchor - (INT)FDKgetValidBits(hBsAu));
1882
378k
    } else {
1883
378k
      if ((self->buildUpStatus == AACDEC_RSV60_BUILD_UP_ON) ||
1884
378k
          (self->buildUpStatus == AACDEC_RSV60_BUILD_UP_ON_IN_BAND) ||
1885
378k
          (self->buildUpStatus == AACDEC_USAC_BUILD_UP_ON)) {
1886
1.13k
        self->buildUpCnt--;
1887
1888
1.13k
        if (self->buildUpCnt < 0) {
1889
1.13k
          self->buildUpStatus = 0;
1890
1.13k
        }
1891
1.13k
      }
1892
1893
378k
      if (self->flags[0] & AC_USAC) {
1894
246k
        if (self->flushStatus == AACDEC_USAC_DASH_IPF_FLUSH_ON &&
1895
25
            !(flags & AACDEC_CONCEAL)) {
1896
25
          self->streamInfo.frameSize = 0;
1897
25
        }
1898
246k
      }
1899
378k
    }
1900
1901
381k
    if (self->flushStatus != AACDEC_USAC_DASH_IPF_FLUSH_ON) {
1902
381k
      accessUnit++;
1903
381k
    }
1904
381k
  } while ((accessUnit < numAccessUnits) ||
1905
378k
           ((self->flushStatus == AACDEC_USAC_DASH_IPF_FLUSH_ON) &&
1906
0
            !(flags & AACDEC_CONCEAL)));
1907
1908
378k
  if (self->streamInfo.extAot != AOT_AAC_SLS) {
1909
378k
    pcmLimiterScale += PCM_OUT_HEADROOM;
1910
1911
378k
    if (flags & AACDEC_CLRHIST) {
1912
0
      if (!(self->flags[0] & AC_USAC)) {
1913
        /* Reset DRC data */
1914
0
        aacDecoder_drcReset(self->hDrcInfo);
1915
        /* Delete the delayed signal. */
1916
0
        pcmLimiter_Reset(self->hLimiter);
1917
0
      }
1918
0
    }
1919
1920
    /* Set applyExtGain if DRC processing is enabled and if progRefLevelPresent
1921
       is present for the first time. Consequences: The headroom of the output
1922
       signal can be set to AACDEC_DRC_GAIN_SCALING only for audio formats which
1923
       support legacy DRC Level Normalization. For all other audio formats the
1924
       headroom of the output signal is set to PCM_OUT_HEADROOM. */
1925
378k
    if (self->hDrcInfo->enable && (self->hDrcInfo->progRefLevelPresent == 1)) {
1926
18.9k
      self->hDrcInfo->applyExtGain |= 1;
1927
18.9k
    }
1928
1929
    /* Check whether time data buffer is large enough. */
1930
378k
    if (timeDataSize <
1931
378k
        (self->streamInfo.numChannels * self->streamInfo.frameSize)) {
1932
0
      ErrorStatus = AAC_DEC_OUTPUT_BUFFER_TOO_SMALL;
1933
0
      goto bail;
1934
0
    }
1935
1936
378k
    if (self->limiterEnableCurr) {
1937
      /* use workBufferCore2 buffer for interleaving */
1938
297k
      PCM_LIM *pInterleaveBuffer;
1939
297k
      int blockLength = self->streamInfo.frameSize;
1940
1941
      /* Set actual signal parameters */
1942
297k
      pcmLimiter_SetNChannels(self->hLimiter, self->streamInfo.numChannels);
1943
297k
      pcmLimiter_SetSampleRate(self->hLimiter, self->streamInfo.sampleRate);
1944
1945
297k
      if ((self->streamInfo.numChannels == 1) || (self->sbrEnabled) ||
1946
273k
          (self->mpsEnableCurr)) {
1947
273k
        pInterleaveBuffer = (PCM_LIM *)pTimeData2;
1948
273k
      } else {
1949
23.9k
        pInterleaveBuffer = (PCM_LIM *)self->workBufferCore2;
1950
1951
        /* applyLimiter requests for interleaved data */
1952
        /* Interleave ouput buffer */
1953
23.9k
        FDK_interleave(pTimeData2, pInterleaveBuffer,
1954
23.9k
                       self->streamInfo.numChannels, blockLength,
1955
23.9k
                       self->streamInfo.frameSize);
1956
23.9k
      }
1957
1958
297k
      FIXP_DBL *pGainPerSample = NULL;
1959
1960
297k
      if (self->hDrcInfo->enable && self->hDrcInfo->applyExtGain) {
1961
13.0k
        pGainPerSample = self->workBufferCore1;
1962
1963
13.0k
        if ((INT)GetRequiredMemWorkBufferCore1() <
1964
13.0k
            (INT)(self->streamInfo.frameSize * sizeof(FIXP_DBL))) {
1965
0
          ErrorStatus = AAC_DEC_UNKNOWN;
1966
0
          goto bail;
1967
0
        }
1968
1969
13.0k
        pcmLimiterScale = applyDrcLevelNormalization(
1970
13.0k
            self->hDrcInfo, (PCM_DEC *)pInterleaveBuffer, self->extGain,
1971
13.0k
            pGainPerSample, pcmLimiterScale, self->extGainDelay,
1972
13.0k
            self->streamInfo.frameSize, self->streamInfo.numChannels, 1, 1);
1973
13.0k
      }
1974
1975
297k
      pcmLimiter_Apply(self->hLimiter, pInterleaveBuffer, pTimeData,
1976
297k
                       pGainPerSample, pcmLimiterScale,
1977
297k
                       self->streamInfo.frameSize);
1978
1979
297k
      {
1980
        /* Announce the additional limiter output delay */
1981
297k
        self->streamInfo.outputDelay += pcmLimiter_GetDelay(self->hLimiter);
1982
297k
      }
1983
297k
    } else {
1984
81.6k
      if (self->hDrcInfo->enable && self->hDrcInfo->applyExtGain) {
1985
5.89k
        pcmLimiterScale = applyDrcLevelNormalization(
1986
5.89k
            self->hDrcInfo, pTimeData2, self->extGain, NULL, pcmLimiterScale,
1987
5.89k
            self->extGainDelay, self->streamInfo.frameSize,
1988
5.89k
            self->streamInfo.numChannels,
1989
5.89k
            (interleaved || (self->streamInfo.numChannels == 1))
1990
5.89k
                ? 1
1991
5.89k
                : self->streamInfo.frameSize,
1992
5.89k
            0);
1993
5.89k
      }
1994
1995
      /* If numChannels = 1 we do not need interleaving. The same applies if SBR
1996
      or MPS are used, since their output is interleaved already (resampled or
1997
      not) */
1998
81.6k
      if ((self->streamInfo.numChannels == 1) || (self->sbrEnabled) ||
1999
76.2k
          (self->mpsEnableCurr)) {
2000
76.2k
        scaleValuesSaturate(
2001
76.2k
            pTimeData, pTimeData2,
2002
76.2k
            self->streamInfo.frameSize * self->streamInfo.numChannels,
2003
76.2k
            pcmLimiterScale);
2004
2005
76.2k
      } else {
2006
5.44k
        scaleValuesSaturate(
2007
5.44k
            (INT_PCM *)self->workBufferCore2, pTimeData2,
2008
5.44k
            self->streamInfo.frameSize * self->streamInfo.numChannels,
2009
5.44k
            pcmLimiterScale);
2010
        /* Interleave ouput buffer */
2011
5.44k
        FDK_interleave((INT_PCM *)self->workBufferCore2, pTimeData,
2012
5.44k
                       self->streamInfo.numChannels, self->streamInfo.frameSize,
2013
5.44k
                       self->streamInfo.frameSize);
2014
5.44k
      }
2015
81.6k
    }
2016
378k
  } /* if (self->streamInfo.extAot != AOT_AAC_SLS)*/
2017
2018
398k
bail:
2019
2020
  /* error in renderer part occurred, ErrorStatus was set to invalid output */
2021
398k
  if (fEndAuNotAdjusted && !IS_OUTPUT_VALID(ErrorStatus) &&
2022
2
      (accessUnit < numPrerollAU)) {
2023
2
    transportDec_EndAccessUnit(self->hInput);
2024
2
  }
2025
2026
  /* Update Statistics */
2027
398k
  aacDecoder_UpdateBitStreamCounters(&self->streamInfo, hBs, nBits,
2028
398k
                                     ErrorStatus);
2029
398k
  if (((self->streamInfo.numChannels <= 0) ||
2030
387k
       (self->streamInfo.frameSize <= 0) ||
2031
387k
       (self->streamInfo.sampleRate <= 0)) &&
2032
11.3k
      IS_OUTPUT_VALID(ErrorStatus)) {
2033
    /* Ensure consistency of IS_OUTPUT_VALID() macro. */
2034
0
    ErrorStatus = AAC_DEC_UNKNOWN;
2035
0
  }
2036
2037
398k
  if (!IS_OUTPUT_VALID(ErrorStatus)) {
2038
19.4k
    FDKmemclear(pTimeData, timeDataSize * sizeof(*pTimeData));
2039
19.4k
  }
2040
2041
398k
  return ErrorStatus;
2042
378k
}
2043
2044
24.0k
LINKSPEC_CPP void aacDecoder_Close(HANDLE_AACDECODER self) {
2045
24.0k
  if (self == NULL) return;
2046
2047
24.0k
  if (self->hLimiter != NULL) {
2048
24.0k
    pcmLimiter_Destroy(self->hLimiter);
2049
24.0k
  }
2050
2051
24.0k
  if (self->hPcmUtils != NULL) {
2052
24.0k
    pcmDmx_Close(&self->hPcmUtils);
2053
24.0k
  }
2054
2055
24.0k
  FDK_drcDec_Close(&self->hUniDrcDecoder);
2056
2057
24.0k
  if (self->pMpegSurroundDecoder != NULL) {
2058
24.0k
    mpegSurroundDecoder_Close(
2059
24.0k
        (CMpegSurroundDecoder *)self->pMpegSurroundDecoder);
2060
24.0k
  }
2061
2062
24.0k
  if (self->hSbrDecoder != NULL) {
2063
24.0k
    sbrDecoder_Close(&self->hSbrDecoder);
2064
24.0k
  }
2065
2066
24.0k
  if (self->hInput != NULL) {
2067
24.0k
    transportDec_Close(&self->hInput);
2068
24.0k
  }
2069
2070
24.0k
  CAacDecoder_Close(self);
2071
24.0k
}
2072
2073
0
LINKSPEC_CPP CStreamInfo *aacDecoder_GetStreamInfo(HANDLE_AACDECODER self) {
2074
0
  return CAacDecoder_GetStreamInfo(self);
2075
0
}
2076
2077
0
LINKSPEC_CPP INT aacDecoder_GetLibInfo(LIB_INFO *info) {
2078
0
  int i;
2079
2080
0
  if (info == NULL) {
2081
0
    return -1;
2082
0
  }
2083
2084
0
  sbrDecoder_GetLibInfo(info);
2085
0
  mpegSurroundDecoder_GetLibInfo(info);
2086
0
  transportDec_GetLibInfo(info);
2087
0
  FDK_toolsGetLibInfo(info);
2088
0
  pcmDmx_GetLibInfo(info);
2089
0
  pcmLimiter_GetLibInfo(info);
2090
0
  FDK_drcDec_GetLibInfo(info);
2091
2092
  /* search for next free tab */
2093
0
  for (i = 0; i < FDK_MODULE_LAST; i++) {
2094
0
    if (info[i].module_id == FDK_NONE) break;
2095
0
  }
2096
0
  if (i == FDK_MODULE_LAST) {
2097
0
    return -1;
2098
0
  }
2099
0
  info += i;
2100
2101
0
  info->module_id = FDK_AACDEC;
2102
  /* build own library info */
2103
0
  info->version =
2104
0
      LIB_VERSION(AACDECODER_LIB_VL0, AACDECODER_LIB_VL1, AACDECODER_LIB_VL2);
2105
0
  LIB_VERSION_STRING(info);
2106
0
  info->build_date = AACDECODER_LIB_BUILD_DATE;
2107
0
  info->build_time = AACDECODER_LIB_BUILD_TIME;
2108
0
  info->title = AACDECODER_LIB_TITLE;
2109
2110
  /* Set flags */
2111
0
  info->flags = 0 | CAPF_AAC_LC | CAPF_ER_AAC_LC | CAPF_ER_AAC_SCAL |
2112
0
                CAPF_AAC_VCB11 | CAPF_AAC_HCR | CAPF_AAC_RVLC | CAPF_ER_AAC_LD |
2113
0
                CAPF_ER_AAC_ELD | CAPF_AAC_CONCEALMENT | CAPF_AAC_DRC |
2114
0
                CAPF_AAC_MPEG4 | CAPF_AAC_DRM_BSFORMAT | CAPF_AAC_1024 |
2115
0
                CAPF_AAC_960 | CAPF_AAC_512 | CAPF_AAC_480 |
2116
0
                CAPF_AAC_ELD_DOWNSCALE
2117
2118
0
                | CAPF_AAC_USAC | CAPF_ER_AAC_ELDV2 | CAPF_AAC_UNIDRC;
2119
  /* End of flags */
2120
2121
0
  return 0;
2122
0
}