Coverage Report

Created: 2025-12-14 06:45

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/aac/libSBRdec/src/sbrdecoder.cpp
Line
Count
Source
1
/* -----------------------------------------------------------------------------
2
Software License for The Fraunhofer FDK AAC Codec Library for Android
3
4
© Copyright  1995 - 2021 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
/**************************** SBR decoder library ******************************
96
97
   Author(s):
98
99
   Description:
100
101
*******************************************************************************/
102
103
/*!
104
  \file
105
  \brief  SBR decoder frontend
106
  This module provides a frontend to the SBR decoder. The function openSBR() is
107
  called for initialization. The function sbrDecoder_Apply() is called for each
108
  frame. sbr_Apply() will call the required functions to decode the raw SBR data
109
  (provided by env_extr.cpp), to decode the envelope data and noise floor levels
110
  [decodeSbrData()], and to finally apply SBR to the current frame [sbr_dec()].
111
112
  \sa sbrDecoder_Apply(), \ref documentationOverview
113
*/
114
115
/*!
116
  \page documentationOverview Overview of important information resources and
117
  source code documentation
118
119
  As part of this documentation you can find more extensive descriptions about
120
  key concepts and algorithms at the following locations:
121
122
  <h2>Programming</h2>
123
124
  \li Buffer management: sbrDecoder_Apply() and sbr_dec()
125
  \li Internal scale factors to maximize SNR on fixed point processors:
126
  #QMF_SCALE_FACTOR \li Special mantissa-exponent format: Created in
127
  requantizeEnvelopeData() and used in calculateSbrEnvelope()
128
129
  <h2>Algorithmic details</h2>
130
  \li About the SBR data format: \ref SBR_HEADER_ELEMENT and \ref
131
  SBR_STANDARD_ELEMENT \li Details about the bitstream decoder: env_extr.cpp \li
132
  Details about the QMF filterbank and the provided polyphase implementation:
133
  qmf_dec.cpp \li Details about the transposer: lpp_tran.cpp \li Details about
134
  the envelope adjuster: env_calc.cpp
135
136
*/
137
138
#include "sbrdecoder.h"
139
140
#include "FDK_bitstream.h"
141
142
#include "sbrdec_freq_sca.h"
143
#include "env_extr.h"
144
#include "sbr_dec.h"
145
#include "env_dec.h"
146
#include "FDK_crc.h"
147
#include "sbr_ram.h"
148
#include "sbr_rom.h"
149
#include "lpp_tran.h"
150
#include "transcendent.h"
151
152
#include "sbrdec_drc.h"
153
154
#include "psbitdec.h"
155
156
/* Decoder library info */
157
#define SBRDECODER_LIB_VL0 3
158
#define SBRDECODER_LIB_VL1 1
159
#define SBRDECODER_LIB_VL2 0
160
0
#define SBRDECODER_LIB_TITLE "SBR Decoder"
161
#ifdef SUPPRESS_BUILD_DATE_INFO
162
#define SBRDECODER_LIB_BUILD_DATE ""
163
#define SBRDECODER_LIB_BUILD_TIME ""
164
#else
165
0
#define SBRDECODER_LIB_BUILD_DATE __DATE__
166
0
#define SBRDECODER_LIB_BUILD_TIME __TIME__
167
#endif
168
169
529k
static void setFrameErrorFlag(SBR_DECODER_ELEMENT *pSbrElement, UCHAR value) {
170
529k
  if (pSbrElement != NULL) {
171
529k
    switch (value) {
172
130k
      case FRAME_ERROR_ALLSLOTS:
173
130k
        FDKmemset(pSbrElement->frameErrorFlag, FRAME_ERROR,
174
130k
                  sizeof(pSbrElement->frameErrorFlag));
175
130k
        break;
176
399k
      default:
177
399k
        pSbrElement->frameErrorFlag[pSbrElement->useFrameSlot] = value;
178
529k
    }
179
529k
  }
180
529k
}
181
182
690k
static UCHAR getHeaderSlot(UCHAR currentSlot, UCHAR hdrSlotUsage[(1) + 1]) {
183
690k
  UINT occupied = 0;
184
690k
  int s;
185
690k
  UCHAR slot = hdrSlotUsage[currentSlot];
186
187
690k
  FDK_ASSERT((1) + 1 < 32);
188
189
1.85M
  for (s = 0; s < (1) + 1; s++) {
190
1.35M
    if ((hdrSlotUsage[s] == slot) && (s != slot)) {
191
190k
      occupied = 1;
192
190k
      break;
193
190k
    }
194
1.35M
  }
195
196
690k
  if (occupied) {
197
190k
    occupied = 0;
198
199
572k
    for (s = 0; s < (1) + 1; s++) {
200
381k
      occupied |= 1 << hdrSlotUsage[s];
201
381k
    }
202
354k
    for (s = 0; s < (1) + 1; s++) {
203
353k
      if (!(occupied & 0x1)) {
204
189k
        slot = s;
205
189k
        break;
206
189k
      }
207
163k
      occupied >>= 1;
208
163k
    }
209
190k
  }
210
211
690k
  return slot;
212
690k
}
213
214
static void copySbrHeader(HANDLE_SBR_HEADER_DATA hDst,
215
39.0k
                          const HANDLE_SBR_HEADER_DATA hSrc) {
216
  /* copy the whole header memory (including pointers) */
217
39.0k
  FDKmemcpy(hDst, hSrc, sizeof(SBR_HEADER_DATA));
218
219
  /* update pointers */
220
39.0k
  hDst->freqBandData.freqBandTable[0] = hDst->freqBandData.freqBandTableLo;
221
39.0k
  hDst->freqBandData.freqBandTable[1] = hDst->freqBandData.freqBandTableHi;
222
39.0k
}
223
224
static int compareSbrHeader(const HANDLE_SBR_HEADER_DATA hHdr1,
225
7.23k
                            const HANDLE_SBR_HEADER_DATA hHdr2) {
226
7.23k
  int result = 0;
227
228
  /* compare basic data */
229
7.23k
  result |= (hHdr1->syncState != hHdr2->syncState) ? 1 : 0;
230
7.23k
  result |= (hHdr1->status != hHdr2->status) ? 1 : 0;
231
7.23k
  result |= (hHdr1->frameErrorFlag != hHdr2->frameErrorFlag) ? 1 : 0;
232
7.23k
  result |= (hHdr1->numberTimeSlots != hHdr2->numberTimeSlots) ? 1 : 0;
233
7.23k
  result |=
234
7.23k
      (hHdr1->numberOfAnalysisBands != hHdr2->numberOfAnalysisBands) ? 1 : 0;
235
7.23k
  result |= (hHdr1->timeStep != hHdr2->timeStep) ? 1 : 0;
236
7.23k
  result |= (hHdr1->sbrProcSmplRate != hHdr2->sbrProcSmplRate) ? 1 : 0;
237
238
  /* compare bitstream data */
239
7.23k
  result |=
240
7.23k
      FDKmemcmp(&hHdr1->bs_data, &hHdr2->bs_data, sizeof(SBR_HEADER_DATA_BS));
241
7.23k
  result |=
242
7.23k
      FDKmemcmp(&hHdr1->bs_dflt, &hHdr2->bs_dflt, sizeof(SBR_HEADER_DATA_BS));
243
7.23k
  result |= FDKmemcmp(&hHdr1->bs_info, &hHdr2->bs_info,
244
7.23k
                      sizeof(SBR_HEADER_DATA_BS_INFO));
245
246
  /* compare frequency band data */
247
7.23k
  result |= FDKmemcmp(&hHdr1->freqBandData, &hHdr2->freqBandData,
248
7.23k
                      (8 + MAX_NUM_LIMITERS + 1) * sizeof(UCHAR));
249
7.23k
  result |= FDKmemcmp(hHdr1->freqBandData.freqBandTableLo,
250
7.23k
                      hHdr2->freqBandData.freqBandTableLo,
251
7.23k
                      (MAX_FREQ_COEFFS / 2 + 1) * sizeof(UCHAR));
252
7.23k
  result |= FDKmemcmp(hHdr1->freqBandData.freqBandTableHi,
253
7.23k
                      hHdr2->freqBandData.freqBandTableHi,
254
7.23k
                      (MAX_FREQ_COEFFS + 1) * sizeof(UCHAR));
255
7.23k
  result |= FDKmemcmp(hHdr1->freqBandData.freqBandTableNoise,
256
7.23k
                      hHdr2->freqBandData.freqBandTableNoise,
257
7.23k
                      (MAX_NOISE_COEFFS + 1) * sizeof(UCHAR));
258
7.23k
  result |=
259
7.23k
      FDKmemcmp(hHdr1->freqBandData.v_k_master, hHdr2->freqBandData.v_k_master,
260
7.23k
                (MAX_FREQ_COEFFS + 1) * sizeof(UCHAR));
261
262
7.23k
  return result;
263
7.23k
}
264
265
/*!
266
  \brief Reset SBR decoder.
267
268
  Reset should only be called if SBR has been sucessfully detected by
269
  an appropriate checkForPayload() function.
270
271
  \return Error code.
272
*/
273
static SBR_ERROR sbrDecoder_ResetElement(HANDLE_SBRDECODER self,
274
                                         int sampleRateIn, int sampleRateOut,
275
                                         int samplesPerFrame,
276
                                         const MP4_ELEMENT_ID elementID,
277
                                         const int elementIndex,
278
101k
                                         const int overlap) {
279
101k
  SBR_ERROR sbrError = SBRDEC_OK;
280
101k
  HANDLE_SBR_HEADER_DATA hSbrHeader;
281
101k
  UINT qmfFlags = 0;
282
283
101k
  int i, synDownsampleFac;
284
285
  /* USAC: assuming theoretical case 8 kHz output sample rate with 4:1 SBR */
286
101k
  const int sbr_min_sample_rate_in = IS_USAC(self->coreCodec) ? 2000 : 6400;
287
288
  /* Check in/out samplerates */
289
101k
  if (sampleRateIn < sbr_min_sample_rate_in || sampleRateIn > (96000)) {
290
605
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
291
605
    goto bail;
292
605
  }
293
294
100k
  if (sampleRateOut > (96000)) {
295
205
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
296
205
    goto bail;
297
205
  }
298
299
  /* Set QMF mode flags */
300
100k
  if (self->flags & SBRDEC_LOW_POWER) qmfFlags |= QMF_FLAG_LP;
301
302
100k
  if (self->coreCodec == AOT_ER_AAC_ELD) {
303
55.9k
    if (self->flags & SBRDEC_LD_MPS_QMF) {
304
0
      qmfFlags |= QMF_FLAG_MPSLDFB;
305
55.9k
    } else {
306
55.9k
      qmfFlags |= QMF_FLAG_CLDFB;
307
55.9k
    }
308
55.9k
  }
309
310
  /* Set downsampling factor for synthesis filter bank */
311
100k
  if (sampleRateOut == 0) {
312
    /* no single rate mode */
313
5.52k
    sampleRateOut =
314
5.52k
        sampleRateIn
315
5.52k
        << 1; /* In case of implicit signalling, assume dual rate SBR */
316
5.52k
  }
317
318
100k
  if (sampleRateIn == sampleRateOut) {
319
39.6k
    synDownsampleFac = 2;
320
39.6k
    self->flags |= SBRDEC_DOWNSAMPLE;
321
60.9k
  } else {
322
60.9k
    synDownsampleFac = 1;
323
60.9k
    self->flags &= ~SBRDEC_DOWNSAMPLE;
324
60.9k
  }
325
326
100k
  self->synDownsampleFac = synDownsampleFac;
327
100k
  self->sampleRateOut = sampleRateOut;
328
329
100k
  {
330
301k
    for (i = 0; i < (1) + 1; i++) {
331
201k
      int setDflt;
332
201k
      hSbrHeader = &(self->sbrHeader[elementIndex][i]);
333
201k
      setDflt = ((hSbrHeader->syncState == SBR_NOT_INITIALIZED) ||
334
1.34k
                 (self->flags & SBRDEC_FORCE_RESET))
335
201k
                    ? 1
336
201k
                    : 0;
337
338
      /* init a default header such that we can at least do upsampling later */
339
201k
      sbrError = initHeaderData(hSbrHeader, sampleRateIn, sampleRateOut,
340
201k
                                self->downscaleFactor, samplesPerFrame,
341
201k
                                self->flags, setDflt);
342
343
      /* Set synchState to UPSAMPLING in case it already is initialized */
344
201k
      hSbrHeader->syncState = hSbrHeader->syncState > UPSAMPLING
345
201k
                                  ? UPSAMPLING
346
201k
                                  : hSbrHeader->syncState;
347
201k
    }
348
100k
  }
349
350
100k
  if (sbrError != SBRDEC_OK) {
351
54
    goto bail;
352
54
  }
353
354
100k
  if (!self->pQmfDomain->globalConf.qmfDomainExplicitConfig) {
355
100k
    self->pQmfDomain->globalConf.flags_requested |= qmfFlags;
356
100k
    self->pQmfDomain->globalConf.nBandsAnalysis_requested =
357
100k
        self->sbrHeader[elementIndex][0].numberOfAnalysisBands;
358
100k
    self->pQmfDomain->globalConf.nBandsSynthesis_requested =
359
100k
        (synDownsampleFac == 1) ? 64 : 32; /* may be overwritten by MPS */
360
100k
    self->pQmfDomain->globalConf.nBandsSynthesis_requested /=
361
100k
        self->downscaleFactor;
362
100k
    self->pQmfDomain->globalConf.nQmfTimeSlots_requested =
363
100k
        self->sbrHeader[elementIndex][0].numberTimeSlots *
364
100k
        self->sbrHeader[elementIndex][0].timeStep;
365
100k
    self->pQmfDomain->globalConf.nQmfOvTimeSlots_requested = overlap;
366
100k
    self->pQmfDomain->globalConf.nQmfProcBands_requested = 64; /* always 64 */
367
100k
    self->pQmfDomain->globalConf.nQmfProcChannels_requested =
368
100k
        1; /* may be overwritten by MPS */
369
100k
  }
370
371
  /* Init SBR channels going to be assigned to a SBR element */
372
100k
  {
373
100k
    int ch;
374
257k
    for (ch = 0; ch < self->pSbrElement[elementIndex]->nChannels; ch++) {
375
158k
      int headerIndex =
376
158k
          getHeaderSlot(self->pSbrElement[elementIndex]->useFrameSlot,
377
158k
                        self->pSbrElement[elementIndex]->useHeaderSlot);
378
379
      /* and create sbrDec */
380
158k
      sbrError =
381
158k
          createSbrDec(self->pSbrElement[elementIndex]->pSbrChannel[ch],
382
158k
                       &self->sbrHeader[elementIndex][headerIndex],
383
158k
                       &self->pSbrElement[elementIndex]->transposerSettings,
384
158k
                       synDownsampleFac, qmfFlags, self->flags, overlap, ch,
385
158k
                       self->codecFrameSize);
386
387
158k
      if (sbrError != SBRDEC_OK) {
388
1.31k
        goto bail;
389
1.31k
      }
390
158k
    }
391
100k
  }
392
393
  // FDKmemclear(sbr_OverlapBuffer, sizeof(sbr_OverlapBuffer));
394
395
99.2k
  if (self->numSbrElements == 1) {
396
60.5k
    switch (self->coreCodec) {
397
1.24k
      case AOT_AAC_LC:
398
1.24k
      case AOT_SBR:
399
1.24k
      case AOT_PS:
400
4.73k
      case AOT_ER_AAC_SCAL:
401
4.73k
      case AOT_DRM_AAC:
402
4.73k
      case AOT_DRM_SURROUND:
403
4.73k
        if (CreatePsDec(&self->hParametricStereoDec, samplesPerFrame)) {
404
0
          sbrError = SBRDEC_CREATE_ERROR;
405
0
          goto bail;
406
0
        }
407
4.73k
        break;
408
55.8k
      default:
409
55.8k
        break;
410
60.5k
    }
411
60.5k
  }
412
413
  /* Init frame delay slot handling */
414
99.2k
  self->pSbrElement[elementIndex]->useFrameSlot = 0;
415
297k
  for (i = 0; i < ((1) + 1); i++) {
416
198k
    self->pSbrElement[elementIndex]->useHeaderSlot[i] = i;
417
198k
  }
418
419
101k
bail:
420
421
101k
  return sbrError;
422
99.2k
}
423
424
/*!
425
  \brief Assign QMF domain provided QMF channels to SBR channels.
426
427
  \return void
428
*/
429
101k
static void sbrDecoder_AssignQmfChannels2SbrChannels(HANDLE_SBRDECODER self) {
430
101k
  int ch, el, absCh_offset = 0;
431
295k
  for (el = 0; el < self->numSbrElements; el++) {
432
194k
    if (self->pSbrElement[el] != NULL) {
433
497k
      for (ch = 0; ch < self->pSbrElement[el]->nChannels; ch++) {
434
303k
        FDK_ASSERT(((absCh_offset + ch) < ((8) + (1))) &&
435
303k
                   ((absCh_offset + ch) < ((8) + (1))));
436
303k
        self->pSbrElement[el]->pSbrChannel[ch]->SbrDec.qmfDomainInCh =
437
303k
            &self->pQmfDomain->QmfDomainIn[absCh_offset + ch];
438
303k
        self->pSbrElement[el]->pSbrChannel[ch]->SbrDec.qmfDomainOutCh =
439
303k
            &self->pQmfDomain->QmfDomainOut[absCh_offset + ch];
440
303k
      }
441
194k
      absCh_offset += self->pSbrElement[el]->nChannels;
442
194k
    }
443
194k
  }
444
101k
}
445
446
SBR_ERROR sbrDecoder_Open(HANDLE_SBRDECODER *pSelf,
447
29.6k
                          HANDLE_FDK_QMF_DOMAIN pQmfDomain) {
448
29.6k
  HANDLE_SBRDECODER self = NULL;
449
29.6k
  SBR_ERROR sbrError = SBRDEC_OK;
450
29.6k
  int elIdx;
451
452
29.6k
  if ((pSelf == NULL) || (pQmfDomain == NULL)) {
453
0
    return SBRDEC_INVALID_ARGUMENT;
454
0
  }
455
456
  /* Get memory for this instance */
457
29.6k
  self = GetRam_SbrDecoder();
458
29.6k
  if (self == NULL) {
459
0
    sbrError = SBRDEC_MEM_ALLOC_FAILED;
460
0
    goto bail;
461
0
  }
462
463
29.6k
  self->pQmfDomain = pQmfDomain;
464
465
  /*
466
  Already zero because of calloc
467
  self->numSbrElements = 0;
468
  self->numSbrChannels = 0;
469
  self->codecFrameSize = 0;
470
  */
471
472
29.6k
  self->numDelayFrames = (1); /* set to the max value by default */
473
474
  /* Initialize header sync state */
475
266k
  for (elIdx = 0; elIdx < (8); elIdx += 1) {
476
237k
    int i;
477
711k
    for (i = 0; i < (1) + 1; i += 1) {
478
474k
      self->sbrHeader[elIdx][i].syncState = SBR_NOT_INITIALIZED;
479
474k
    }
480
237k
  }
481
482
29.6k
  *pSelf = self;
483
484
29.6k
bail:
485
29.6k
  return sbrError;
486
29.6k
}
487
488
/**
489
 * \brief determine if the given core codec AOT can be processed or not.
490
 * \param coreCodec core codec audio object type.
491
 * \return 1 if SBR can be processed, 0 if SBR cannot be processed/applied.
492
 */
493
1.29M
static int sbrDecoder_isCoreCodecValid(AUDIO_OBJECT_TYPE coreCodec) {
494
1.29M
  switch (coreCodec) {
495
12.1k
    case AOT_AAC_LC:
496
12.1k
    case AOT_SBR:
497
12.1k
    case AOT_PS:
498
70.9k
    case AOT_ER_AAC_SCAL:
499
922k
    case AOT_ER_AAC_ELD:
500
922k
    case AOT_DRM_AAC:
501
922k
    case AOT_DRM_SURROUND:
502
1.29M
    case AOT_USAC:
503
1.29M
      return 1;
504
829
    default:
505
829
      return 0;
506
1.29M
  }
507
1.29M
}
508
509
static void sbrDecoder_DestroyElement(HANDLE_SBRDECODER self,
510
1.38M
                                      const int elementIndex) {
511
1.38M
  if (self->pSbrElement[elementIndex] != NULL) {
512
100k
    int ch;
513
514
302k
    for (ch = 0; ch < SBRDEC_MAX_CH_PER_ELEMENT; ch++) {
515
201k
      if (self->pSbrElement[elementIndex]->pSbrChannel[ch] != NULL) {
516
159k
        deleteSbrDec(self->pSbrElement[elementIndex]->pSbrChannel[ch]);
517
159k
        FreeRam_SbrDecChannel(
518
159k
            &self->pSbrElement[elementIndex]->pSbrChannel[ch]);
519
159k
        self->numSbrChannels -= 1;
520
159k
      }
521
201k
    }
522
100k
    FreeRam_SbrDecElement(&self->pSbrElement[elementIndex]);
523
100k
    self->numSbrElements -= 1;
524
100k
  }
525
1.38M
}
526
527
SBR_ERROR sbrDecoder_InitElement(
528
    HANDLE_SBRDECODER self, const int sampleRateIn, const int sampleRateOut,
529
    const int samplesPerFrame, const AUDIO_OBJECT_TYPE coreCodec,
530
    const MP4_ELEMENT_ID elementID, const int elementIndex,
531
    const UCHAR harmonicSBR, const UCHAR stereoConfigIndex,
532
729k
    const UCHAR configMode, UCHAR *configChanged, const INT downscaleFactor) {
533
729k
  SBR_ERROR sbrError = SBRDEC_OK;
534
729k
  int chCnt = 0;
535
729k
  int nSbrElementsStart;
536
729k
  int nSbrChannelsStart;
537
729k
  if (self == NULL) {
538
0
    return SBRDEC_INVALID_ARGUMENT;
539
0
  }
540
541
729k
  nSbrElementsStart = self->numSbrElements;
542
729k
  nSbrChannelsStart = self->numSbrChannels;
543
544
  /* Check core codec AOT */
545
729k
  if (!sbrDecoder_isCoreCodecValid(coreCodec) || elementIndex >= (8)) {
546
829
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
547
829
    goto bail;
548
829
  }
549
550
728k
  if (elementID != ID_SCE && elementID != ID_CPE && elementID != ID_LFE) {
551
0
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
552
0
    goto bail;
553
0
  }
554
555
728k
  if (self->sampleRateIn == sampleRateIn &&
556
622k
      self->codecFrameSize == samplesPerFrame && self->coreCodec == coreCodec &&
557
584k
      self->pSbrElement[elementIndex] != NULL &&
558
524k
      self->pSbrElement[elementIndex]->elementID == elementID &&
559
520k
      !(self->flags & SBRDEC_FORCE_RESET) &&
560
520k
      ((sampleRateOut == 0) ? 1 : (self->sampleRateOut == sampleRateOut)) &&
561
513k
      ((harmonicSBR == 2) ? 1
562
513k
                          : (self->harmonicSBR ==
563
356k
                             harmonicSBR)) /* The value 2 signalizes that
564
                                              harmonicSBR shall be ignored in
565
                                              the config change detection */
566
728k
  ) {
567
    /* Nothing to do */
568
509k
    return SBRDEC_OK;
569
509k
  } else {
570
219k
    if (configMode & AC_CM_DET_CFG_CHANGE) {
571
118k
      *configChanged = 1;
572
118k
    }
573
219k
  }
574
575
  /* reaching this point the SBR-decoder gets (re-)configured */
576
577
  /* The flags field is used for all elements! */
578
219k
  self->flags &=
579
219k
      (SBRDEC_FORCE_RESET | SBRDEC_FLUSH); /* Keep the global flags. They will
580
                                              be reset after decoding. */
581
219k
  self->flags |= (downscaleFactor > 1) ? SBRDEC_ELD_DOWNSCALE : 0;
582
219k
  self->flags |= (coreCodec == AOT_ER_AAC_ELD) ? SBRDEC_ELD_GRID : 0;
583
219k
  self->flags |= (coreCodec == AOT_ER_AAC_SCAL) ? SBRDEC_SYNTAX_SCAL : 0;
584
219k
  self->flags |=
585
219k
      (coreCodec == AOT_DRM_AAC) ? SBRDEC_SYNTAX_SCAL | SBRDEC_SYNTAX_DRM : 0;
586
219k
  self->flags |= (coreCodec == AOT_DRM_SURROUND)
587
219k
                     ? SBRDEC_SYNTAX_SCAL | SBRDEC_SYNTAX_DRM
588
219k
                     : 0;
589
219k
  self->flags |= (coreCodec == AOT_USAC) ? SBRDEC_SYNTAX_USAC : 0;
590
  /* Robustness: Take integer division rounding into consideration. E.g. 22050
591
   * Hz with 4:1 SBR => 5512 Hz core sampling rate. */
592
219k
  self->flags |= (sampleRateIn == sampleRateOut / 4) ? SBRDEC_QUAD_RATE : 0;
593
219k
  self->flags |= (harmonicSBR == 1) ? SBRDEC_USAC_HARMONICSBR : 0;
594
595
219k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
596
118k
    return SBRDEC_OK;
597
118k
  }
598
599
101k
  self->sampleRateIn = sampleRateIn;
600
101k
  self->codecFrameSize = samplesPerFrame;
601
101k
  self->coreCodec = coreCodec;
602
101k
  self->harmonicSBR = harmonicSBR;
603
101k
  self->downscaleFactor = downscaleFactor;
604
605
  /* Init SBR elements */
606
101k
  {
607
101k
    int elChannels, ch;
608
609
101k
    if (self->pSbrElement[elementIndex] == NULL) {
610
100k
      self->pSbrElement[elementIndex] = GetRam_SbrDecElement(elementIndex);
611
100k
      if (self->pSbrElement[elementIndex] == NULL) {
612
0
        sbrError = SBRDEC_MEM_ALLOC_FAILED;
613
0
        goto bail;
614
0
      }
615
100k
      self->numSbrElements++;
616
100k
    } else {
617
729
      self->numSbrChannels -= self->pSbrElement[elementIndex]->nChannels;
618
729
    }
619
620
    /* Determine amount of channels for this element */
621
101k
    switch (elementID) {
622
0
      case ID_NONE:
623
56.0k
      case ID_CPE:
624
56.0k
        elChannels = 2;
625
56.0k
        break;
626
8.93k
      case ID_LFE:
627
45.3k
      case ID_SCE:
628
45.3k
        elChannels = 1;
629
45.3k
        break;
630
0
      default:
631
0
        elChannels = 0;
632
0
        break;
633
101k
    }
634
635
    /* Handle case of Parametric Stereo */
636
101k
    if (elementIndex == 0 && elementID == ID_SCE) {
637
33.4k
      switch (coreCodec) {
638
1.20k
        case AOT_AAC_LC:
639
1.20k
        case AOT_SBR:
640
1.20k
        case AOT_PS:
641
3.59k
        case AOT_ER_AAC_SCAL:
642
3.59k
        case AOT_DRM_AAC:
643
3.59k
        case AOT_DRM_SURROUND:
644
3.59k
          elChannels = 2;
645
3.59k
          break;
646
29.8k
        default:
647
29.8k
          break;
648
33.4k
      }
649
33.4k
    }
650
651
    /* Sanity check to avoid memory leaks */
652
101k
    if (elChannels < self->pSbrElement[elementIndex]->nChannels ||
653
101k
        (self->numSbrChannels + elChannels) > (8) + (1)) {
654
0
      self->numSbrChannels += self->pSbrElement[elementIndex]->nChannels;
655
0
      sbrError = SBRDEC_PARSE_ERROR;
656
0
      goto bail;
657
0
    }
658
659
    /* Save element ID for sanity checks and to have a fallback for concealment.
660
     */
661
101k
    self->pSbrElement[elementIndex]->elementID = elementID;
662
101k
    self->pSbrElement[elementIndex]->nChannels = elChannels;
663
664
262k
    for (ch = 0; ch < elChannels; ch++) {
665
161k
      if (self->pSbrElement[elementIndex]->pSbrChannel[ch] == NULL) {
666
159k
        self->pSbrElement[elementIndex]->pSbrChannel[ch] =
667
159k
            GetRam_SbrDecChannel(chCnt);
668
159k
        if (self->pSbrElement[elementIndex]->pSbrChannel[ch] == NULL) {
669
0
          sbrError = SBRDEC_MEM_ALLOC_FAILED;
670
0
          goto bail;
671
0
        }
672
159k
      }
673
161k
      self->numSbrChannels++;
674
675
161k
      sbrDecoder_drcInitChannel(&self->pSbrElement[elementIndex]
676
161k
                                     ->pSbrChannel[ch]
677
161k
                                     ->SbrDec.sbrDrcChannel);
678
679
161k
      chCnt++;
680
161k
    }
681
101k
  }
682
683
101k
  if (!self->pQmfDomain->globalConf.qmfDomainExplicitConfig) {
684
101k
    self->pQmfDomain->globalConf.nInputChannels_requested =
685
101k
        self->numSbrChannels;
686
101k
    self->pQmfDomain->globalConf.nOutputChannels_requested =
687
101k
        fMax((INT)self->numSbrChannels,
688
101k
             (INT)self->pQmfDomain->globalConf.nOutputChannels_requested);
689
101k
  }
690
691
  /* Make sure each SBR channel has one QMF channel assigned even if
692
   * numSbrChannels or element set-up has changed. */
693
101k
  sbrDecoder_AssignQmfChannels2SbrChannels(self);
694
695
  /* clear error flags for all delay slots */
696
101k
  FDKmemclear(self->pSbrElement[elementIndex]->frameErrorFlag,
697
101k
              ((1) + 1) * sizeof(UCHAR));
698
699
101k
  {
700
101k
    int overlap;
701
702
101k
    if (coreCodec == AOT_ER_AAC_ELD) {
703
56.3k
      overlap = 0;
704
56.3k
    } else if (self->flags & SBRDEC_QUAD_RATE) {
705
8.75k
      overlap = (3 * 4);
706
36.2k
    } else {
707
36.2k
      overlap = (3 * 2);
708
36.2k
    }
709
    /* Initialize this instance */
710
101k
    sbrError = sbrDecoder_ResetElement(self, sampleRateIn, sampleRateOut,
711
101k
                                       samplesPerFrame, elementID, elementIndex,
712
101k
                                       overlap);
713
101k
  }
714
715
102k
bail:
716
102k
  if (sbrError != SBRDEC_OK) {
717
3.00k
    if ((nSbrElementsStart < self->numSbrElements) ||
718
2.17k
        (nSbrChannelsStart < self->numSbrChannels)) {
719
      /* Free the memory allocated for this element */
720
2.17k
      sbrDecoder_DestroyElement(self, elementIndex);
721
2.17k
    } else if ((elementIndex < (8)) &&
722
829
               (self->pSbrElement[elementIndex] !=
723
829
                NULL)) { /* Set error flag to trigger concealment */
724
0
      setFrameErrorFlag(self->pSbrElement[elementIndex], FRAME_ERROR);
725
0
    }
726
3.00k
  }
727
728
102k
  return sbrError;
729
101k
}
730
731
/**
732
 * \brief Free config dependent SBR memory.
733
 * \param self SBR decoder instance handle
734
 */
735
142k
SBR_ERROR sbrDecoder_FreeMem(HANDLE_SBRDECODER *self) {
736
142k
  int i;
737
142k
  int elIdx;
738
739
142k
  if (self != NULL && *self != NULL) {
740
1.28M
    for (i = 0; i < (8); i++) {
741
1.14M
      sbrDecoder_DestroyElement(*self, i);
742
1.14M
    }
743
744
1.28M
    for (elIdx = 0; elIdx < (8); elIdx += 1) {
745
3.42M
      for (i = 0; i < (1) + 1; i += 1) {
746
2.28M
        (*self)->sbrHeader[elIdx][i].syncState = SBR_NOT_INITIALIZED;
747
2.28M
      }
748
1.14M
    }
749
142k
  }
750
751
142k
  return SBRDEC_OK;
752
142k
}
753
754
/**
755
 * \brief Apply decoded SBR header for one element.
756
 * \param self SBR decoder instance handle
757
 * \param hSbrHeader SBR header handle to be processed.
758
 * \param hSbrChannel pointer array to the SBR element channels corresponding to
759
 * the SBR header.
760
 * \param headerStatus header status value returned from SBR header parser.
761
 * \param numElementChannels amount of channels for the SBR element whos header
762
 * is to be processed.
763
 */
764
static SBR_ERROR sbrDecoder_HeaderUpdate(HANDLE_SBRDECODER self,
765
                                         HANDLE_SBR_HEADER_DATA hSbrHeader,
766
                                         SBR_HEADER_STATUS headerStatus,
767
                                         HANDLE_SBR_CHANNEL hSbrChannel[],
768
244k
                                         const int numElementChannels) {
769
244k
  SBR_ERROR errorStatus = SBRDEC_OK;
770
771
  /*
772
    change of control data, reset decoder
773
  */
774
244k
  errorStatus = resetFreqBandTables(hSbrHeader, self->flags);
775
776
244k
  if (errorStatus == SBRDEC_OK) {
777
213k
    if (hSbrHeader->syncState == UPSAMPLING && headerStatus != HEADER_RESET) {
778
#if (SBRDEC_MAX_HB_FADE_FRAMES > 0)
779
      int ch;
780
      for (ch = 0; ch < numElementChannels; ch += 1) {
781
        hSbrChannel[ch]->SbrDec.highBandFadeCnt = SBRDEC_MAX_HB_FADE_FRAMES;
782
      }
783
784
#endif
785
      /* As the default header would limit the frequency range,
786
         lowSubband and highSubband must be patched. */
787
42.4k
      hSbrHeader->freqBandData.lowSubband = hSbrHeader->numberOfAnalysisBands;
788
42.4k
      hSbrHeader->freqBandData.highSubband = hSbrHeader->numberOfAnalysisBands;
789
42.4k
    }
790
791
    /* Trigger a reset before processing this slot */
792
213k
    hSbrHeader->status |= SBRDEC_HDR_STAT_RESET;
793
213k
  }
794
795
244k
  return errorStatus;
796
244k
}
797
798
INT sbrDecoder_Header(HANDLE_SBRDECODER self, HANDLE_FDK_BITSTREAM hBs,
799
                      const INT sampleRateIn, const INT sampleRateOut,
800
                      const INT samplesPerFrame,
801
                      const AUDIO_OBJECT_TYPE coreCodec,
802
                      const MP4_ELEMENT_ID elementID, const INT elementIndex,
803
                      const UCHAR harmonicSBR, const UCHAR stereoConfigIndex,
804
                      const UCHAR configMode, UCHAR *configChanged,
805
565k
                      const INT downscaleFactor) {
806
565k
  SBR_HEADER_STATUS headerStatus;
807
565k
  HANDLE_SBR_HEADER_DATA hSbrHeader;
808
565k
  SBR_ERROR sbrError = SBRDEC_OK;
809
565k
  int headerIndex;
810
565k
  UINT flagsSaved =
811
565k
      0; /* flags should not be changed in AC_CM_DET_CFG_CHANGE - mode after
812
            parsing */
813
814
565k
  if (self == NULL || elementIndex >= (8)) {
815
0
    return SBRDEC_UNSUPPORTED_CONFIG;
816
0
  }
817
818
565k
  if (!sbrDecoder_isCoreCodecValid(coreCodec)) {
819
0
    return SBRDEC_UNSUPPORTED_CONFIG;
820
0
  }
821
822
565k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
823
356k
    flagsSaved = self->flags; /* store */
824
356k
  }
825
826
565k
  sbrError = sbrDecoder_InitElement(
827
565k
      self, sampleRateIn, sampleRateOut, samplesPerFrame, coreCodec, elementID,
828
565k
      elementIndex, harmonicSBR, stereoConfigIndex, configMode, configChanged,
829
565k
      downscaleFactor);
830
831
565k
  if ((sbrError != SBRDEC_OK) || (elementID == ID_LFE)) {
832
72.3k
    goto bail;
833
72.3k
  }
834
835
492k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
836
311k
    hSbrHeader = NULL;
837
311k
  } else {
838
181k
    headerIndex = getHeaderSlot(self->pSbrElement[elementIndex]->useFrameSlot,
839
181k
                                self->pSbrElement[elementIndex]->useHeaderSlot);
840
841
181k
    hSbrHeader = &(self->sbrHeader[elementIndex][headerIndex]);
842
181k
  }
843
844
492k
  headerStatus = sbrGetHeaderData(hSbrHeader, hBs, self->flags, 0, configMode);
845
846
492k
  if (coreCodec == AOT_USAC) {
847
184k
    if (configMode & AC_CM_DET_CFG_CHANGE) {
848
116k
      self->flags = flagsSaved; /* restore */
849
116k
    }
850
184k
    return sbrError;
851
184k
  }
852
853
308k
  if (configMode & AC_CM_ALLOC_MEM) {
854
113k
    SBR_DECODER_ELEMENT *pSbrElement;
855
856
113k
    pSbrElement = self->pSbrElement[elementIndex];
857
858
    /* Sanity check */
859
113k
    if (pSbrElement != NULL) {
860
113k
      if ((elementID == ID_CPE && pSbrElement->nChannels != 2) ||
861
113k
          (elementID != ID_CPE && pSbrElement->nChannels != 1)) {
862
0
        return SBRDEC_UNSUPPORTED_CONFIG;
863
0
      }
864
113k
      if (headerStatus == HEADER_RESET) {
865
76.3k
        sbrError = sbrDecoder_HeaderUpdate(self, hSbrHeader, headerStatus,
866
76.3k
                                           pSbrElement->pSbrChannel,
867
76.3k
                                           pSbrElement->nChannels);
868
869
76.3k
        if (sbrError == SBRDEC_OK) {
870
71.1k
          hSbrHeader->syncState = SBR_HEADER;
871
71.1k
          hSbrHeader->status |= SBRDEC_HDR_STAT_UPDATE;
872
71.1k
        } else {
873
5.21k
          hSbrHeader->syncState = SBR_NOT_INITIALIZED;
874
5.21k
          hSbrHeader->status = HEADER_ERROR;
875
5.21k
        }
876
76.3k
      }
877
113k
    }
878
113k
  }
879
381k
bail:
880
381k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
881
240k
    self->flags = flagsSaved; /* restore */
882
240k
  }
883
381k
  return sbrError;
884
308k
}
885
886
SBR_ERROR sbrDecoder_SetParam(HANDLE_SBRDECODER self, const SBRDEC_PARAM param,
887
1.56M
                              const INT value) {
888
1.56M
  SBR_ERROR errorStatus = SBRDEC_OK;
889
890
  /* configure the subsystems */
891
1.56M
  switch (param) {
892
378k
    case SBR_SYSTEM_BITSTREAM_DELAY:
893
378k
      if (value < 0 || value > (1)) {
894
0
        errorStatus = SBRDEC_SET_PARAM_FAIL;
895
0
        break;
896
0
      }
897
378k
      if (self == NULL) {
898
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
899
378k
      } else {
900
378k
        self->numDelayFrames = (UCHAR)value;
901
378k
      }
902
378k
      break;
903
486k
    case SBR_QMF_MODE:
904
486k
      if (self == NULL) {
905
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
906
486k
      } else {
907
486k
        if (value == 1) {
908
136k
          self->flags |= SBRDEC_LOW_POWER;
909
349k
        } else {
910
349k
          self->flags &= ~SBRDEC_LOW_POWER;
911
349k
        }
912
486k
      }
913
486k
      break;
914
34.9k
    case SBR_LD_QMF_TIME_ALIGN:
915
34.9k
      if (self == NULL) {
916
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
917
34.9k
      } else {
918
34.9k
        if (value == 1) {
919
2.28k
          self->flags |= SBRDEC_LD_MPS_QMF;
920
32.6k
        } else {
921
32.6k
          self->flags &= ~SBRDEC_LD_MPS_QMF;
922
32.6k
        }
923
34.9k
      }
924
34.9k
      break;
925
328k
    case SBR_FLUSH_DATA:
926
328k
      if (value != 0) {
927
27
        if (self == NULL) {
928
0
          errorStatus = SBRDEC_NOT_INITIALIZED;
929
27
        } else {
930
27
          self->flags |= SBRDEC_FLUSH;
931
27
        }
932
27
      }
933
328k
      break;
934
0
    case SBR_CLEAR_HISTORY:
935
0
      if (value != 0) {
936
0
        if (self == NULL) {
937
0
          errorStatus = SBRDEC_NOT_INITIALIZED;
938
0
        } else {
939
0
          self->flags |= SBRDEC_FORCE_RESET;
940
0
        }
941
0
      }
942
0
      break;
943
8.92k
    case SBR_BS_INTERRUPTION: {
944
8.92k
      int elementIndex;
945
946
8.92k
      if (self == NULL) {
947
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
948
0
        break;
949
0
      }
950
951
      /* Loop over SBR elements */
952
16.3k
      for (elementIndex = 0; elementIndex < self->numSbrElements;
953
8.92k
           elementIndex++) {
954
7.45k
        if (self->pSbrElement[elementIndex] != NULL) {
955
7.45k
          HANDLE_SBR_HEADER_DATA hSbrHeader;
956
7.45k
          int headerIndex =
957
7.45k
              getHeaderSlot(self->pSbrElement[elementIndex]->useFrameSlot,
958
7.45k
                            self->pSbrElement[elementIndex]->useHeaderSlot);
959
960
7.45k
          hSbrHeader = &(self->sbrHeader[elementIndex][headerIndex]);
961
962
          /* Set sync state UPSAMPLING for the corresponding slot.
963
             This switches off bitstream parsing until a new header arrives. */
964
7.45k
          if (hSbrHeader->syncState != SBR_NOT_INITIALIZED) {
965
7.32k
            hSbrHeader->syncState = UPSAMPLING;
966
7.32k
            hSbrHeader->status |= SBRDEC_HDR_STAT_UPDATE;
967
7.32k
          }
968
7.45k
        }
969
7.45k
      }
970
8.92k
    } break;
971
972
328k
    case SBR_SKIP_QMF:
973
328k
      if (self == NULL) {
974
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
975
328k
      } else {
976
328k
        if (value == 1) {
977
17.8k
          self->flags |= SBRDEC_SKIP_QMF_ANA;
978
310k
        } else {
979
310k
          self->flags &= ~SBRDEC_SKIP_QMF_ANA;
980
310k
        }
981
328k
        if (value == 2) {
982
153k
          self->flags |= SBRDEC_SKIP_QMF_SYN;
983
175k
        } else {
984
175k
          self->flags &= ~SBRDEC_SKIP_QMF_SYN;
985
175k
        }
986
328k
      }
987
328k
      break;
988
0
    default:
989
0
      errorStatus = SBRDEC_SET_PARAM_FAIL;
990
0
      break;
991
1.56M
  } /* switch(param) */
992
993
1.56M
  return (errorStatus);
994
1.56M
}
995
996
static SBRDEC_DRC_CHANNEL *sbrDecoder_drcGetChannel(
997
549k
    const HANDLE_SBRDECODER self, const INT channel) {
998
549k
  SBRDEC_DRC_CHANNEL *pSbrDrcChannelData = NULL;
999
549k
  int elementIndex, elChanIdx = 0, numCh = 0;
1000
1001
1.33M
  for (elementIndex = 0; (elementIndex < (8)) && (numCh <= channel);
1002
791k
       elementIndex++) {
1003
791k
    SBR_DECODER_ELEMENT *pSbrElement = self->pSbrElement[elementIndex];
1004
791k
    int c, elChannels;
1005
1006
791k
    elChanIdx = 0;
1007
791k
    if (pSbrElement == NULL) break;
1008
1009
    /* Determine amount of channels for this element */
1010
786k
    switch (pSbrElement->elementID) {
1011
427k
      case ID_CPE:
1012
427k
        elChannels = 2;
1013
427k
        break;
1014
33.4k
      case ID_LFE:
1015
358k
      case ID_SCE:
1016
358k
        elChannels = 1;
1017
358k
        break;
1018
0
      case ID_NONE:
1019
0
      default:
1020
0
        elChannels = 0;
1021
0
        break;
1022
786k
    }
1023
1024
    /* Limit with actual allocated element channels */
1025
786k
    elChannels = fMin(elChannels, pSbrElement->nChannels);
1026
1027
1.84M
    for (c = 0; (c < elChannels) && (numCh <= channel); c++) {
1028
1.05M
      if (pSbrElement->pSbrChannel[elChanIdx] != NULL) {
1029
1.05M
        numCh++;
1030
1.05M
        elChanIdx++;
1031
1.05M
      }
1032
1.05M
    }
1033
786k
  }
1034
549k
  elementIndex -= 1;
1035
549k
  elChanIdx -= 1;
1036
1037
549k
  if (elChanIdx < 0 || elementIndex < 0) {
1038
4.74k
    return NULL;
1039
4.74k
  }
1040
1041
544k
  if (self->pSbrElement[elementIndex] != NULL) {
1042
544k
    if (self->pSbrElement[elementIndex]->pSbrChannel[elChanIdx] != NULL) {
1043
544k
      pSbrDrcChannelData = &self->pSbrElement[elementIndex]
1044
544k
                                ->pSbrChannel[elChanIdx]
1045
544k
                                ->SbrDec.sbrDrcChannel;
1046
544k
    }
1047
544k
  }
1048
1049
544k
  return (pSbrDrcChannelData);
1050
549k
}
1051
1052
SBR_ERROR sbrDecoder_drcFeedChannel(HANDLE_SBRDECODER self, INT ch,
1053
                                    UINT numBands, FIXP_DBL *pNextFact_mag,
1054
                                    INT nextFact_exp,
1055
                                    SHORT drcInterpolationScheme,
1056
196k
                                    UCHAR winSequence, USHORT *pBandTop) {
1057
196k
  SBRDEC_DRC_CHANNEL *pSbrDrcChannelData = NULL;
1058
196k
  int band, isValidData = 0;
1059
1060
196k
  if (self == NULL) {
1061
0
    return SBRDEC_NOT_INITIALIZED;
1062
0
  }
1063
196k
  if (ch > (8) || pNextFact_mag == NULL) {
1064
0
    return SBRDEC_SET_PARAM_FAIL;
1065
0
  }
1066
1067
  /* Search for gain values different to 1.0f */
1068
380k
  for (band = 0; band < (int)numBands; band += 1) {
1069
202k
    if (!((pNextFact_mag[band] == FL2FXCONST_DBL(0.5)) &&
1070
183k
          (nextFact_exp == 1)) &&
1071
18.9k
        !((pNextFact_mag[band] == (FIXP_DBL)MAXVAL_DBL) &&
1072
18.9k
          (nextFact_exp == 0))) {
1073
18.9k
      isValidData = 1;
1074
18.9k
      break;
1075
18.9k
    }
1076
202k
  }
1077
1078
  /* Find the right SBR channel */
1079
196k
  pSbrDrcChannelData = sbrDecoder_drcGetChannel(self, ch);
1080
1081
196k
  if (pSbrDrcChannelData != NULL) {
1082
196k
    if (pSbrDrcChannelData->enable ||
1083
175k
        isValidData) { /* Activate processing only with real and valid data */
1084
23.9k
      int i;
1085
1086
23.9k
      pSbrDrcChannelData->enable = 1;
1087
23.9k
      pSbrDrcChannelData->numBandsNext = numBands;
1088
1089
23.9k
      pSbrDrcChannelData->winSequenceNext = winSequence;
1090
23.9k
      pSbrDrcChannelData->drcInterpolationSchemeNext = drcInterpolationScheme;
1091
23.9k
      pSbrDrcChannelData->nextFact_exp = nextFact_exp;
1092
1093
113k
      for (i = 0; i < (int)numBands; i++) {
1094
89.8k
        pSbrDrcChannelData->bandTopNext[i] = pBandTop[i];
1095
89.8k
        pSbrDrcChannelData->nextFact_mag[i] = pNextFact_mag[i];
1096
89.8k
      }
1097
23.9k
    }
1098
196k
  }
1099
1100
196k
  return SBRDEC_OK;
1101
196k
}
1102
1103
388k
void sbrDecoder_drcDisable(HANDLE_SBRDECODER self, INT ch) {
1104
388k
  SBRDEC_DRC_CHANNEL *pSbrDrcChannelData = NULL;
1105
1106
388k
  if ((self == NULL) || (ch > (8)) || (self->numSbrElements == 0) ||
1107
352k
      (self->numSbrChannels == 0)) {
1108
36.2k
    return;
1109
36.2k
  }
1110
1111
  /* Find the right SBR channel */
1112
352k
  pSbrDrcChannelData = sbrDecoder_drcGetChannel(self, ch);
1113
1114
352k
  if (pSbrDrcChannelData != NULL) {
1115
348k
    sbrDecoder_drcInitChannel(pSbrDrcChannelData);
1116
348k
  }
1117
352k
}
1118
1119
SBR_ERROR sbrDecoder_Parse(HANDLE_SBRDECODER self, HANDLE_FDK_BITSTREAM hBs,
1120
                           UCHAR *pDrmBsBuffer, USHORT drmBsBufferSize,
1121
                           int *count, int bsPayLen, int crcFlag,
1122
                           MP4_ELEMENT_ID prevElement, int elementIndex,
1123
399k
                           UINT acFlags, UINT acElFlags[]) {
1124
399k
  SBR_DECODER_ELEMENT *hSbrElement = NULL;
1125
399k
  HANDLE_SBR_HEADER_DATA hSbrHeader = NULL;
1126
399k
  HANDLE_SBR_CHANNEL *pSbrChannel;
1127
1128
399k
  SBR_FRAME_DATA *hFrameDataLeft = NULL;
1129
399k
  SBR_FRAME_DATA *hFrameDataRight = NULL;
1130
399k
  SBR_FRAME_DATA frameDataLeftCopy;
1131
399k
  SBR_FRAME_DATA frameDataRightCopy;
1132
1133
399k
  SBR_ERROR errorStatus = SBRDEC_OK;
1134
399k
  SBR_HEADER_STATUS headerStatus = HEADER_NOT_PRESENT;
1135
1136
399k
  INT startPos = FDKgetValidBits(hBs);
1137
399k
  FDK_CRCINFO crcInfo;
1138
399k
  INT crcReg = 0;
1139
399k
  USHORT sbrCrc = 0;
1140
399k
  UINT crcPoly;
1141
399k
  UINT crcStartValue = 0;
1142
399k
  UINT crcLen;
1143
1144
399k
  HANDLE_FDK_BITSTREAM hBsOriginal = hBs;
1145
399k
  FDK_BITSTREAM bsBwd;
1146
1147
399k
  const int fGlobalIndependencyFlag = acFlags & AC_INDEP;
1148
399k
  const int bs_pvc = acElFlags[elementIndex] & AC_EL_USAC_PVC;
1149
399k
  const int bs_interTes = acElFlags[elementIndex] & AC_EL_USAC_ITES;
1150
399k
  int stereo;
1151
399k
  int fDoDecodeSbrData = 1;
1152
399k
  int alignBits = 0;
1153
1154
399k
  int lastSlot, lastHdrSlot = 0, thisHdrSlot = 0;
1155
1156
399k
  if (*count <= 0) {
1157
56.2k
    setFrameErrorFlag(self->pSbrElement[elementIndex], FRAME_ERROR);
1158
56.2k
    return SBRDEC_OK;
1159
56.2k
  }
1160
1161
  /* SBR sanity checks */
1162
343k
  if (self == NULL) {
1163
0
    errorStatus = SBRDEC_NOT_INITIALIZED;
1164
0
    goto bail;
1165
0
  }
1166
1167
  /* Reverse bits of DRM SBR payload */
1168
343k
  if ((self->flags & SBRDEC_SYNTAX_DRM) && *count > 0) {
1169
0
    int dataBytes, dataBits;
1170
1171
0
    FDK_ASSERT(drmBsBufferSize >= (512));
1172
0
    dataBits = *count;
1173
1174
0
    if (dataBits > ((512) * 8)) {
1175
      /* do not flip more data than needed */
1176
0
      dataBits = (512) * 8;
1177
0
    }
1178
1179
0
    dataBytes = (dataBits + 7) >> 3;
1180
1181
0
    int j;
1182
1183
0
    if ((j = (int)FDKgetValidBits(hBs)) != 8) {
1184
0
      FDKpushBiDirectional(hBs, (j - 8));
1185
0
    }
1186
1187
0
    j = 0;
1188
0
    for (; dataBytes > 0; dataBytes--) {
1189
0
      int i;
1190
0
      UCHAR tmpByte;
1191
0
      UCHAR buffer = 0x00;
1192
1193
0
      tmpByte = (UCHAR)FDKreadBits(hBs, 8);
1194
0
      for (i = 0; i < 4; i++) {
1195
0
        int shift = 2 * i + 1;
1196
0
        buffer |= (tmpByte & (0x08 >> i)) << shift;
1197
0
        buffer |= (tmpByte & (0x10 << i)) >> shift;
1198
0
      }
1199
0
      pDrmBsBuffer[j++] = buffer;
1200
0
      FDKpushBack(hBs, 16);
1201
0
    }
1202
1203
0
    FDKinitBitStream(&bsBwd, pDrmBsBuffer, (512), dataBits, BS_READER);
1204
1205
    /* Use reversed data */
1206
0
    hBs = &bsBwd;
1207
0
    bsPayLen = *count;
1208
0
  }
1209
1210
  /* Remember start position of  SBR element */
1211
343k
  startPos = FDKgetValidBits(hBs);
1212
1213
  /* SBR sanity checks */
1214
343k
  if (self->pSbrElement[elementIndex] == NULL) {
1215
0
    errorStatus = SBRDEC_NOT_INITIALIZED;
1216
0
    goto bail;
1217
0
  }
1218
343k
  hSbrElement = self->pSbrElement[elementIndex];
1219
1220
343k
  lastSlot = (hSbrElement->useFrameSlot > 0) ? hSbrElement->useFrameSlot - 1
1221
343k
                                             : self->numDelayFrames;
1222
343k
  lastHdrSlot = hSbrElement->useHeaderSlot[lastSlot];
1223
343k
  thisHdrSlot = getHeaderSlot(
1224
343k
      hSbrElement->useFrameSlot,
1225
343k
      hSbrElement->useHeaderSlot); /* Get a free header slot not used by
1226
                                      frames not processed yet. */
1227
1228
  /* Assign the free slot to store a new header if there is one. */
1229
343k
  hSbrHeader = &self->sbrHeader[elementIndex][thisHdrSlot];
1230
1231
343k
  pSbrChannel = hSbrElement->pSbrChannel;
1232
343k
  stereo = (hSbrElement->elementID == ID_CPE) ? 1 : 0;
1233
1234
343k
  hFrameDataLeft = &self->pSbrElement[elementIndex]
1235
343k
                        ->pSbrChannel[0]
1236
343k
                        ->frameData[hSbrElement->useFrameSlot];
1237
343k
  if (stereo) {
1238
121k
    hFrameDataRight = &self->pSbrElement[elementIndex]
1239
121k
                           ->pSbrChannel[1]
1240
121k
                           ->frameData[hSbrElement->useFrameSlot];
1241
121k
  }
1242
1243
  /* store frameData; new parsed frameData possibly corrupted */
1244
343k
  FDKmemcpy(&frameDataLeftCopy, hFrameDataLeft, sizeof(SBR_FRAME_DATA));
1245
343k
  if (stereo) {
1246
121k
    FDKmemcpy(&frameDataRightCopy, hFrameDataRight, sizeof(SBR_FRAME_DATA));
1247
121k
  }
1248
1249
  /* reset PS flag; will be set after PS was found */
1250
343k
  self->flags &= ~SBRDEC_PS_DECODED;
1251
1252
343k
  if (hSbrHeader->status & SBRDEC_HDR_STAT_UPDATE) {
1253
    /* Got a new header from extern (e.g. from an ASC) */
1254
28.1k
    headerStatus = HEADER_OK;
1255
28.1k
    hSbrHeader->status &= ~SBRDEC_HDR_STAT_UPDATE;
1256
314k
  } else if (thisHdrSlot != lastHdrSlot) {
1257
    /* Copy the last header into this slot otherwise the
1258
       header compare will trigger more HEADER_RESETs than needed. */
1259
39.0k
    copySbrHeader(hSbrHeader, &self->sbrHeader[elementIndex][lastHdrSlot]);
1260
39.0k
  }
1261
1262
  /*
1263
     Check if bit stream data is valid and matches the element context
1264
  */
1265
343k
  if (((prevElement != ID_SCE) && (prevElement != ID_CPE)) ||
1266
340k
      prevElement != hSbrElement->elementID) {
1267
    /* In case of LFE we also land here, since there is no LFE SBR element (do
1268
     * upsampling only) */
1269
2.63k
    fDoDecodeSbrData = 0;
1270
2.63k
  }
1271
1272
343k
  if (fDoDecodeSbrData) {
1273
340k
    if ((INT)FDKgetValidBits(hBs) <= 0) {
1274
6
      fDoDecodeSbrData = 0;
1275
6
    }
1276
340k
  }
1277
1278
  /*
1279
     SBR CRC-check
1280
  */
1281
343k
  if (fDoDecodeSbrData) {
1282
340k
    if (crcFlag) {
1283
35.8k
      switch (self->coreCodec) {
1284
0
        case AOT_DRM_AAC:
1285
0
        case AOT_DRM_SURROUND:
1286
0
          crcPoly = 0x001d;
1287
0
          crcLen = 8;
1288
0
          crcStartValue = 0x000000ff;
1289
0
          break;
1290
35.8k
        default:
1291
35.8k
          crcPoly = 0x0633;
1292
35.8k
          crcLen = 10;
1293
35.8k
          crcStartValue = 0x00000000;
1294
35.8k
          break;
1295
35.8k
      }
1296
35.8k
      sbrCrc = (USHORT)FDKreadBits(hBs, crcLen);
1297
      /* Setup CRC decoder */
1298
35.8k
      FDKcrcInit(&crcInfo, crcPoly, crcStartValue, crcLen);
1299
      /* Start CRC region */
1300
35.8k
      crcReg = FDKcrcStartReg(&crcInfo, hBs, 0);
1301
35.8k
    }
1302
340k
  } /* if (fDoDecodeSbrData) */
1303
1304
  /*
1305
     Read in the header data and issue a reset if change occured
1306
  */
1307
343k
  if (fDoDecodeSbrData) {
1308
340k
    int sbrHeaderPresent;
1309
1310
340k
    if (self->flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC)) {
1311
250k
      SBR_HEADER_DATA_BS_INFO newSbrInfo;
1312
250k
      int sbrInfoPresent;
1313
1314
250k
      if (bs_interTes) {
1315
77.9k
        self->flags |= SBRDEC_USAC_ITES;
1316
172k
      } else {
1317
172k
        self->flags &= ~SBRDEC_USAC_ITES;
1318
172k
      }
1319
1320
250k
      if (fGlobalIndependencyFlag) {
1321
193k
        self->flags |= SBRDEC_USAC_INDEP;
1322
193k
        sbrInfoPresent = 1;
1323
193k
        sbrHeaderPresent = 1;
1324
193k
      } else {
1325
56.2k
        self->flags &= ~SBRDEC_USAC_INDEP;
1326
56.2k
        sbrInfoPresent = FDKreadBit(hBs);
1327
56.2k
        if (sbrInfoPresent) {
1328
7.31k
          sbrHeaderPresent = FDKreadBit(hBs);
1329
48.8k
        } else {
1330
48.8k
          sbrHeaderPresent = 0;
1331
48.8k
        }
1332
56.2k
      }
1333
1334
250k
      if (sbrInfoPresent) {
1335
201k
        newSbrInfo.ampResolution = FDKreadBit(hBs);
1336
201k
        newSbrInfo.xover_band = FDKreadBits(hBs, 4);
1337
201k
        newSbrInfo.sbr_preprocessing = FDKreadBit(hBs);
1338
201k
        if (bs_pvc) {
1339
128k
          newSbrInfo.pvc_mode = FDKreadBits(hBs, 2);
1340
          /* bs_pvc_mode: 0 -> no PVC, 1 -> PVC mode 1, 2 -> PVC mode 2, 3 ->
1341
           * reserved */
1342
128k
          if (newSbrInfo.pvc_mode > 2) {
1343
9.74k
            headerStatus = HEADER_ERROR;
1344
9.74k
          }
1345
128k
          if (stereo && newSbrInfo.pvc_mode > 0) {
1346
            /* bs_pvc is always transmitted but pvc_mode is set to zero in case
1347
             * of stereo SBR. The config might be wrong but we cannot tell for
1348
             * sure. */
1349
10.0k
            newSbrInfo.pvc_mode = 0;
1350
10.0k
          }
1351
128k
        } else {
1352
73.1k
          newSbrInfo.pvc_mode = 0;
1353
73.1k
        }
1354
201k
        if (headerStatus != HEADER_ERROR) {
1355
191k
          if (FDKmemcmp(&hSbrHeader->bs_info, &newSbrInfo,
1356
191k
                        sizeof(SBR_HEADER_DATA_BS_INFO))) {
1357
            /* in case of ampResolution and preprocessing change no full reset
1358
             * required    */
1359
            /* HEADER reset would trigger HBE transposer reset which breaks
1360
             * eSbr_3_Eaa.mp4 */
1361
67.8k
            if ((hSbrHeader->bs_info.pvc_mode != newSbrInfo.pvc_mode) ||
1362
59.7k
                (hSbrHeader->bs_info.xover_band != newSbrInfo.xover_band)) {
1363
59.7k
              headerStatus = HEADER_RESET;
1364
59.7k
            } else {
1365
8.13k
              headerStatus = HEADER_OK;
1366
8.13k
            }
1367
1368
67.8k
            hSbrHeader->bs_info = newSbrInfo;
1369
123k
          } else {
1370
123k
            headerStatus = HEADER_OK;
1371
123k
          }
1372
191k
        }
1373
201k
      }
1374
250k
      if (headerStatus == HEADER_ERROR) {
1375
        /* Corrupt SBR info data, do not decode and switch to UPSAMPLING */
1376
9.74k
        hSbrHeader->syncState = hSbrHeader->syncState > UPSAMPLING
1377
9.74k
                                    ? UPSAMPLING
1378
9.74k
                                    : hSbrHeader->syncState;
1379
9.74k
        fDoDecodeSbrData = 0;
1380
9.74k
        sbrHeaderPresent = 0;
1381
9.74k
      }
1382
1383
250k
      if (sbrHeaderPresent && fDoDecodeSbrData) {
1384
188k
        int useDfltHeader;
1385
1386
188k
        useDfltHeader = FDKreadBit(hBs);
1387
1388
188k
        if (useDfltHeader) {
1389
112k
          sbrHeaderPresent = 0;
1390
112k
          if (FDKmemcmp(&hSbrHeader->bs_data, &hSbrHeader->bs_dflt,
1391
112k
                        sizeof(SBR_HEADER_DATA_BS)) ||
1392
92.7k
              hSbrHeader->syncState != SBR_ACTIVE) {
1393
22.1k
            hSbrHeader->bs_data = hSbrHeader->bs_dflt;
1394
22.1k
            headerStatus = HEADER_RESET;
1395
22.1k
          }
1396
112k
        }
1397
188k
      }
1398
250k
    } else {
1399
90.3k
      sbrHeaderPresent = FDKreadBit(hBs);
1400
90.3k
    }
1401
1402
340k
    if (sbrHeaderPresent) {
1403
133k
      headerStatus = sbrGetHeaderData(hSbrHeader, hBs, self->flags, 1, 0);
1404
133k
    }
1405
1406
340k
    if (headerStatus == HEADER_RESET) {
1407
125k
      errorStatus = sbrDecoder_HeaderUpdate(
1408
125k
          self, hSbrHeader, headerStatus, pSbrChannel, hSbrElement->nChannels);
1409
1410
125k
      if (errorStatus == SBRDEC_OK) {
1411
99.8k
        hSbrHeader->syncState = SBR_HEADER;
1412
99.8k
      } else {
1413
25.9k
        hSbrHeader->syncState = SBR_NOT_INITIALIZED;
1414
25.9k
        headerStatus = HEADER_ERROR;
1415
25.9k
      }
1416
125k
    }
1417
1418
340k
    if (errorStatus != SBRDEC_OK) {
1419
25.9k
      fDoDecodeSbrData = 0;
1420
25.9k
    }
1421
340k
  } /* if (fDoDecodeSbrData) */
1422
1423
  /*
1424
    Print debugging output only if state has changed
1425
  */
1426
1427
  /* read frame data */
1428
343k
  if ((hSbrHeader->syncState >= SBR_HEADER) && fDoDecodeSbrData) {
1429
298k
    int sbrFrameOk;
1430
    /* read the SBR element data */
1431
298k
    if (!stereo && (self->hParametricStereoDec != NULL)) {
1432
      /* update slot index for PS bitstream parsing */
1433
26.8k
      self->hParametricStereoDec->bsLastSlot =
1434
26.8k
          self->hParametricStereoDec->bsReadSlot;
1435
26.8k
      self->hParametricStereoDec->bsReadSlot = hSbrElement->useFrameSlot;
1436
26.8k
    }
1437
298k
    sbrFrameOk = sbrGetChannelElement(
1438
298k
        hSbrHeader, hFrameDataLeft, (stereo) ? hFrameDataRight : NULL,
1439
298k
        &pSbrChannel[0]->prevFrameData,
1440
298k
        pSbrChannel[0]->SbrDec.PvcStaticData.pvc_mode_last, hBs,
1441
298k
        (stereo) ? NULL : self->hParametricStereoDec, self->flags,
1442
298k
        self->pSbrElement[elementIndex]->transposerSettings.overlap);
1443
1444
298k
    if (!sbrFrameOk) {
1445
19.8k
      fDoDecodeSbrData = 0;
1446
278k
    } else {
1447
278k
      INT valBits;
1448
1449
278k
      if (bsPayLen > 0) {
1450
28.9k
        valBits = bsPayLen - ((INT)startPos - (INT)FDKgetValidBits(hBs));
1451
249k
      } else {
1452
249k
        valBits = (INT)FDKgetValidBits(hBs);
1453
249k
      }
1454
1455
      /* sanity check of remaining bits */
1456
278k
      if (valBits < 0) {
1457
31.3k
        fDoDecodeSbrData = 0;
1458
247k
      } else {
1459
247k
        switch (self->coreCodec) {
1460
0
          case AOT_SBR:
1461
0
          case AOT_PS:
1462
1.86k
          case AOT_AAC_LC: {
1463
            /* This sanity check is only meaningful with General Audio
1464
             * bitstreams */
1465
1.86k
            alignBits = valBits & 0x7;
1466
1467
1.86k
            if (valBits > alignBits) {
1468
264
              fDoDecodeSbrData = 0;
1469
264
            }
1470
1.86k
          } break;
1471
245k
          default:
1472
            /* No sanity check available */
1473
245k
            break;
1474
247k
        }
1475
247k
      }
1476
278k
    }
1477
298k
  } else {
1478
    /* The returned bit count will not be the actual payload size since we did
1479
       not parse the frame data. Return an error so that the caller can react
1480
       respectively. */
1481
44.4k
    errorStatus = SBRDEC_PARSE_ERROR;
1482
44.4k
  }
1483
1484
343k
  if (crcFlag && (hSbrHeader->syncState >= SBR_HEADER) && fDoDecodeSbrData) {
1485
15.3k
    FDKpushFor(hBs, alignBits);
1486
15.3k
    FDKcrcEndReg(&crcInfo, hBs, crcReg); /* End CRC region */
1487
15.3k
    FDKpushBack(hBs, alignBits);
1488
    /* Check CRC */
1489
15.3k
    if ((FDKcrcGetCRC(&crcInfo) ^ crcStartValue) != sbrCrc) {
1490
14.0k
      fDoDecodeSbrData = 0;
1491
14.0k
      if (headerStatus != HEADER_NOT_PRESENT) {
1492
12.6k
        headerStatus = HEADER_ERROR;
1493
12.6k
        hSbrHeader->syncState = SBR_NOT_INITIALIZED;
1494
12.6k
      }
1495
14.0k
    }
1496
15.3k
  }
1497
1498
343k
  if (!fDoDecodeSbrData) {
1499
    /* Set error flag for this slot to trigger concealment */
1500
103k
    setFrameErrorFlag(self->pSbrElement[elementIndex], FRAME_ERROR);
1501
    /* restore old frameData for concealment */
1502
103k
    FDKmemcpy(hFrameDataLeft, &frameDataLeftCopy, sizeof(SBR_FRAME_DATA));
1503
103k
    if (stereo) {
1504
37.7k
      FDKmemcpy(hFrameDataRight, &frameDataRightCopy, sizeof(SBR_FRAME_DATA));
1505
37.7k
    }
1506
103k
    errorStatus = SBRDEC_PARSE_ERROR;
1507
239k
  } else {
1508
    /* Everything seems to be ok so clear the error flag */
1509
239k
    setFrameErrorFlag(self->pSbrElement[elementIndex], FRAME_OK);
1510
239k
  }
1511
1512
343k
  if (!stereo) {
1513
    /* Turn coupling off explicitely to avoid access to absent right frame data
1514
       that might occur with corrupt bitstreams. */
1515
221k
    hFrameDataLeft->coupling = COUPLING_OFF;
1516
221k
  }
1517
1518
343k
bail:
1519
1520
343k
  if (self != NULL) {
1521
343k
    if (self->flags & SBRDEC_SYNTAX_DRM) {
1522
0
      hBs = hBsOriginal;
1523
0
    }
1524
1525
343k
    if (errorStatus != SBRDEC_NOT_INITIALIZED) {
1526
343k
      int useOldHdr =
1527
343k
          ((headerStatus == HEADER_NOT_PRESENT) ||
1528
277k
           (headerStatus == HEADER_ERROR) ||
1529
229k
           (headerStatus == HEADER_RESET && errorStatus == SBRDEC_PARSE_ERROR))
1530
343k
              ? 1
1531
343k
              : 0;
1532
1533
343k
      if (!useOldHdr && (thisHdrSlot != lastHdrSlot) && (hSbrHeader != NULL)) {
1534
7.23k
        useOldHdr |=
1535
7.23k
            (compareSbrHeader(hSbrHeader,
1536
7.23k
                              &self->sbrHeader[elementIndex][lastHdrSlot]) == 0)
1537
7.23k
                ? 1
1538
7.23k
                : 0;
1539
7.23k
      }
1540
1541
343k
      if (hSbrElement != NULL) {
1542
343k
        if (useOldHdr != 0) {
1543
          /* Use the old header for this frame */
1544
153k
          hSbrElement->useHeaderSlot[hSbrElement->useFrameSlot] = lastHdrSlot;
1545
189k
        } else {
1546
          /* Use the new header for this frame */
1547
189k
          hSbrElement->useHeaderSlot[hSbrElement->useFrameSlot] = thisHdrSlot;
1548
189k
        }
1549
1550
        /* Move frame pointer to the next slot which is up to be decoded/applied
1551
         * next */
1552
343k
        hSbrElement->useFrameSlot =
1553
343k
            (hSbrElement->useFrameSlot + 1) % (self->numDelayFrames + 1);
1554
343k
      }
1555
343k
    }
1556
343k
  }
1557
1558
343k
  *count -= startPos - (INT)FDKgetValidBits(hBs);
1559
1560
343k
  return errorStatus;
1561
343k
}
1562
1563
/**
1564
 * \brief Render one SBR element into time domain signal.
1565
 * \param self SBR decoder handle
1566
 * \param timeData pointer to output buffer
1567
 * \param channelMapping pointer to UCHAR array where next 2 channel offsets are
1568
 * stored.
1569
 * \param elementIndex enumerating index of the SBR element to render.
1570
 * \param numInChannels number of channels from core coder.
1571
 * \param numOutChannels pointer to a location to return number of output
1572
 * channels.
1573
 * \param psPossible flag indicating if PS is possible or not.
1574
 * \return SBRDEC_OK if successfull, else error code
1575
 */
1576
static SBR_ERROR sbrDecoder_DecodeElement(
1577
    HANDLE_SBRDECODER self, LONG *input, LONG *timeData, const int timeDataSize,
1578
    const FDK_channelMapDescr *const mapDescr, const int mapIdx,
1579
    int channelIndex, const int elementIndex, const int numInChannels,
1580
387k
    int *numOutChannels, const int psPossible) {
1581
387k
  SBR_DECODER_ELEMENT *hSbrElement = self->pSbrElement[elementIndex];
1582
387k
  HANDLE_SBR_CHANNEL *pSbrChannel =
1583
387k
      self->pSbrElement[elementIndex]->pSbrChannel;
1584
387k
  HANDLE_SBR_HEADER_DATA hSbrHeader =
1585
387k
      &self->sbrHeader[elementIndex]
1586
387k
                      [hSbrElement->useHeaderSlot[hSbrElement->useFrameSlot]];
1587
387k
  HANDLE_PS_DEC h_ps_d = self->hParametricStereoDec;
1588
1589
  /* get memory for frame data from scratch */
1590
387k
  SBR_FRAME_DATA *hFrameDataLeft = NULL;
1591
387k
  SBR_FRAME_DATA *hFrameDataRight = NULL;
1592
1593
387k
  SBR_ERROR errorStatus = SBRDEC_OK;
1594
1595
387k
  INT strideOut, offset0 = 255, offset0_block = 0, offset1 = 255,
1596
387k
                 offset1_block = 0;
1597
387k
  INT codecFrameSize = self->codecFrameSize;
1598
1599
387k
  int stereo = (hSbrElement->elementID == ID_CPE) ? 1 : 0;
1600
387k
  int numElementChannels =
1601
387k
      hSbrElement
1602
387k
          ->nChannels; /* Number of channels of the current SBR element */
1603
1604
387k
  hFrameDataLeft =
1605
387k
      &hSbrElement->pSbrChannel[0]->frameData[hSbrElement->useFrameSlot];
1606
387k
  if (stereo) {
1607
156k
    hFrameDataRight =
1608
156k
        &hSbrElement->pSbrChannel[1]->frameData[hSbrElement->useFrameSlot];
1609
156k
  }
1610
1611
387k
  if (self->flags & SBRDEC_FLUSH) {
1612
27
    if (self->numFlushedFrames > self->numDelayFrames) {
1613
27
      int hdrIdx;
1614
      /* No valid SBR payload available, hence switch to upsampling (in all
1615
       * headers) */
1616
81
      for (hdrIdx = 0; hdrIdx < ((1) + 1); hdrIdx += 1) {
1617
54
        if (self->sbrHeader[elementIndex][hdrIdx].syncState > UPSAMPLING) {
1618
26
          self->sbrHeader[elementIndex][hdrIdx].syncState = UPSAMPLING;
1619
26
        }
1620
54
      }
1621
27
    } else {
1622
      /* Move frame pointer to the next slot which is up to be decoded/applied
1623
       * next */
1624
0
      hSbrElement->useFrameSlot =
1625
0
          (hSbrElement->useFrameSlot + 1) % (self->numDelayFrames + 1);
1626
      /* Update header and frame data pointer because they have already been set
1627
       */
1628
0
      hSbrHeader =
1629
0
          &self->sbrHeader[elementIndex]
1630
0
                          [hSbrElement
1631
0
                               ->useHeaderSlot[hSbrElement->useFrameSlot]];
1632
0
      hFrameDataLeft =
1633
0
          &hSbrElement->pSbrChannel[0]->frameData[hSbrElement->useFrameSlot];
1634
0
      if (stereo) {
1635
0
        hFrameDataRight =
1636
0
            &hSbrElement->pSbrChannel[1]->frameData[hSbrElement->useFrameSlot];
1637
0
      }
1638
0
    }
1639
27
  }
1640
1641
  /* Update the header error flag */
1642
387k
  hSbrHeader->frameErrorFlag =
1643
387k
      hSbrElement->frameErrorFlag[hSbrElement->useFrameSlot];
1644
1645
  /*
1646
     Prepare filterbank for upsampling if no valid bit stream data is available.
1647
   */
1648
387k
  if (hSbrHeader->syncState == SBR_NOT_INITIALIZED) {
1649
42.4k
    errorStatus =
1650
42.4k
        initHeaderData(hSbrHeader, self->sampleRateIn, self->sampleRateOut,
1651
42.4k
                       self->downscaleFactor, codecFrameSize, self->flags,
1652
42.4k
                       1 /* SET_DEFAULT_HDR */
1653
42.4k
        );
1654
1655
42.4k
    if (errorStatus != SBRDEC_OK) {
1656
0
      return errorStatus;
1657
0
    }
1658
1659
42.4k
    hSbrHeader->syncState = UPSAMPLING;
1660
1661
42.4k
    errorStatus = sbrDecoder_HeaderUpdate(self, hSbrHeader, HEADER_NOT_PRESENT,
1662
42.4k
                                          pSbrChannel, hSbrElement->nChannels);
1663
1664
42.4k
    if (errorStatus != SBRDEC_OK) {
1665
0
      hSbrHeader->syncState = SBR_NOT_INITIALIZED;
1666
0
      return errorStatus;
1667
0
    }
1668
42.4k
  }
1669
1670
  /* reset */
1671
387k
  if (hSbrHeader->status & SBRDEC_HDR_STAT_RESET) {
1672
185k
    int ch;
1673
185k
    int applySbrProc = (hSbrHeader->syncState == SBR_ACTIVE ||
1674
185k
                        (hSbrHeader->frameErrorFlag == 0 &&
1675
107k
                         hSbrHeader->syncState == SBR_HEADER));
1676
481k
    for (ch = 0; ch < numElementChannels; ch++) {
1677
296k
      SBR_ERROR errorStatusTmp = SBRDEC_OK;
1678
1679
296k
      errorStatusTmp = resetSbrDec(
1680
296k
          &pSbrChannel[ch]->SbrDec, hSbrHeader, &pSbrChannel[ch]->prevFrameData,
1681
296k
          self->synDownsampleFac, self->flags, pSbrChannel[ch]->frameData);
1682
1683
296k
      if (errorStatusTmp != SBRDEC_OK) {
1684
4.13k
        hSbrHeader->syncState = UPSAMPLING;
1685
4.13k
      }
1686
296k
    }
1687
185k
    if (applySbrProc) {
1688
56.1k
      hSbrHeader->status &= ~SBRDEC_HDR_STAT_RESET;
1689
56.1k
    }
1690
185k
  }
1691
1692
  /* decoding */
1693
387k
  if ((hSbrHeader->syncState == SBR_ACTIVE) ||
1694
191k
      ((hSbrHeader->syncState == SBR_HEADER) &&
1695
252k
       (hSbrHeader->frameErrorFlag == 0))) {
1696
252k
    errorStatus = SBRDEC_OK;
1697
1698
252k
    decodeSbrData(hSbrHeader, hFrameDataLeft, &pSbrChannel[0]->prevFrameData,
1699
252k
                  (stereo) ? hFrameDataRight : NULL,
1700
252k
                  (stereo) ? &pSbrChannel[1]->prevFrameData : NULL);
1701
1702
    /* Now we have a full parameter set and can do parameter
1703
       based concealment instead of plain upsampling. */
1704
252k
    hSbrHeader->syncState = SBR_ACTIVE;
1705
252k
  }
1706
1707
387k
  if (timeDataSize <
1708
387k
      hSbrHeader->numberTimeSlots * hSbrHeader->timeStep *
1709
387k
          self->pQmfDomain->globalConf.nBandsSynthesis *
1710
387k
          (psPossible ? fMax(2, numInChannels) : numInChannels)) {
1711
0
    return SBRDEC_OUTPUT_BUFFER_TOO_SMALL;
1712
0
  }
1713
1714
387k
  {
1715
387k
    self->flags &= ~SBRDEC_PS_DECODED;
1716
387k
    C_ALLOC_SCRATCH_START(pPsScratch, struct PS_DEC_COEFFICIENTS, 1)
1717
1718
    /* decode PS data if available */
1719
387k
    if (h_ps_d != NULL && psPossible && (hSbrHeader->syncState == SBR_ACTIVE)) {
1720
3.64k
      int applyPs = 1;
1721
1722
      /* define which frame delay line slot to process */
1723
3.64k
      h_ps_d->processSlot = hSbrElement->useFrameSlot;
1724
1725
3.64k
      applyPs = DecodePs(h_ps_d, hSbrHeader->frameErrorFlag, pPsScratch);
1726
3.64k
      self->flags |= (applyPs) ? SBRDEC_PS_DECODED : 0;
1727
3.64k
    }
1728
1729
387k
    offset0 = FDK_chMapDescr_getMapValue(mapDescr, channelIndex, mapIdx);
1730
387k
    offset0_block = offset0 * codecFrameSize;
1731
387k
    if (stereo || psPossible) {
1732
      /* the value of offset1 only matters if the condition is true, however if
1733
      it is not true channelIndex+1 may exceed the channel map resutling in an
1734
      error, though the value of offset1 is actually meaningless. This is
1735
      prevented here. */
1736
162k
      offset1 = FDK_chMapDescr_getMapValue(mapDescr, channelIndex + 1, mapIdx);
1737
162k
      offset1_block = offset1 * codecFrameSize;
1738
162k
    }
1739
    /* Set strides for reading and writing */
1740
387k
    if (psPossible)
1741
5.70k
      strideOut = (numInChannels < 2) ? 2 : numInChannels;
1742
381k
    else
1743
381k
      strideOut = numInChannels;
1744
1745
    /* use same buffers for left and right channel and apply PS per timeslot */
1746
    /* Process left channel */
1747
387k
    sbr_dec(&pSbrChannel[0]->SbrDec, input + offset0_block, timeData + offset0,
1748
387k
            (self->flags & SBRDEC_PS_DECODED) ? &pSbrChannel[1]->SbrDec : NULL,
1749
387k
            timeData + offset1, strideOut, hSbrHeader, hFrameDataLeft,
1750
387k
            &pSbrChannel[0]->prevFrameData,
1751
387k
            (hSbrHeader->syncState == SBR_ACTIVE), h_ps_d, self->flags,
1752
387k
            codecFrameSize, self->sbrInDataHeadroom);
1753
1754
387k
    if (stereo) {
1755
      /* Process right channel */
1756
156k
      sbr_dec(&pSbrChannel[1]->SbrDec, input + offset1_block,
1757
156k
              timeData + offset1, NULL, NULL, strideOut, hSbrHeader,
1758
156k
              hFrameDataRight, &pSbrChannel[1]->prevFrameData,
1759
156k
              (hSbrHeader->syncState == SBR_ACTIVE), NULL, self->flags,
1760
156k
              codecFrameSize, self->sbrInDataHeadroom);
1761
156k
    }
1762
1763
387k
    C_ALLOC_SCRATCH_END(pPsScratch, struct PS_DEC_COEFFICIENTS, 1)
1764
387k
  }
1765
1766
387k
  if (h_ps_d != NULL) {
1767
    /* save PS status for next run */
1768
31.8k
    h_ps_d->psDecodedPrv = (self->flags & SBRDEC_PS_DECODED) ? 1 : 0;
1769
31.8k
  }
1770
1771
387k
  if (psPossible && !(self->flags & SBRDEC_SKIP_QMF_SYN)) {
1772
5.70k
    FDK_ASSERT(strideOut > 1);
1773
5.70k
    if (!(self->flags & SBRDEC_PS_DECODED)) {
1774
      /* A decoder which is able to decode PS has to produce a stereo output
1775
       * even if no PS data is available. */
1776
      /* So copy left channel to right channel. */
1777
2.44k
      int copyFrameSize =
1778
2.44k
          codecFrameSize * self->pQmfDomain->QmfDomainOut->fb.no_channels;
1779
2.44k
      copyFrameSize /= self->pQmfDomain->QmfDomainIn->fb.no_channels;
1780
2.44k
      LONG *ptr;
1781
2.44k
      INT i;
1782
2.44k
      FDK_ASSERT(strideOut == 2);
1783
1784
2.44k
      ptr = timeData;
1785
2.40M
      for (i = copyFrameSize >> 1; i--;) {
1786
2.40M
        LONG tmp; /* This temporal variable is required because some compilers
1787
                     can't do *ptr++ = *ptr++ correctly. */
1788
2.40M
        tmp = *ptr++;
1789
2.40M
        *ptr++ = tmp;
1790
2.40M
        tmp = *ptr++;
1791
2.40M
        *ptr++ = tmp;
1792
2.40M
      }
1793
2.44k
    }
1794
5.70k
    *numOutChannels = 2; /* Output minimum two channels when PS is enabled. */
1795
5.70k
  }
1796
1797
387k
  return errorStatus;
1798
387k
}
1799
1800
SBR_ERROR sbrDecoder_Apply(HANDLE_SBRDECODER self, LONG *input, LONG *timeData,
1801
                           const int timeDataSize, int *numChannels,
1802
                           int *sampleRate,
1803
                           const FDK_channelMapDescr *const mapDescr,
1804
                           const int mapIdx, const int coreDecodedOk,
1805
                           UCHAR *psDecoded, const INT inDataHeadroom,
1806
328k
                           INT *outDataHeadroom) {
1807
328k
  SBR_ERROR errorStatus = SBRDEC_OK;
1808
1809
328k
  int psPossible;
1810
328k
  int sbrElementNum;
1811
328k
  int numCoreChannels;
1812
328k
  int numSbrChannels = 0;
1813
1814
328k
  if ((self == NULL) || (timeData == NULL) || (numChannels == NULL) ||
1815
328k
      (sampleRate == NULL) || (psDecoded == NULL) ||
1816
328k
      !FDK_chMapDescr_isValid(mapDescr)) {
1817
0
    return SBRDEC_INVALID_ARGUMENT;
1818
0
  }
1819
1820
328k
  psPossible = *psDecoded;
1821
328k
  numCoreChannels = *numChannels;
1822
328k
  if (numCoreChannels <= 0) {
1823
0
    return SBRDEC_INVALID_ARGUMENT;
1824
0
  }
1825
1826
328k
  if (self->numSbrElements < 1) {
1827
    /* exit immediately to avoid access violations */
1828
0
    return SBRDEC_NOT_INITIALIZED;
1829
0
  }
1830
1831
  /* Sanity check of allocated SBR elements. */
1832
717k
  for (sbrElementNum = 0; sbrElementNum < self->numSbrElements;
1833
389k
       sbrElementNum++) {
1834
389k
    if (self->pSbrElement[sbrElementNum] == NULL) {
1835
139
      return SBRDEC_NOT_INITIALIZED;
1836
139
    }
1837
389k
  }
1838
1839
328k
  if (self->numSbrElements != 1 || self->pSbrElement[0]->elementID != ID_SCE) {
1840
130k
    psPossible = 0;
1841
130k
  }
1842
1843
328k
  self->sbrInDataHeadroom = inDataHeadroom;
1844
328k
  *outDataHeadroom = (INT)(8);
1845
1846
  /* Make sure that even if no SBR data was found/parsed *psDecoded is returned
1847
   * 1 if psPossible was 0. */
1848
328k
  if (psPossible == 0) {
1849
322k
    self->flags &= ~SBRDEC_PS_DECODED;
1850
322k
  }
1851
1852
  /* replaces channel based reset inside sbr_dec() */
1853
328k
  if (((self->flags & SBRDEC_LOW_POWER) ? 1 : 0) !=
1854
328k
      ((self->pQmfDomain->globalConf.flags & QMF_FLAG_LP) ? 1 : 0)) {
1855
13.2k
    if (self->flags & SBRDEC_LOW_POWER) {
1856
12.6k
      self->pQmfDomain->globalConf.flags |= QMF_FLAG_LP;
1857
12.6k
      self->pQmfDomain->globalConf.flags_requested |= QMF_FLAG_LP;
1858
12.6k
    } else {
1859
666
      self->pQmfDomain->globalConf.flags &= ~QMF_FLAG_LP;
1860
666
      self->pQmfDomain->globalConf.flags_requested &= ~QMF_FLAG_LP;
1861
666
    }
1862
13.2k
    if (FDK_QmfDomain_InitFilterBank(self->pQmfDomain, QMF_FLAG_KEEP_STATES)) {
1863
0
      return SBRDEC_UNSUPPORTED_CONFIG;
1864
0
    }
1865
13.2k
  }
1866
328k
  if (self->numSbrChannels > self->pQmfDomain->globalConf.nInputChannels) {
1867
0
    return SBRDEC_UNSUPPORTED_CONFIG;
1868
0
  }
1869
1870
328k
  if (self->flags & SBRDEC_FLUSH) {
1871
    /* flushing is signalized, hence increment the flush frame counter */
1872
27
    self->numFlushedFrames++;
1873
328k
  } else {
1874
    /* no flushing is signalized, hence reset the flush frame counter */
1875
328k
    self->numFlushedFrames = 0;
1876
328k
  }
1877
1878
  /* Loop over SBR elements */
1879
391k
  for (sbrElementNum = 0; sbrElementNum < self->numSbrElements;
1880
387k
       sbrElementNum++) {
1881
387k
    int numElementChan;
1882
1883
387k
    if (psPossible &&
1884
5.70k
        self->pSbrElement[sbrElementNum]->pSbrChannel[1] == NULL) {
1885
      /* Disable PS and try decoding SBR mono. */
1886
0
      psPossible = 0;
1887
0
    }
1888
1889
387k
    numElementChan =
1890
387k
        (self->pSbrElement[sbrElementNum]->elementID == ID_CPE) ? 2 : 1;
1891
1892
    /* If core signal is bad then force upsampling */
1893
387k
    if (!coreDecodedOk) {
1894
130k
      setFrameErrorFlag(self->pSbrElement[sbrElementNum], FRAME_ERROR_ALLSLOTS);
1895
130k
    }
1896
1897
387k
    errorStatus = sbrDecoder_DecodeElement(
1898
387k
        self, input, timeData, timeDataSize, mapDescr, mapIdx, numSbrChannels,
1899
387k
        sbrElementNum,
1900
387k
        numCoreChannels, /* is correct even for USC SCI==2 case */
1901
387k
        &numElementChan, psPossible);
1902
1903
387k
    if (errorStatus != SBRDEC_OK) {
1904
0
      goto bail;
1905
0
    }
1906
1907
387k
    numSbrChannels += numElementChan;
1908
1909
387k
    if (numSbrChannels >= numCoreChannels) {
1910
323k
      break;
1911
323k
    }
1912
387k
  }
1913
1914
  /* Update numChannels and samplerate */
1915
  /* Do not mess with output channels in case of USAC. numSbrChannels !=
1916
   * numChannels for stereoConfigIndex == 2 */
1917
328k
  if (!(self->flags & SBRDEC_SYNTAX_USAC)) {
1918
64.7k
    *numChannels = numSbrChannels;
1919
64.7k
  }
1920
328k
  *sampleRate = self->sampleRateOut;
1921
328k
  *psDecoded = (self->flags & SBRDEC_PS_DECODED) ? 1 : 0;
1922
1923
  /* Clear reset and flush flag because everything seems to be done
1924
   * successfully. */
1925
328k
  self->flags &= ~SBRDEC_FORCE_RESET;
1926
328k
  self->flags &= ~SBRDEC_FLUSH;
1927
1928
328k
bail:
1929
1930
328k
  return errorStatus;
1931
328k
}
1932
1933
29.6k
SBR_ERROR sbrDecoder_Close(HANDLE_SBRDECODER *pSelf) {
1934
29.6k
  HANDLE_SBRDECODER self = *pSelf;
1935
29.6k
  int i;
1936
1937
29.6k
  if (self != NULL) {
1938
29.6k
    if (self->hParametricStereoDec != NULL) {
1939
2.22k
      DeletePsDec(&self->hParametricStereoDec);
1940
2.22k
    }
1941
1942
266k
    for (i = 0; i < (8); i++) {
1943
237k
      sbrDecoder_DestroyElement(self, i);
1944
237k
    }
1945
1946
29.6k
    FreeRam_SbrDecoder(pSelf);
1947
29.6k
  }
1948
1949
29.6k
  return SBRDEC_OK;
1950
29.6k
}
1951
1952
0
INT sbrDecoder_GetLibInfo(LIB_INFO *info) {
1953
0
  int i;
1954
1955
0
  if (info == NULL) {
1956
0
    return -1;
1957
0
  }
1958
1959
  /* search for next free tab */
1960
0
  for (i = 0; i < FDK_MODULE_LAST; i++) {
1961
0
    if (info[i].module_id == FDK_NONE) break;
1962
0
  }
1963
0
  if (i == FDK_MODULE_LAST) return -1;
1964
0
  info += i;
1965
1966
0
  info->module_id = FDK_SBRDEC;
1967
0
  info->version =
1968
0
      LIB_VERSION(SBRDECODER_LIB_VL0, SBRDECODER_LIB_VL1, SBRDECODER_LIB_VL2);
1969
0
  LIB_VERSION_STRING(info);
1970
0
  info->build_date = SBRDECODER_LIB_BUILD_DATE;
1971
0
  info->build_time = SBRDECODER_LIB_BUILD_TIME;
1972
0
  info->title = SBRDECODER_LIB_TITLE;
1973
1974
  /* Set flags */
1975
0
  info->flags = 0 | CAPF_SBR_HQ | CAPF_SBR_LP | CAPF_SBR_PS_MPEG |
1976
0
                CAPF_SBR_DRM_BS | CAPF_SBR_CONCEALMENT | CAPF_SBR_DRC |
1977
0
                CAPF_SBR_ELD_DOWNSCALE | CAPF_SBR_HBEHQ;
1978
  /* End of flags */
1979
1980
0
  return 0;
1981
0
}
1982
1983
310k
UINT sbrDecoder_GetDelay(const HANDLE_SBRDECODER self) {
1984
310k
  UINT outputDelay = 0;
1985
1986
310k
  if (self != NULL) {
1987
310k
    UINT flags = self->flags;
1988
1989
    /* See chapter 1.6.7.2 of ISO/IEC 14496-3 for the GA-SBR figures below. */
1990
1991
    /* Are we initialized? */
1992
310k
    if ((self->numSbrChannels > 0) && (self->numSbrElements > 0)) {
1993
      /* Add QMF synthesis delay */
1994
310k
      if ((flags & SBRDEC_ELD_GRID) && IS_LOWDELAY(self->coreCodec)) {
1995
        /* Low delay SBR: */
1996
34.9k
        if (!(flags & SBRDEC_SKIP_QMF_SYN)) {
1997
33.5k
          outputDelay +=
1998
33.5k
              (flags & SBRDEC_DOWNSAMPLE) ? 32 : 64; /* QMF synthesis */
1999
33.5k
          if (flags & SBRDEC_LD_MPS_QMF) {
2000
895
            outputDelay += 32;
2001
895
          }
2002
33.5k
        }
2003
275k
      } else if (!IS_USAC(self->coreCodec)) {
2004
        /* By the method of elimination this is the GA (AAC-LC, HE-AAC, ...)
2005
         * branch: */
2006
29.8k
        outputDelay += (flags & SBRDEC_DOWNSAMPLE) ? 481 : 962;
2007
29.8k
        if (flags & SBRDEC_SKIP_QMF_SYN) {
2008
0
          outputDelay -= 257; /* QMF synthesis */
2009
0
        }
2010
29.8k
      }
2011
310k
    }
2012
310k
  }
2013
2014
310k
  return (outputDelay);
2015
310k
}