Coverage Report

Created: 2026-04-12 06:21

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
430k
static void setFrameErrorFlag(SBR_DECODER_ELEMENT *pSbrElement, UCHAR value) {
170
430k
  if (pSbrElement != NULL) {
171
430k
    switch (value) {
172
110k
      case FRAME_ERROR_ALLSLOTS:
173
110k
        FDKmemset(pSbrElement->frameErrorFlag, FRAME_ERROR,
174
110k
                  sizeof(pSbrElement->frameErrorFlag));
175
110k
        break;
176
319k
      default:
177
319k
        pSbrElement->frameErrorFlag[pSbrElement->useFrameSlot] = value;
178
430k
    }
179
430k
  }
180
430k
}
181
182
587k
static UCHAR getHeaderSlot(UCHAR currentSlot, UCHAR hdrSlotUsage[(1) + 1]) {
183
587k
  UINT occupied = 0;
184
587k
  int s;
185
587k
  UCHAR slot = hdrSlotUsage[currentSlot];
186
187
587k
  FDK_ASSERT((1) + 1 < 32);
188
189
1.55M
  for (s = 0; s < (1) + 1; s++) {
190
1.14M
    if ((hdrSlotUsage[s] == slot) && (s != slot)) {
191
182k
      occupied = 1;
192
182k
      break;
193
182k
    }
194
1.14M
  }
195
196
587k
  if (occupied) {
197
182k
    occupied = 0;
198
199
546k
    for (s = 0; s < (1) + 1; s++) {
200
364k
      occupied |= 1 << hdrSlotUsage[s];
201
364k
    }
202
338k
    for (s = 0; s < (1) + 1; s++) {
203
337k
      if (!(occupied & 0x1)) {
204
181k
        slot = s;
205
181k
        break;
206
181k
      }
207
156k
      occupied >>= 1;
208
156k
    }
209
182k
  }
210
211
587k
  return slot;
212
587k
}
213
214
static void copySbrHeader(HANDLE_SBR_HEADER_DATA hDst,
215
37.1k
                          const HANDLE_SBR_HEADER_DATA hSrc) {
216
  /* copy the whole header memory (including pointers) */
217
37.1k
  FDKmemcpy(hDst, hSrc, sizeof(SBR_HEADER_DATA));
218
219
  /* update pointers */
220
37.1k
  hDst->freqBandData.freqBandTable[0] = hDst->freqBandData.freqBandTableLo;
221
37.1k
  hDst->freqBandData.freqBandTable[1] = hDst->freqBandData.freqBandTableHi;
222
37.1k
}
223
224
static int compareSbrHeader(const HANDLE_SBR_HEADER_DATA hHdr1,
225
6.69k
                            const HANDLE_SBR_HEADER_DATA hHdr2) {
226
6.69k
  int result = 0;
227
228
  /* compare basic data */
229
6.69k
  result |= (hHdr1->syncState != hHdr2->syncState) ? 1 : 0;
230
6.69k
  result |= (hHdr1->status != hHdr2->status) ? 1 : 0;
231
6.69k
  result |= (hHdr1->frameErrorFlag != hHdr2->frameErrorFlag) ? 1 : 0;
232
6.69k
  result |= (hHdr1->numberTimeSlots != hHdr2->numberTimeSlots) ? 1 : 0;
233
6.69k
  result |=
234
6.69k
      (hHdr1->numberOfAnalysisBands != hHdr2->numberOfAnalysisBands) ? 1 : 0;
235
6.69k
  result |= (hHdr1->timeStep != hHdr2->timeStep) ? 1 : 0;
236
6.69k
  result |= (hHdr1->sbrProcSmplRate != hHdr2->sbrProcSmplRate) ? 1 : 0;
237
238
  /* compare bitstream data */
239
6.69k
  result |=
240
6.69k
      FDKmemcmp(&hHdr1->bs_data, &hHdr2->bs_data, sizeof(SBR_HEADER_DATA_BS));
241
6.69k
  result |=
242
6.69k
      FDKmemcmp(&hHdr1->bs_dflt, &hHdr2->bs_dflt, sizeof(SBR_HEADER_DATA_BS));
243
6.69k
  result |= FDKmemcmp(&hHdr1->bs_info, &hHdr2->bs_info,
244
6.69k
                      sizeof(SBR_HEADER_DATA_BS_INFO));
245
246
  /* compare frequency band data */
247
6.69k
  result |= FDKmemcmp(&hHdr1->freqBandData, &hHdr2->freqBandData,
248
6.69k
                      (8 + MAX_NUM_LIMITERS + 1) * sizeof(UCHAR));
249
6.69k
  result |= FDKmemcmp(hHdr1->freqBandData.freqBandTableLo,
250
6.69k
                      hHdr2->freqBandData.freqBandTableLo,
251
6.69k
                      (MAX_FREQ_COEFFS / 2 + 1) * sizeof(UCHAR));
252
6.69k
  result |= FDKmemcmp(hHdr1->freqBandData.freqBandTableHi,
253
6.69k
                      hHdr2->freqBandData.freqBandTableHi,
254
6.69k
                      (MAX_FREQ_COEFFS + 1) * sizeof(UCHAR));
255
6.69k
  result |= FDKmemcmp(hHdr1->freqBandData.freqBandTableNoise,
256
6.69k
                      hHdr2->freqBandData.freqBandTableNoise,
257
6.69k
                      (MAX_NOISE_COEFFS + 1) * sizeof(UCHAR));
258
6.69k
  result |=
259
6.69k
      FDKmemcmp(hHdr1->freqBandData.v_k_master, hHdr2->freqBandData.v_k_master,
260
6.69k
                (MAX_FREQ_COEFFS + 1) * sizeof(UCHAR));
261
262
6.69k
  return result;
263
6.69k
}
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
98.4k
                                         const int overlap) {
279
98.4k
  SBR_ERROR sbrError = SBRDEC_OK;
280
98.4k
  HANDLE_SBR_HEADER_DATA hSbrHeader;
281
98.4k
  UINT qmfFlags = 0;
282
283
98.4k
  int i, synDownsampleFac;
284
285
  /* USAC: assuming theoretical case 8 kHz output sample rate with 4:1 SBR */
286
98.4k
  const int sbr_min_sample_rate_in = IS_USAC(self->coreCodec) ? 2000 : 6400;
287
288
  /* Check in/out samplerates */
289
98.4k
  if (sampleRateIn < sbr_min_sample_rate_in || sampleRateIn > (96000)) {
290
1.16k
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
291
1.16k
    goto bail;
292
1.16k
  }
293
294
97.2k
  if (sampleRateOut > (96000)) {
295
214
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
296
214
    goto bail;
297
214
  }
298
299
  /* Set QMF mode flags */
300
97.0k
  if (self->flags & SBRDEC_LOW_POWER) qmfFlags |= QMF_FLAG_LP;
301
302
97.0k
  if (self->coreCodec == AOT_ER_AAC_ELD) {
303
58.1k
    if (self->flags & SBRDEC_LD_MPS_QMF) {
304
0
      qmfFlags |= QMF_FLAG_MPSLDFB;
305
58.1k
    } else {
306
58.1k
      qmfFlags |= QMF_FLAG_CLDFB;
307
58.1k
    }
308
58.1k
  }
309
310
  /* Set downsampling factor for synthesis filter bank */
311
97.0k
  if (sampleRateOut == 0) {
312
    /* no single rate mode */
313
4.44k
    sampleRateOut =
314
4.44k
        sampleRateIn
315
4.44k
        << 1; /* In case of implicit signalling, assume dual rate SBR */
316
4.44k
  }
317
318
97.0k
  if (sampleRateIn == sampleRateOut) {
319
47.3k
    synDownsampleFac = 2;
320
47.3k
    self->flags |= SBRDEC_DOWNSAMPLE;
321
49.7k
  } else {
322
49.7k
    synDownsampleFac = 1;
323
49.7k
    self->flags &= ~SBRDEC_DOWNSAMPLE;
324
49.7k
  }
325
326
97.0k
  self->synDownsampleFac = synDownsampleFac;
327
97.0k
  self->sampleRateOut = sampleRateOut;
328
329
97.0k
  {
330
291k
    for (i = 0; i < (1) + 1; i++) {
331
194k
      int setDflt;
332
194k
      hSbrHeader = &(self->sbrHeader[elementIndex][i]);
333
194k
      setDflt = ((hSbrHeader->syncState == SBR_NOT_INITIALIZED) ||
334
1.11k
                 (self->flags & SBRDEC_FORCE_RESET))
335
194k
                    ? 1
336
194k
                    : 0;
337
338
      /* init a default header such that we can at least do upsampling later */
339
194k
      sbrError = initHeaderData(hSbrHeader, sampleRateIn, sampleRateOut,
340
194k
                                self->downscaleFactor, samplesPerFrame,
341
194k
                                self->flags, setDflt);
342
343
      /* Set synchState to UPSAMPLING in case it already is initialized */
344
194k
      hSbrHeader->syncState = hSbrHeader->syncState > UPSAMPLING
345
194k
                                  ? UPSAMPLING
346
194k
                                  : hSbrHeader->syncState;
347
194k
    }
348
97.0k
  }
349
350
97.0k
  if (sbrError != SBRDEC_OK) {
351
39
    goto bail;
352
39
  }
353
354
97.0k
  if (!self->pQmfDomain->globalConf.qmfDomainExplicitConfig) {
355
97.0k
    self->pQmfDomain->globalConf.flags_requested |= qmfFlags;
356
97.0k
    self->pQmfDomain->globalConf.nBandsAnalysis_requested =
357
97.0k
        self->sbrHeader[elementIndex][0].numberOfAnalysisBands;
358
97.0k
    self->pQmfDomain->globalConf.nBandsSynthesis_requested =
359
97.0k
        (synDownsampleFac == 1) ? 64 : 32; /* may be overwritten by MPS */
360
97.0k
    self->pQmfDomain->globalConf.nBandsSynthesis_requested /=
361
97.0k
        self->downscaleFactor;
362
97.0k
    self->pQmfDomain->globalConf.nQmfTimeSlots_requested =
363
97.0k
        self->sbrHeader[elementIndex][0].numberTimeSlots *
364
97.0k
        self->sbrHeader[elementIndex][0].timeStep;
365
97.0k
    self->pQmfDomain->globalConf.nQmfOvTimeSlots_requested = overlap;
366
97.0k
    self->pQmfDomain->globalConf.nQmfProcBands_requested = 64; /* always 64 */
367
97.0k
    self->pQmfDomain->globalConf.nQmfProcChannels_requested =
368
97.0k
        1; /* may be overwritten by MPS */
369
97.0k
  }
370
371
  /* Init SBR channels going to be assigned to a SBR element */
372
97.0k
  {
373
97.0k
    int ch;
374
246k
    for (ch = 0; ch < self->pSbrElement[elementIndex]->nChannels; ch++) {
375
150k
      int headerIndex =
376
150k
          getHeaderSlot(self->pSbrElement[elementIndex]->useFrameSlot,
377
150k
                        self->pSbrElement[elementIndex]->useHeaderSlot);
378
379
      /* and create sbrDec */
380
150k
      sbrError =
381
150k
          createSbrDec(self->pSbrElement[elementIndex]->pSbrChannel[ch],
382
150k
                       &self->sbrHeader[elementIndex][headerIndex],
383
150k
                       &self->pSbrElement[elementIndex]->transposerSettings,
384
150k
                       synDownsampleFac, qmfFlags, self->flags, overlap, ch,
385
150k
                       self->codecFrameSize);
386
387
150k
      if (sbrError != SBRDEC_OK) {
388
1.39k
        goto bail;
389
1.39k
      }
390
150k
    }
391
97.0k
  }
392
393
  // FDKmemclear(sbr_OverlapBuffer, sizeof(sbr_OverlapBuffer));
394
395
95.6k
  if (self->numSbrElements == 1) {
396
54.9k
    switch (self->coreCodec) {
397
1.10k
      case AOT_AAC_LC:
398
1.10k
      case AOT_SBR:
399
1.10k
      case AOT_PS:
400
3.86k
      case AOT_ER_AAC_SCAL:
401
3.86k
      case AOT_DRM_AAC:
402
3.86k
      case AOT_DRM_SURROUND:
403
3.86k
        if (CreatePsDec(&self->hParametricStereoDec, samplesPerFrame)) {
404
0
          sbrError = SBRDEC_CREATE_ERROR;
405
0
          goto bail;
406
0
        }
407
3.86k
        break;
408
51.0k
      default:
409
51.0k
        break;
410
54.9k
    }
411
54.9k
  }
412
413
  /* Init frame delay slot handling */
414
95.6k
  self->pSbrElement[elementIndex]->useFrameSlot = 0;
415
286k
  for (i = 0; i < ((1) + 1); i++) {
416
191k
    self->pSbrElement[elementIndex]->useHeaderSlot[i] = i;
417
191k
  }
418
419
98.4k
bail:
420
421
98.4k
  return sbrError;
422
95.6k
}
423
424
/*!
425
  \brief Assign QMF domain provided QMF channels to SBR channels.
426
427
  \return void
428
*/
429
98.4k
static void sbrDecoder_AssignQmfChannels2SbrChannels(HANDLE_SBRDECODER self) {
430
98.4k
  int ch, el, absCh_offset = 0;
431
295k
  for (el = 0; el < self->numSbrElements; el++) {
432
196k
    if (self->pSbrElement[el] != NULL) {
433
502k
      for (ch = 0; ch < self->pSbrElement[el]->nChannels; ch++) {
434
305k
        FDK_ASSERT(((absCh_offset + ch) < ((8) + (1))) &&
435
305k
                   ((absCh_offset + ch) < ((8) + (1))));
436
305k
        self->pSbrElement[el]->pSbrChannel[ch]->SbrDec.qmfDomainInCh =
437
305k
            &self->pQmfDomain->QmfDomainIn[absCh_offset + ch];
438
305k
        self->pSbrElement[el]->pSbrChannel[ch]->SbrDec.qmfDomainOutCh =
439
305k
            &self->pQmfDomain->QmfDomainOut[absCh_offset + ch];
440
305k
      }
441
196k
      absCh_offset += self->pSbrElement[el]->nChannels;
442
196k
    }
443
196k
  }
444
98.4k
}
445
446
SBR_ERROR sbrDecoder_Open(HANDLE_SBRDECODER *pSelf,
447
23.8k
                          HANDLE_FDK_QMF_DOMAIN pQmfDomain) {
448
23.8k
  HANDLE_SBRDECODER self = NULL;
449
23.8k
  SBR_ERROR sbrError = SBRDEC_OK;
450
23.8k
  int elIdx;
451
452
23.8k
  if ((pSelf == NULL) || (pQmfDomain == NULL)) {
453
0
    return SBRDEC_INVALID_ARGUMENT;
454
0
  }
455
456
  /* Get memory for this instance */
457
23.8k
  self = GetRam_SbrDecoder();
458
23.8k
  if (self == NULL) {
459
0
    sbrError = SBRDEC_MEM_ALLOC_FAILED;
460
0
    goto bail;
461
0
  }
462
463
23.8k
  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
23.8k
  self->numDelayFrames = (1); /* set to the max value by default */
473
474
  /* Initialize header sync state */
475
214k
  for (elIdx = 0; elIdx < (8); elIdx += 1) {
476
190k
    int i;
477
572k
    for (i = 0; i < (1) + 1; i += 1) {
478
381k
      self->sbrHeader[elIdx][i].syncState = SBR_NOT_INITIALIZED;
479
381k
    }
480
190k
  }
481
482
23.8k
  *pSelf = self;
483
484
23.8k
bail:
485
23.8k
  return sbrError;
486
23.8k
}
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.16M
static int sbrDecoder_isCoreCodecValid(AUDIO_OBJECT_TYPE coreCodec) {
494
1.16M
  switch (coreCodec) {
495
11.9k
    case AOT_AAC_LC:
496
11.9k
    case AOT_SBR:
497
11.9k
    case AOT_PS:
498
61.9k
    case AOT_ER_AAC_SCAL:
499
825k
    case AOT_ER_AAC_ELD:
500
825k
    case AOT_DRM_AAC:
501
825k
    case AOT_DRM_SURROUND:
502
1.16M
    case AOT_USAC:
503
1.16M
      return 1;
504
579
    default:
505
579
      return 0;
506
1.16M
  }
507
1.16M
}
508
509
static void sbrDecoder_DestroyElement(HANDLE_SBRDECODER self,
510
1.29M
                                      const int elementIndex) {
511
1.29M
  if (self->pSbrElement[elementIndex] != NULL) {
512
97.8k
    int ch;
513
514
293k
    for (ch = 0; ch < SBRDEC_MAX_CH_PER_ELEMENT; ch++) {
515
195k
      if (self->pSbrElement[elementIndex]->pSbrChannel[ch] != NULL) {
516
153k
        deleteSbrDec(self->pSbrElement[elementIndex]->pSbrChannel[ch]);
517
153k
        FreeRam_SbrDecChannel(
518
153k
            &self->pSbrElement[elementIndex]->pSbrChannel[ch]);
519
153k
        self->numSbrChannels -= 1;
520
153k
      }
521
195k
    }
522
97.8k
    FreeRam_SbrDecElement(&self->pSbrElement[elementIndex]);
523
97.8k
    self->numSbrElements -= 1;
524
97.8k
  }
525
1.29M
}
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
654k
    const UCHAR configMode, UCHAR *configChanged, const INT downscaleFactor) {
533
654k
  SBR_ERROR sbrError = SBRDEC_OK;
534
654k
  int chCnt = 0;
535
654k
  int nSbrElementsStart;
536
654k
  int nSbrChannelsStart;
537
654k
  if (self == NULL) {
538
0
    return SBRDEC_INVALID_ARGUMENT;
539
0
  }
540
541
654k
  nSbrElementsStart = self->numSbrElements;
542
654k
  nSbrChannelsStart = self->numSbrChannels;
543
544
  /* Check core codec AOT */
545
654k
  if (!sbrDecoder_isCoreCodecValid(coreCodec) || elementIndex >= (8)) {
546
579
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
547
579
    goto bail;
548
579
  }
549
550
653k
  if (elementID != ID_SCE && elementID != ID_CPE && elementID != ID_LFE) {
551
0
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
552
0
    goto bail;
553
0
  }
554
555
653k
  if (self->sampleRateIn == sampleRateIn &&
556
553k
      self->codecFrameSize == samplesPerFrame && self->coreCodec == coreCodec &&
557
513k
      self->pSbrElement[elementIndex] != NULL &&
558
451k
      self->pSbrElement[elementIndex]->elementID == elementID &&
559
449k
      !(self->flags & SBRDEC_FORCE_RESET) &&
560
449k
      ((sampleRateOut == 0) ? 1 : (self->sampleRateOut == sampleRateOut)) &&
561
445k
      ((harmonicSBR == 2) ? 1
562
445k
                          : (self->harmonicSBR ==
563
306k
                             harmonicSBR)) /* The value 2 signalizes that
564
                                              harmonicSBR shall be ignored in
565
                                              the config change detection */
566
653k
  ) {
567
    /* Nothing to do */
568
441k
    return SBRDEC_OK;
569
441k
  } else {
570
212k
    if (configMode & AC_CM_DET_CFG_CHANGE) {
571
114k
      *configChanged = 1;
572
114k
    }
573
212k
  }
574
575
  /* reaching this point the SBR-decoder gets (re-)configured */
576
577
  /* The flags field is used for all elements! */
578
212k
  self->flags &=
579
212k
      (SBRDEC_FORCE_RESET | SBRDEC_FLUSH); /* Keep the global flags. They will
580
                                              be reset after decoding. */
581
212k
  self->flags |= (downscaleFactor > 1) ? SBRDEC_ELD_DOWNSCALE : 0;
582
212k
  self->flags |= (coreCodec == AOT_ER_AAC_ELD) ? SBRDEC_ELD_GRID : 0;
583
212k
  self->flags |= (coreCodec == AOT_ER_AAC_SCAL) ? SBRDEC_SYNTAX_SCAL : 0;
584
212k
  self->flags |=
585
212k
      (coreCodec == AOT_DRM_AAC) ? SBRDEC_SYNTAX_SCAL | SBRDEC_SYNTAX_DRM : 0;
586
212k
  self->flags |= (coreCodec == AOT_DRM_SURROUND)
587
212k
                     ? SBRDEC_SYNTAX_SCAL | SBRDEC_SYNTAX_DRM
588
212k
                     : 0;
589
212k
  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
212k
  self->flags |= (sampleRateIn == sampleRateOut / 4) ? SBRDEC_QUAD_RATE : 0;
593
212k
  self->flags |= (harmonicSBR == 1) ? SBRDEC_USAC_HARMONICSBR : 0;
594
595
212k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
596
114k
    return SBRDEC_OK;
597
114k
  }
598
599
98.4k
  self->sampleRateIn = sampleRateIn;
600
98.4k
  self->codecFrameSize = samplesPerFrame;
601
98.4k
  self->coreCodec = coreCodec;
602
98.4k
  self->harmonicSBR = harmonicSBR;
603
98.4k
  self->downscaleFactor = downscaleFactor;
604
605
  /* Init SBR elements */
606
98.4k
  {
607
98.4k
    int elChannels, ch;
608
609
98.4k
    if (self->pSbrElement[elementIndex] == NULL) {
610
97.8k
      self->pSbrElement[elementIndex] = GetRam_SbrDecElement(elementIndex);
611
97.8k
      if (self->pSbrElement[elementIndex] == NULL) {
612
0
        sbrError = SBRDEC_MEM_ALLOC_FAILED;
613
0
        goto bail;
614
0
      }
615
97.8k
      self->numSbrElements++;
616
97.8k
    } else {
617
598
      self->numSbrChannels -= self->pSbrElement[elementIndex]->nChannels;
618
598
    }
619
620
    /* Determine amount of channels for this element */
621
98.4k
    switch (elementID) {
622
0
      case ID_NONE:
623
53.2k
      case ID_CPE:
624
53.2k
        elChannels = 2;
625
53.2k
        break;
626
9.31k
      case ID_LFE:
627
45.1k
      case ID_SCE:
628
45.1k
        elChannels = 1;
629
45.1k
        break;
630
0
      default:
631
0
        elChannels = 0;
632
0
        break;
633
98.4k
    }
634
635
    /* Handle case of Parametric Stereo */
636
98.4k
    if (elementIndex == 0 && elementID == ID_SCE) {
637
33.8k
      switch (coreCodec) {
638
1.03k
        case AOT_AAC_LC:
639
1.03k
        case AOT_SBR:
640
1.03k
        case AOT_PS:
641
2.84k
        case AOT_ER_AAC_SCAL:
642
2.84k
        case AOT_DRM_AAC:
643
2.84k
        case AOT_DRM_SURROUND:
644
2.84k
          elChannels = 2;
645
2.84k
          break;
646
30.9k
        default:
647
30.9k
          break;
648
33.8k
      }
649
33.8k
    }
650
651
    /* Sanity check to avoid memory leaks */
652
98.4k
    if (elChannels < self->pSbrElement[elementIndex]->nChannels ||
653
98.4k
        (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
98.4k
    self->pSbrElement[elementIndex]->elementID = elementID;
662
98.4k
    self->pSbrElement[elementIndex]->nChannels = elChannels;
663
664
252k
    for (ch = 0; ch < elChannels; ch++) {
665
154k
      if (self->pSbrElement[elementIndex]->pSbrChannel[ch] == NULL) {
666
153k
        self->pSbrElement[elementIndex]->pSbrChannel[ch] =
667
153k
            GetRam_SbrDecChannel(chCnt);
668
153k
        if (self->pSbrElement[elementIndex]->pSbrChannel[ch] == NULL) {
669
0
          sbrError = SBRDEC_MEM_ALLOC_FAILED;
670
0
          goto bail;
671
0
        }
672
153k
      }
673
154k
      self->numSbrChannels++;
674
675
154k
      sbrDecoder_drcInitChannel(&self->pSbrElement[elementIndex]
676
154k
                                     ->pSbrChannel[ch]
677
154k
                                     ->SbrDec.sbrDrcChannel);
678
679
154k
      chCnt++;
680
154k
    }
681
98.4k
  }
682
683
98.4k
  if (!self->pQmfDomain->globalConf.qmfDomainExplicitConfig) {
684
98.4k
    self->pQmfDomain->globalConf.nInputChannels_requested =
685
98.4k
        self->numSbrChannels;
686
98.4k
    self->pQmfDomain->globalConf.nOutputChannels_requested =
687
98.4k
        fMax((INT)self->numSbrChannels,
688
98.4k
             (INT)self->pQmfDomain->globalConf.nOutputChannels_requested);
689
98.4k
  }
690
691
  /* Make sure each SBR channel has one QMF channel assigned even if
692
   * numSbrChannels or element set-up has changed. */
693
98.4k
  sbrDecoder_AssignQmfChannels2SbrChannels(self);
694
695
  /* clear error flags for all delay slots */
696
98.4k
  FDKmemclear(self->pSbrElement[elementIndex]->frameErrorFlag,
697
98.4k
              ((1) + 1) * sizeof(UCHAR));
698
699
98.4k
  {
700
98.4k
    int overlap;
701
702
98.4k
    if (coreCodec == AOT_ER_AAC_ELD) {
703
58.6k
      overlap = 0;
704
58.6k
    } else if (self->flags & SBRDEC_QUAD_RATE) {
705
9.14k
      overlap = (3 * 4);
706
30.5k
    } else {
707
30.5k
      overlap = (3 * 2);
708
30.5k
    }
709
    /* Initialize this instance */
710
98.4k
    sbrError = sbrDecoder_ResetElement(self, sampleRateIn, sampleRateOut,
711
98.4k
                                       samplesPerFrame, elementID, elementIndex,
712
98.4k
                                       overlap);
713
98.4k
  }
714
715
99.0k
bail:
716
99.0k
  if (sbrError != SBRDEC_OK) {
717
3.38k
    if ((nSbrElementsStart < self->numSbrElements) ||
718
2.80k
        (nSbrChannelsStart < self->numSbrChannels)) {
719
      /* Free the memory allocated for this element */
720
2.80k
      sbrDecoder_DestroyElement(self, elementIndex);
721
2.80k
    } else if ((elementIndex < (8)) &&
722
579
               (self->pSbrElement[elementIndex] !=
723
579
                NULL)) { /* Set error flag to trigger concealment */
724
0
      setFrameErrorFlag(self->pSbrElement[elementIndex], FRAME_ERROR);
725
0
    }
726
3.38k
  }
727
728
99.0k
  return sbrError;
729
98.4k
}
730
731
/**
732
 * \brief Free config dependent SBR memory.
733
 * \param self SBR decoder instance handle
734
 */
735
137k
SBR_ERROR sbrDecoder_FreeMem(HANDLE_SBRDECODER *self) {
736
137k
  int i;
737
137k
  int elIdx;
738
739
137k
  if (self != NULL && *self != NULL) {
740
1.24M
    for (i = 0; i < (8); i++) {
741
1.10M
      sbrDecoder_DestroyElement(*self, i);
742
1.10M
    }
743
744
1.24M
    for (elIdx = 0; elIdx < (8); elIdx += 1) {
745
3.30M
      for (i = 0; i < (1) + 1; i += 1) {
746
2.20M
        (*self)->sbrHeader[elIdx][i].syncState = SBR_NOT_INITIALIZED;
747
2.20M
      }
748
1.10M
    }
749
137k
  }
750
751
137k
  return SBRDEC_OK;
752
137k
}
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
219k
                                         const int numElementChannels) {
769
219k
  SBR_ERROR errorStatus = SBRDEC_OK;
770
771
  /*
772
    change of control data, reset decoder
773
  */
774
219k
  errorStatus = resetFreqBandTables(hSbrHeader, self->flags);
775
776
219k
  if (errorStatus == SBRDEC_OK) {
777
186k
    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
39.9k
      hSbrHeader->freqBandData.lowSubband = hSbrHeader->numberOfAnalysisBands;
788
39.9k
      hSbrHeader->freqBandData.highSubband = hSbrHeader->numberOfAnalysisBands;
789
39.9k
    }
790
791
    /* Trigger a reset before processing this slot */
792
186k
    hSbrHeader->status |= SBRDEC_HDR_STAT_RESET;
793
186k
  }
794
795
219k
  return errorStatus;
796
219k
}
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
510k
                      const INT downscaleFactor) {
806
510k
  SBR_HEADER_STATUS headerStatus;
807
510k
  HANDLE_SBR_HEADER_DATA hSbrHeader;
808
510k
  SBR_ERROR sbrError = SBRDEC_OK;
809
510k
  int headerIndex;
810
510k
  UINT flagsSaved =
811
510k
      0; /* flags should not be changed in AC_CM_DET_CFG_CHANGE - mode after
812
            parsing */
813
814
510k
  if (self == NULL || elementIndex >= (8)) {
815
0
    return SBRDEC_UNSUPPORTED_CONFIG;
816
0
  }
817
818
510k
  if (!sbrDecoder_isCoreCodecValid(coreCodec)) {
819
0
    return SBRDEC_UNSUPPORTED_CONFIG;
820
0
  }
821
822
510k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
823
330k
    flagsSaved = self->flags; /* store */
824
330k
  }
825
826
510k
  sbrError = sbrDecoder_InitElement(
827
510k
      self, sampleRateIn, sampleRateOut, samplesPerFrame, coreCodec, elementID,
828
510k
      elementIndex, harmonicSBR, stereoConfigIndex, configMode, configChanged,
829
510k
      downscaleFactor);
830
831
510k
  if ((sbrError != SBRDEC_OK) || (elementID == ID_LFE)) {
832
65.3k
    goto bail;
833
65.3k
  }
834
835
445k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
836
289k
    hSbrHeader = NULL;
837
289k
  } else {
838
155k
    headerIndex = getHeaderSlot(self->pSbrElement[elementIndex]->useFrameSlot,
839
155k
                                self->pSbrElement[elementIndex]->useHeaderSlot);
840
841
155k
    hSbrHeader = &(self->sbrHeader[elementIndex][headerIndex]);
842
155k
  }
843
844
445k
  headerStatus = sbrGetHeaderData(hSbrHeader, hBs, self->flags, 0, configMode);
845
846
445k
  if (coreCodec == AOT_USAC) {
847
167k
    if (configMode & AC_CM_DET_CFG_CHANGE) {
848
107k
      self->flags = flagsSaved; /* restore */
849
107k
    }
850
167k
    return sbrError;
851
167k
  }
852
853
277k
  if (configMode & AC_CM_ALLOC_MEM) {
854
95.7k
    SBR_DECODER_ELEMENT *pSbrElement;
855
856
95.7k
    pSbrElement = self->pSbrElement[elementIndex];
857
858
    /* Sanity check */
859
95.7k
    if (pSbrElement != NULL) {
860
95.7k
      if ((elementID == ID_CPE && pSbrElement->nChannels != 2) ||
861
95.7k
          (elementID != ID_CPE && pSbrElement->nChannels != 1)) {
862
0
        return SBRDEC_UNSUPPORTED_CONFIG;
863
0
      }
864
95.7k
      if (headerStatus == HEADER_RESET) {
865
69.6k
        sbrError = sbrDecoder_HeaderUpdate(self, hSbrHeader, headerStatus,
866
69.6k
                                           pSbrElement->pSbrChannel,
867
69.6k
                                           pSbrElement->nChannels);
868
869
69.6k
        if (sbrError == SBRDEC_OK) {
870
64.1k
          hSbrHeader->syncState = SBR_HEADER;
871
64.1k
          hSbrHeader->status |= SBRDEC_HDR_STAT_UPDATE;
872
64.1k
        } else {
873
5.54k
          hSbrHeader->syncState = SBR_NOT_INITIALIZED;
874
5.54k
          hSbrHeader->status = HEADER_ERROR;
875
5.54k
        }
876
69.6k
      }
877
95.7k
    }
878
95.7k
  }
879
343k
bail:
880
343k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
881
223k
    self->flags = flagsSaved; /* restore */
882
223k
  }
883
343k
  return sbrError;
884
277k
}
885
886
SBR_ERROR sbrDecoder_SetParam(HANDLE_SBRDECODER self, const SBRDEC_PARAM param,
887
1.25M
                              const INT value) {
888
1.25M
  SBR_ERROR errorStatus = SBRDEC_OK;
889
890
  /* configure the subsystems */
891
1.25M
  switch (param) {
892
297k
    case SBR_SYSTEM_BITSTREAM_DELAY:
893
297k
      if (value < 0 || value > (1)) {
894
0
        errorStatus = SBRDEC_SET_PARAM_FAIL;
895
0
        break;
896
0
      }
897
297k
      if (self == NULL) {
898
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
899
297k
      } else {
900
297k
        self->numDelayFrames = (UCHAR)value;
901
297k
      }
902
297k
      break;
903
396k
    case SBR_QMF_MODE:
904
396k
      if (self == NULL) {
905
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
906
396k
      } else {
907
396k
        if (value == 1) {
908
117k
          self->flags |= SBRDEC_LOW_POWER;
909
278k
        } else {
910
278k
          self->flags &= ~SBRDEC_LOW_POWER;
911
278k
        }
912
396k
      }
913
396k
      break;
914
34.4k
    case SBR_LD_QMF_TIME_ALIGN:
915
34.4k
      if (self == NULL) {
916
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
917
34.4k
      } else {
918
34.4k
        if (value == 1) {
919
2.07k
          self->flags |= SBRDEC_LD_MPS_QMF;
920
32.3k
        } else {
921
32.3k
          self->flags &= ~SBRDEC_LD_MPS_QMF;
922
32.3k
        }
923
34.4k
      }
924
34.4k
      break;
925
257k
    case SBR_FLUSH_DATA:
926
257k
      if (value != 0) {
927
23
        if (self == NULL) {
928
0
          errorStatus = SBRDEC_NOT_INITIALIZED;
929
23
        } else {
930
23
          self->flags |= SBRDEC_FLUSH;
931
23
        }
932
23
      }
933
257k
      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
6.96k
    case SBR_BS_INTERRUPTION: {
944
6.96k
      int elementIndex;
945
946
6.96k
      if (self == NULL) {
947
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
948
0
        break;
949
0
      }
950
951
      /* Loop over SBR elements */
952
12.8k
      for (elementIndex = 0; elementIndex < self->numSbrElements;
953
6.96k
           elementIndex++) {
954
5.87k
        if (self->pSbrElement[elementIndex] != NULL) {
955
5.86k
          HANDLE_SBR_HEADER_DATA hSbrHeader;
956
5.86k
          int headerIndex =
957
5.86k
              getHeaderSlot(self->pSbrElement[elementIndex]->useFrameSlot,
958
5.86k
                            self->pSbrElement[elementIndex]->useHeaderSlot);
959
960
5.86k
          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
5.86k
          if (hSbrHeader->syncState != SBR_NOT_INITIALIZED) {
965
5.77k
            hSbrHeader->syncState = UPSAMPLING;
966
5.77k
            hSbrHeader->status |= SBRDEC_HDR_STAT_UPDATE;
967
5.77k
          }
968
5.86k
        }
969
5.87k
      }
970
6.96k
    } break;
971
972
257k
    case SBR_SKIP_QMF:
973
257k
      if (self == NULL) {
974
0
        errorStatus = SBRDEC_NOT_INITIALIZED;
975
257k
      } else {
976
257k
        if (value == 1) {
977
14.0k
          self->flags |= SBRDEC_SKIP_QMF_ANA;
978
243k
        } else {
979
243k
          self->flags &= ~SBRDEC_SKIP_QMF_ANA;
980
243k
        }
981
257k
        if (value == 2) {
982
105k
          self->flags |= SBRDEC_SKIP_QMF_SYN;
983
152k
        } else {
984
152k
          self->flags &= ~SBRDEC_SKIP_QMF_SYN;
985
152k
        }
986
257k
      }
987
257k
      break;
988
0
    default:
989
0
      errorStatus = SBRDEC_SET_PARAM_FAIL;
990
0
      break;
991
1.25M
  } /* switch(param) */
992
993
1.25M
  return (errorStatus);
994
1.25M
}
995
996
static SBRDEC_DRC_CHANNEL *sbrDecoder_drcGetChannel(
997
445k
    const HANDLE_SBRDECODER self, const INT channel) {
998
445k
  SBRDEC_DRC_CHANNEL *pSbrDrcChannelData = NULL;
999
445k
  int elementIndex, elChanIdx = 0, numCh = 0;
1000
1001
1.08M
  for (elementIndex = 0; (elementIndex < (8)) && (numCh <= channel);
1002
645k
       elementIndex++) {
1003
645k
    SBR_DECODER_ELEMENT *pSbrElement = self->pSbrElement[elementIndex];
1004
645k
    int c, elChannels;
1005
1006
645k
    elChanIdx = 0;
1007
645k
    if (pSbrElement == NULL) break;
1008
1009
    /* Determine amount of channels for this element */
1010
640k
    switch (pSbrElement->elementID) {
1011
363k
      case ID_CPE:
1012
363k
        elChannels = 2;
1013
363k
        break;
1014
28.3k
      case ID_LFE:
1015
276k
      case ID_SCE:
1016
276k
        elChannels = 1;
1017
276k
        break;
1018
0
      case ID_NONE:
1019
0
      default:
1020
0
        elChannels = 0;
1021
0
        break;
1022
640k
    }
1023
1024
    /* Limit with actual allocated element channels */
1025
640k
    elChannels = fMin(elChannels, pSbrElement->nChannels);
1026
1027
1.51M
    for (c = 0; (c < elChannels) && (numCh <= channel); c++) {
1028
869k
      if (pSbrElement->pSbrChannel[elChanIdx] != NULL) {
1029
869k
        numCh++;
1030
869k
        elChanIdx++;
1031
869k
      }
1032
869k
    }
1033
640k
  }
1034
445k
  elementIndex -= 1;
1035
445k
  elChanIdx -= 1;
1036
1037
445k
  if (elChanIdx < 0 || elementIndex < 0) {
1038
4.38k
    return NULL;
1039
4.38k
  }
1040
1041
441k
  if (self->pSbrElement[elementIndex] != NULL) {
1042
441k
    if (self->pSbrElement[elementIndex]->pSbrChannel[elChanIdx] != NULL) {
1043
441k
      pSbrDrcChannelData = &self->pSbrElement[elementIndex]
1044
441k
                                ->pSbrChannel[elChanIdx]
1045
441k
                                ->SbrDec.sbrDrcChannel;
1046
441k
    }
1047
441k
  }
1048
1049
441k
  return (pSbrDrcChannelData);
1050
445k
}
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
171k
                                    UCHAR winSequence, USHORT *pBandTop) {
1057
171k
  SBRDEC_DRC_CHANNEL *pSbrDrcChannelData = NULL;
1058
171k
  int band, isValidData = 0;
1059
1060
171k
  if (self == NULL) {
1061
0
    return SBRDEC_NOT_INITIALIZED;
1062
0
  }
1063
171k
  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
336k
  for (band = 0; band < (int)numBands; band += 1) {
1069
176k
    if (!((pNextFact_mag[band] == FL2FXCONST_DBL(0.5)) &&
1070
165k
          (nextFact_exp == 1)) &&
1071
11.6k
        !((pNextFact_mag[band] == (FIXP_DBL)MAXVAL_DBL) &&
1072
11.6k
          (nextFact_exp == 0))) {
1073
11.6k
      isValidData = 1;
1074
11.6k
      break;
1075
11.6k
    }
1076
176k
  }
1077
1078
  /* Find the right SBR channel */
1079
171k
  pSbrDrcChannelData = sbrDecoder_drcGetChannel(self, ch);
1080
1081
171k
  if (pSbrDrcChannelData != NULL) {
1082
171k
    if (pSbrDrcChannelData->enable ||
1083
156k
        isValidData) { /* Activate processing only with real and valid data */
1084
16.4k
      int i;
1085
1086
16.4k
      pSbrDrcChannelData->enable = 1;
1087
16.4k
      pSbrDrcChannelData->numBandsNext = numBands;
1088
1089
16.4k
      pSbrDrcChannelData->winSequenceNext = winSequence;
1090
16.4k
      pSbrDrcChannelData->drcInterpolationSchemeNext = drcInterpolationScheme;
1091
16.4k
      pSbrDrcChannelData->nextFact_exp = nextFact_exp;
1092
1093
83.5k
      for (i = 0; i < (int)numBands; i++) {
1094
67.0k
        pSbrDrcChannelData->bandTopNext[i] = pBandTop[i];
1095
67.0k
        pSbrDrcChannelData->nextFact_mag[i] = pNextFact_mag[i];
1096
67.0k
      }
1097
16.4k
    }
1098
171k
  }
1099
1100
171k
  return SBRDEC_OK;
1101
171k
}
1102
1103
306k
void sbrDecoder_drcDisable(HANDLE_SBRDECODER self, INT ch) {
1104
306k
  SBRDEC_DRC_CHANNEL *pSbrDrcChannelData = NULL;
1105
1106
306k
  if ((self == NULL) || (ch > (8)) || (self->numSbrElements == 0) ||
1107
274k
      (self->numSbrChannels == 0)) {
1108
32.5k
    return;
1109
32.5k
  }
1110
1111
  /* Find the right SBR channel */
1112
274k
  pSbrDrcChannelData = sbrDecoder_drcGetChannel(self, ch);
1113
1114
274k
  if (pSbrDrcChannelData != NULL) {
1115
269k
    sbrDecoder_drcInitChannel(pSbrDrcChannelData);
1116
269k
  }
1117
274k
}
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
319k
                           UINT acFlags, UINT acElFlags[]) {
1124
319k
  SBR_DECODER_ELEMENT *hSbrElement = NULL;
1125
319k
  HANDLE_SBR_HEADER_DATA hSbrHeader = NULL;
1126
319k
  HANDLE_SBR_CHANNEL *pSbrChannel;
1127
1128
319k
  SBR_FRAME_DATA *hFrameDataLeft = NULL;
1129
319k
  SBR_FRAME_DATA *hFrameDataRight = NULL;
1130
319k
  SBR_FRAME_DATA frameDataLeftCopy;
1131
319k
  SBR_FRAME_DATA frameDataRightCopy;
1132
1133
319k
  SBR_ERROR errorStatus = SBRDEC_OK;
1134
319k
  SBR_HEADER_STATUS headerStatus = HEADER_NOT_PRESENT;
1135
1136
319k
  INT startPos = FDKgetValidBits(hBs);
1137
319k
  FDK_CRCINFO crcInfo;
1138
319k
  INT crcReg = 0;
1139
319k
  USHORT sbrCrc = 0;
1140
319k
  UINT crcPoly;
1141
319k
  UINT crcStartValue = 0;
1142
319k
  UINT crcLen;
1143
1144
319k
  HANDLE_FDK_BITSTREAM hBsOriginal = hBs;
1145
319k
  FDK_BITSTREAM bsBwd;
1146
1147
319k
  const int fGlobalIndependencyFlag = acFlags & AC_INDEP;
1148
319k
  const int bs_pvc = acElFlags[elementIndex] & AC_EL_USAC_PVC;
1149
319k
  const int bs_interTes = acElFlags[elementIndex] & AC_EL_USAC_ITES;
1150
319k
  int stereo;
1151
319k
  int fDoDecodeSbrData = 1;
1152
319k
  int alignBits = 0;
1153
1154
319k
  int lastSlot, lastHdrSlot = 0, thisHdrSlot = 0;
1155
1156
319k
  if (*count <= 0) {
1157
44.8k
    setFrameErrorFlag(self->pSbrElement[elementIndex], FRAME_ERROR);
1158
44.8k
    return SBRDEC_OK;
1159
44.8k
  }
1160
1161
  /* SBR sanity checks */
1162
274k
  if (self == NULL) {
1163
0
    errorStatus = SBRDEC_NOT_INITIALIZED;
1164
0
    goto bail;
1165
0
  }
1166
1167
  /* Reverse bits of DRM SBR payload */
1168
274k
  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
274k
  startPos = FDKgetValidBits(hBs);
1212
1213
  /* SBR sanity checks */
1214
274k
  if (self->pSbrElement[elementIndex] == NULL) {
1215
0
    errorStatus = SBRDEC_NOT_INITIALIZED;
1216
0
    goto bail;
1217
0
  }
1218
274k
  hSbrElement = self->pSbrElement[elementIndex];
1219
1220
274k
  lastSlot = (hSbrElement->useFrameSlot > 0) ? hSbrElement->useFrameSlot - 1
1221
274k
                                             : self->numDelayFrames;
1222
274k
  lastHdrSlot = hSbrElement->useHeaderSlot[lastSlot];
1223
274k
  thisHdrSlot = getHeaderSlot(
1224
274k
      hSbrElement->useFrameSlot,
1225
274k
      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
274k
  hSbrHeader = &self->sbrHeader[elementIndex][thisHdrSlot];
1230
1231
274k
  pSbrChannel = hSbrElement->pSbrChannel;
1232
274k
  stereo = (hSbrElement->elementID == ID_CPE) ? 1 : 0;
1233
1234
274k
  hFrameDataLeft = &self->pSbrElement[elementIndex]
1235
274k
                        ->pSbrChannel[0]
1236
274k
                        ->frameData[hSbrElement->useFrameSlot];
1237
274k
  if (stereo) {
1238
106k
    hFrameDataRight = &self->pSbrElement[elementIndex]
1239
106k
                           ->pSbrChannel[1]
1240
106k
                           ->frameData[hSbrElement->useFrameSlot];
1241
106k
  }
1242
1243
  /* store frameData; new parsed frameData possibly corrupted */
1244
274k
  FDKmemcpy(&frameDataLeftCopy, hFrameDataLeft, sizeof(SBR_FRAME_DATA));
1245
274k
  if (stereo) {
1246
106k
    FDKmemcpy(&frameDataRightCopy, hFrameDataRight, sizeof(SBR_FRAME_DATA));
1247
106k
  }
1248
1249
  /* reset PS flag; will be set after PS was found */
1250
274k
  self->flags &= ~SBRDEC_PS_DECODED;
1251
1252
274k
  if (hSbrHeader->status & SBRDEC_HDR_STAT_UPDATE) {
1253
    /* Got a new header from extern (e.g. from an ASC) */
1254
21.9k
    headerStatus = HEADER_OK;
1255
21.9k
    hSbrHeader->status &= ~SBRDEC_HDR_STAT_UPDATE;
1256
252k
  } 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
37.1k
    copySbrHeader(hSbrHeader, &self->sbrHeader[elementIndex][lastHdrSlot]);
1260
37.1k
  }
1261
1262
  /*
1263
     Check if bit stream data is valid and matches the element context
1264
  */
1265
274k
  if (((prevElement != ID_SCE) && (prevElement != ID_CPE)) ||
1266
272k
      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.04k
    fDoDecodeSbrData = 0;
1270
2.04k
  }
1271
1272
274k
  if (fDoDecodeSbrData) {
1273
272k
    if ((INT)FDKgetValidBits(hBs) <= 0) {
1274
5
      fDoDecodeSbrData = 0;
1275
5
    }
1276
272k
  }
1277
1278
  /*
1279
     SBR CRC-check
1280
  */
1281
274k
  if (fDoDecodeSbrData) {
1282
272k
    if (crcFlag) {
1283
32.0k
      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
32.0k
        default:
1291
32.0k
          crcPoly = 0x0633;
1292
32.0k
          crcLen = 10;
1293
32.0k
          crcStartValue = 0x00000000;
1294
32.0k
          break;
1295
32.0k
      }
1296
32.0k
      sbrCrc = (USHORT)FDKreadBits(hBs, crcLen);
1297
      /* Setup CRC decoder */
1298
32.0k
      FDKcrcInit(&crcInfo, crcPoly, crcStartValue, crcLen);
1299
      /* Start CRC region */
1300
32.0k
      crcReg = FDKcrcStartReg(&crcInfo, hBs, 0);
1301
32.0k
    }
1302
272k
  } /* if (fDoDecodeSbrData) */
1303
1304
  /*
1305
     Read in the header data and issue a reset if change occured
1306
  */
1307
274k
  if (fDoDecodeSbrData) {
1308
272k
    int sbrHeaderPresent;
1309
1310
272k
    if (self->flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC)) {
1311
189k
      SBR_HEADER_DATA_BS_INFO newSbrInfo;
1312
189k
      int sbrInfoPresent;
1313
1314
189k
      if (bs_interTes) {
1315
60.1k
        self->flags |= SBRDEC_USAC_ITES;
1316
129k
      } else {
1317
129k
        self->flags &= ~SBRDEC_USAC_ITES;
1318
129k
      }
1319
1320
189k
      if (fGlobalIndependencyFlag) {
1321
147k
        self->flags |= SBRDEC_USAC_INDEP;
1322
147k
        sbrInfoPresent = 1;
1323
147k
        sbrHeaderPresent = 1;
1324
147k
      } else {
1325
41.7k
        self->flags &= ~SBRDEC_USAC_INDEP;
1326
41.7k
        sbrInfoPresent = FDKreadBit(hBs);
1327
41.7k
        if (sbrInfoPresent) {
1328
6.49k
          sbrHeaderPresent = FDKreadBit(hBs);
1329
35.2k
        } else {
1330
35.2k
          sbrHeaderPresent = 0;
1331
35.2k
        }
1332
41.7k
      }
1333
1334
189k
      if (sbrInfoPresent) {
1335
154k
        newSbrInfo.ampResolution = FDKreadBit(hBs);
1336
154k
        newSbrInfo.xover_band = FDKreadBits(hBs, 4);
1337
154k
        newSbrInfo.sbr_preprocessing = FDKreadBit(hBs);
1338
154k
        if (bs_pvc) {
1339
89.4k
          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
89.4k
          if (newSbrInfo.pvc_mode > 2) {
1343
7.96k
            headerStatus = HEADER_ERROR;
1344
7.96k
          }
1345
89.4k
          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
9.12k
            newSbrInfo.pvc_mode = 0;
1350
9.12k
          }
1351
89.4k
        } else {
1352
64.6k
          newSbrInfo.pvc_mode = 0;
1353
64.6k
        }
1354
154k
        if (headerStatus != HEADER_ERROR) {
1355
146k
          if (FDKmemcmp(&hSbrHeader->bs_info, &newSbrInfo,
1356
146k
                        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
59.3k
            if ((hSbrHeader->bs_info.pvc_mode != newSbrInfo.pvc_mode) ||
1362
49.8k
                (hSbrHeader->bs_info.xover_band != newSbrInfo.xover_band)) {
1363
49.8k
              headerStatus = HEADER_RESET;
1364
49.8k
            } else {
1365
9.49k
              headerStatus = HEADER_OK;
1366
9.49k
            }
1367
1368
59.3k
            hSbrHeader->bs_info = newSbrInfo;
1369
86.7k
          } else {
1370
86.7k
            headerStatus = HEADER_OK;
1371
86.7k
          }
1372
146k
        }
1373
154k
      }
1374
189k
      if (headerStatus == HEADER_ERROR) {
1375
        /* Corrupt SBR info data, do not decode and switch to UPSAMPLING */
1376
7.96k
        hSbrHeader->syncState = hSbrHeader->syncState > UPSAMPLING
1377
7.96k
                                    ? UPSAMPLING
1378
7.96k
                                    : hSbrHeader->syncState;
1379
7.96k
        fDoDecodeSbrData = 0;
1380
7.96k
        sbrHeaderPresent = 0;
1381
7.96k
      }
1382
1383
189k
      if (sbrHeaderPresent && fDoDecodeSbrData) {
1384
144k
        int useDfltHeader;
1385
1386
144k
        useDfltHeader = FDKreadBit(hBs);
1387
1388
144k
        if (useDfltHeader) {
1389
79.4k
          sbrHeaderPresent = 0;
1390
79.4k
          if (FDKmemcmp(&hSbrHeader->bs_data, &hSbrHeader->bs_dflt,
1391
79.4k
                        sizeof(SBR_HEADER_DATA_BS)) ||
1392
63.4k
              hSbrHeader->syncState != SBR_ACTIVE) {
1393
18.6k
            hSbrHeader->bs_data = hSbrHeader->bs_dflt;
1394
18.6k
            headerStatus = HEADER_RESET;
1395
18.6k
          }
1396
79.4k
        }
1397
144k
      }
1398
189k
    } else {
1399
83.1k
      sbrHeaderPresent = FDKreadBit(hBs);
1400
83.1k
    }
1401
1402
272k
    if (sbrHeaderPresent) {
1403
114k
      headerStatus = sbrGetHeaderData(hSbrHeader, hBs, self->flags, 1, 0);
1404
114k
    }
1405
1406
272k
    if (headerStatus == HEADER_RESET) {
1407
109k
      errorStatus = sbrDecoder_HeaderUpdate(
1408
109k
          self, hSbrHeader, headerStatus, pSbrChannel, hSbrElement->nChannels);
1409
1410
109k
      if (errorStatus == SBRDEC_OK) {
1411
82.8k
        hSbrHeader->syncState = SBR_HEADER;
1412
82.8k
      } else {
1413
27.0k
        hSbrHeader->syncState = SBR_NOT_INITIALIZED;
1414
27.0k
        headerStatus = HEADER_ERROR;
1415
27.0k
      }
1416
109k
    }
1417
1418
272k
    if (errorStatus != SBRDEC_OK) {
1419
27.0k
      fDoDecodeSbrData = 0;
1420
27.0k
    }
1421
272k
  } /* if (fDoDecodeSbrData) */
1422
1423
  /*
1424
    Print debugging output only if state has changed
1425
  */
1426
1427
  /* read frame data */
1428
274k
  if ((hSbrHeader->syncState >= SBR_HEADER) && fDoDecodeSbrData) {
1429
232k
    int sbrFrameOk;
1430
    /* read the SBR element data */
1431
232k
    if (!stereo && (self->hParametricStereoDec != NULL)) {
1432
      /* update slot index for PS bitstream parsing */
1433
24.2k
      self->hParametricStereoDec->bsLastSlot =
1434
24.2k
          self->hParametricStereoDec->bsReadSlot;
1435
24.2k
      self->hParametricStereoDec->bsReadSlot = hSbrElement->useFrameSlot;
1436
24.2k
    }
1437
232k
    sbrFrameOk = sbrGetChannelElement(
1438
232k
        hSbrHeader, hFrameDataLeft, (stereo) ? hFrameDataRight : NULL,
1439
232k
        &pSbrChannel[0]->prevFrameData,
1440
232k
        pSbrChannel[0]->SbrDec.PvcStaticData.pvc_mode_last, hBs,
1441
232k
        (stereo) ? NULL : self->hParametricStereoDec, self->flags,
1442
232k
        self->pSbrElement[elementIndex]->transposerSettings.overlap);
1443
1444
232k
    if (!sbrFrameOk) {
1445
20.1k
      fDoDecodeSbrData = 0;
1446
211k
    } else {
1447
211k
      INT valBits;
1448
1449
211k
      if (bsPayLen > 0) {
1450
24.3k
        valBits = bsPayLen - ((INT)startPos - (INT)FDKgetValidBits(hBs));
1451
187k
      } else {
1452
187k
        valBits = (INT)FDKgetValidBits(hBs);
1453
187k
      }
1454
1455
      /* sanity check of remaining bits */
1456
211k
      if (valBits < 0) {
1457
25.2k
        fDoDecodeSbrData = 0;
1458
186k
      } else {
1459
186k
        switch (self->coreCodec) {
1460
0
          case AOT_SBR:
1461
0
          case AOT_PS:
1462
2.31k
          case AOT_AAC_LC: {
1463
            /* This sanity check is only meaningful with General Audio
1464
             * bitstreams */
1465
2.31k
            alignBits = valBits & 0x7;
1466
1467
2.31k
            if (valBits > alignBits) {
1468
399
              fDoDecodeSbrData = 0;
1469
399
            }
1470
2.31k
          } break;
1471
184k
          default:
1472
            /* No sanity check available */
1473
184k
            break;
1474
186k
        }
1475
186k
      }
1476
211k
    }
1477
232k
  } 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
42.4k
    errorStatus = SBRDEC_PARSE_ERROR;
1482
42.4k
  }
1483
1484
274k
  if (crcFlag && (hSbrHeader->syncState >= SBR_HEADER) && fDoDecodeSbrData) {
1485
13.5k
    FDKpushFor(hBs, alignBits);
1486
13.5k
    FDKcrcEndReg(&crcInfo, hBs, crcReg); /* End CRC region */
1487
13.5k
    FDKpushBack(hBs, alignBits);
1488
    /* Check CRC */
1489
13.5k
    if ((FDKcrcGetCRC(&crcInfo) ^ crcStartValue) != sbrCrc) {
1490
12.1k
      fDoDecodeSbrData = 0;
1491
12.1k
      if (headerStatus != HEADER_NOT_PRESENT) {
1492
11.1k
        headerStatus = HEADER_ERROR;
1493
11.1k
        hSbrHeader->syncState = SBR_NOT_INITIALIZED;
1494
11.1k
      }
1495
12.1k
    }
1496
13.5k
  }
1497
1498
274k
  if (!fDoDecodeSbrData) {
1499
    /* Set error flag for this slot to trigger concealment */
1500
94.9k
    setFrameErrorFlag(self->pSbrElement[elementIndex], FRAME_ERROR);
1501
    /* restore old frameData for concealment */
1502
94.9k
    FDKmemcpy(hFrameDataLeft, &frameDataLeftCopy, sizeof(SBR_FRAME_DATA));
1503
94.9k
    if (stereo) {
1504
34.2k
      FDKmemcpy(hFrameDataRight, &frameDataRightCopy, sizeof(SBR_FRAME_DATA));
1505
34.2k
    }
1506
94.9k
    errorStatus = SBRDEC_PARSE_ERROR;
1507
179k
  } else {
1508
    /* Everything seems to be ok so clear the error flag */
1509
179k
    setFrameErrorFlag(self->pSbrElement[elementIndex], FRAME_OK);
1510
179k
  }
1511
1512
274k
  if (!stereo) {
1513
    /* Turn coupling off explicitely to avoid access to absent right frame data
1514
       that might occur with corrupt bitstreams. */
1515
167k
    hFrameDataLeft->coupling = COUPLING_OFF;
1516
167k
  }
1517
1518
274k
bail:
1519
1520
274k
  if (self != NULL) {
1521
274k
    if (self->flags & SBRDEC_SYNTAX_DRM) {
1522
0
      hBs = hBsOriginal;
1523
0
    }
1524
1525
274k
    if (errorStatus != SBRDEC_NOT_INITIALIZED) {
1526
274k
      int useOldHdr =
1527
274k
          ((headerStatus == HEADER_NOT_PRESENT) ||
1528
219k
           (headerStatus == HEADER_ERROR) ||
1529
173k
           (headerStatus == HEADER_RESET && errorStatus == SBRDEC_PARSE_ERROR))
1530
274k
              ? 1
1531
274k
              : 0;
1532
1533
274k
      if (!useOldHdr && (thisHdrSlot != lastHdrSlot) && (hSbrHeader != NULL)) {
1534
6.69k
        useOldHdr |=
1535
6.69k
            (compareSbrHeader(hSbrHeader,
1536
6.69k
                              &self->sbrHeader[elementIndex][lastHdrSlot]) == 0)
1537
6.69k
                ? 1
1538
6.69k
                : 0;
1539
6.69k
      }
1540
1541
274k
      if (hSbrElement != NULL) {
1542
274k
        if (useOldHdr != 0) {
1543
          /* Use the old header for this frame */
1544
137k
          hSbrElement->useHeaderSlot[hSbrElement->useFrameSlot] = lastHdrSlot;
1545
137k
        } else {
1546
          /* Use the new header for this frame */
1547
136k
          hSbrElement->useHeaderSlot[hSbrElement->useFrameSlot] = thisHdrSlot;
1548
136k
        }
1549
1550
        /* Move frame pointer to the next slot which is up to be decoded/applied
1551
         * next */
1552
274k
        hSbrElement->useFrameSlot =
1553
274k
            (hSbrElement->useFrameSlot + 1) % (self->numDelayFrames + 1);
1554
274k
      }
1555
274k
    }
1556
274k
  }
1557
1558
274k
  *count -= startPos - (INT)FDKgetValidBits(hBs);
1559
1560
274k
  return errorStatus;
1561
274k
}
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
306k
    int *numOutChannels, const int psPossible) {
1581
306k
  SBR_DECODER_ELEMENT *hSbrElement = self->pSbrElement[elementIndex];
1582
306k
  HANDLE_SBR_CHANNEL *pSbrChannel =
1583
306k
      self->pSbrElement[elementIndex]->pSbrChannel;
1584
306k
  HANDLE_SBR_HEADER_DATA hSbrHeader =
1585
306k
      &self->sbrHeader[elementIndex]
1586
306k
                      [hSbrElement->useHeaderSlot[hSbrElement->useFrameSlot]];
1587
306k
  HANDLE_PS_DEC h_ps_d = self->hParametricStereoDec;
1588
1589
  /* get memory for frame data from scratch */
1590
306k
  SBR_FRAME_DATA *hFrameDataLeft = NULL;
1591
306k
  SBR_FRAME_DATA *hFrameDataRight = NULL;
1592
1593
306k
  SBR_ERROR errorStatus = SBRDEC_OK;
1594
1595
306k
  INT strideOut, offset0 = 255, offset0_block = 0, offset1 = 255,
1596
306k
                 offset1_block = 0;
1597
306k
  INT codecFrameSize = self->codecFrameSize;
1598
1599
306k
  int stereo = (hSbrElement->elementID == ID_CPE) ? 1 : 0;
1600
306k
  int numElementChannels =
1601
306k
      hSbrElement
1602
306k
          ->nChannels; /* Number of channels of the current SBR element */
1603
1604
306k
  hFrameDataLeft =
1605
306k
      &hSbrElement->pSbrChannel[0]->frameData[hSbrElement->useFrameSlot];
1606
306k
  if (stereo) {
1607
134k
    hFrameDataRight =
1608
134k
        &hSbrElement->pSbrChannel[1]->frameData[hSbrElement->useFrameSlot];
1609
134k
  }
1610
1611
306k
  if (self->flags & SBRDEC_FLUSH) {
1612
23
    if (self->numFlushedFrames > self->numDelayFrames) {
1613
23
      int hdrIdx;
1614
      /* No valid SBR payload available, hence switch to upsampling (in all
1615
       * headers) */
1616
69
      for (hdrIdx = 0; hdrIdx < ((1) + 1); hdrIdx += 1) {
1617
46
        if (self->sbrHeader[elementIndex][hdrIdx].syncState > UPSAMPLING) {
1618
22
          self->sbrHeader[elementIndex][hdrIdx].syncState = UPSAMPLING;
1619
22
        }
1620
46
      }
1621
23
    } 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
23
  }
1640
1641
  /* Update the header error flag */
1642
306k
  hSbrHeader->frameErrorFlag =
1643
306k
      hSbrElement->frameErrorFlag[hSbrElement->useFrameSlot];
1644
1645
  /*
1646
     Prepare filterbank for upsampling if no valid bit stream data is available.
1647
   */
1648
306k
  if (hSbrHeader->syncState == SBR_NOT_INITIALIZED) {
1649
39.9k
    errorStatus =
1650
39.9k
        initHeaderData(hSbrHeader, self->sampleRateIn, self->sampleRateOut,
1651
39.9k
                       self->downscaleFactor, codecFrameSize, self->flags,
1652
39.9k
                       1 /* SET_DEFAULT_HDR */
1653
39.9k
        );
1654
1655
39.9k
    if (errorStatus != SBRDEC_OK) {
1656
0
      return errorStatus;
1657
0
    }
1658
1659
39.9k
    hSbrHeader->syncState = UPSAMPLING;
1660
1661
39.9k
    errorStatus = sbrDecoder_HeaderUpdate(self, hSbrHeader, HEADER_NOT_PRESENT,
1662
39.9k
                                          pSbrChannel, hSbrElement->nChannels);
1663
1664
39.9k
    if (errorStatus != SBRDEC_OK) {
1665
0
      hSbrHeader->syncState = SBR_NOT_INITIALIZED;
1666
0
      return errorStatus;
1667
0
    }
1668
39.9k
  }
1669
1670
  /* reset */
1671
306k
  if (hSbrHeader->status & SBRDEC_HDR_STAT_RESET) {
1672
158k
    int ch;
1673
158k
    int applySbrProc = (hSbrHeader->syncState == SBR_ACTIVE ||
1674
158k
                        (hSbrHeader->frameErrorFlag == 0 &&
1675
91.0k
                         hSbrHeader->syncState == SBR_HEADER));
1676
410k
    for (ch = 0; ch < numElementChannels; ch++) {
1677
251k
      SBR_ERROR errorStatusTmp = SBRDEC_OK;
1678
1679
251k
      errorStatusTmp = resetSbrDec(
1680
251k
          &pSbrChannel[ch]->SbrDec, hSbrHeader, &pSbrChannel[ch]->prevFrameData,
1681
251k
          self->synDownsampleFac, self->flags, pSbrChannel[ch]->frameData);
1682
1683
251k
      if (errorStatusTmp != SBRDEC_OK) {
1684
3.63k
        hSbrHeader->syncState = UPSAMPLING;
1685
3.63k
      }
1686
251k
    }
1687
158k
    if (applySbrProc) {
1688
44.2k
      hSbrHeader->status &= ~SBRDEC_HDR_STAT_RESET;
1689
44.2k
    }
1690
158k
  }
1691
1692
  /* decoding */
1693
306k
  if ((hSbrHeader->syncState == SBR_ACTIVE) ||
1694
162k
      ((hSbrHeader->syncState == SBR_HEADER) &&
1695
187k
       (hSbrHeader->frameErrorFlag == 0))) {
1696
187k
    errorStatus = SBRDEC_OK;
1697
1698
187k
    decodeSbrData(hSbrHeader, hFrameDataLeft, &pSbrChannel[0]->prevFrameData,
1699
187k
                  (stereo) ? hFrameDataRight : NULL,
1700
187k
                  (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
187k
    hSbrHeader->syncState = SBR_ACTIVE;
1705
187k
  }
1706
1707
306k
  if (timeDataSize <
1708
306k
      hSbrHeader->numberTimeSlots * hSbrHeader->timeStep *
1709
306k
          self->pQmfDomain->globalConf.nBandsSynthesis *
1710
306k
          (psPossible ? fMax(2, numInChannels) : numInChannels)) {
1711
0
    return SBRDEC_OUTPUT_BUFFER_TOO_SMALL;
1712
0
  }
1713
1714
306k
  {
1715
306k
    self->flags &= ~SBRDEC_PS_DECODED;
1716
306k
    C_ALLOC_SCRATCH_START(pPsScratch, struct PS_DEC_COEFFICIENTS, 1)
1717
1718
    /* decode PS data if available */
1719
306k
    if (h_ps_d != NULL && psPossible && (hSbrHeader->syncState == SBR_ACTIVE)) {
1720
3.79k
      int applyPs = 1;
1721
1722
      /* define which frame delay line slot to process */
1723
3.79k
      h_ps_d->processSlot = hSbrElement->useFrameSlot;
1724
1725
3.79k
      applyPs = DecodePs(h_ps_d, hSbrHeader->frameErrorFlag, pPsScratch);
1726
3.79k
      self->flags |= (applyPs) ? SBRDEC_PS_DECODED : 0;
1727
3.79k
    }
1728
1729
306k
    offset0 = FDK_chMapDescr_getMapValue(mapDescr, channelIndex, mapIdx);
1730
306k
    offset0_block = offset0 * codecFrameSize;
1731
306k
    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
140k
      offset1 = FDK_chMapDescr_getMapValue(mapDescr, channelIndex + 1, mapIdx);
1737
140k
      offset1_block = offset1 * codecFrameSize;
1738
140k
    }
1739
    /* Set strides for reading and writing */
1740
306k
    if (psPossible)
1741
5.86k
      strideOut = (numInChannels < 2) ? 2 : numInChannels;
1742
300k
    else
1743
300k
      strideOut = numInChannels;
1744
1745
    /* use same buffers for left and right channel and apply PS per timeslot */
1746
    /* Process left channel */
1747
306k
    sbr_dec(&pSbrChannel[0]->SbrDec, input + offset0_block, timeData + offset0,
1748
306k
            (self->flags & SBRDEC_PS_DECODED) ? &pSbrChannel[1]->SbrDec : NULL,
1749
306k
            timeData + offset1, strideOut, hSbrHeader, hFrameDataLeft,
1750
306k
            &pSbrChannel[0]->prevFrameData,
1751
306k
            (hSbrHeader->syncState == SBR_ACTIVE), h_ps_d, self->flags,
1752
306k
            codecFrameSize, self->sbrInDataHeadroom);
1753
1754
306k
    if (stereo) {
1755
      /* Process right channel */
1756
134k
      sbr_dec(&pSbrChannel[1]->SbrDec, input + offset1_block,
1757
134k
              timeData + offset1, NULL, NULL, strideOut, hSbrHeader,
1758
134k
              hFrameDataRight, &pSbrChannel[1]->prevFrameData,
1759
134k
              (hSbrHeader->syncState == SBR_ACTIVE), NULL, self->flags,
1760
134k
              codecFrameSize, self->sbrInDataHeadroom);
1761
134k
    }
1762
1763
306k
    C_ALLOC_SCRATCH_END(pPsScratch, struct PS_DEC_COEFFICIENTS, 1)
1764
306k
  }
1765
1766
306k
  if (h_ps_d != NULL) {
1767
    /* save PS status for next run */
1768
25.6k
    h_ps_d->psDecodedPrv = (self->flags & SBRDEC_PS_DECODED) ? 1 : 0;
1769
25.6k
  }
1770
1771
306k
  if (psPossible && !(self->flags & SBRDEC_SKIP_QMF_SYN)) {
1772
5.86k
    FDK_ASSERT(strideOut > 1);
1773
5.86k
    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.48k
      int copyFrameSize =
1778
2.48k
          codecFrameSize * self->pQmfDomain->QmfDomainOut->fb.no_channels;
1779
2.48k
      copyFrameSize /= self->pQmfDomain->QmfDomainIn->fb.no_channels;
1780
2.48k
      LONG *ptr;
1781
2.48k
      INT i;
1782
2.48k
      FDK_ASSERT(strideOut == 2);
1783
1784
2.48k
      ptr = timeData;
1785
2.45M
      for (i = copyFrameSize >> 1; i--;) {
1786
2.45M
        LONG tmp; /* This temporal variable is required because some compilers
1787
                     can't do *ptr++ = *ptr++ correctly. */
1788
2.45M
        tmp = *ptr++;
1789
2.45M
        *ptr++ = tmp;
1790
2.45M
        tmp = *ptr++;
1791
2.45M
        *ptr++ = tmp;
1792
2.45M
      }
1793
2.48k
    }
1794
5.86k
    *numOutChannels = 2; /* Output minimum two channels when PS is enabled. */
1795
5.86k
  }
1796
1797
306k
  return errorStatus;
1798
306k
}
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
257k
                           INT *outDataHeadroom) {
1807
257k
  SBR_ERROR errorStatus = SBRDEC_OK;
1808
1809
257k
  int psPossible;
1810
257k
  int sbrElementNum;
1811
257k
  int numCoreChannels;
1812
257k
  int numSbrChannels = 0;
1813
1814
257k
  if ((self == NULL) || (timeData == NULL) || (numChannels == NULL) ||
1815
257k
      (sampleRate == NULL) || (psDecoded == NULL) ||
1816
257k
      !FDK_chMapDescr_isValid(mapDescr)) {
1817
0
    return SBRDEC_INVALID_ARGUMENT;
1818
0
  }
1819
1820
257k
  psPossible = *psDecoded;
1821
257k
  numCoreChannels = *numChannels;
1822
257k
  if (numCoreChannels <= 0) {
1823
0
    return SBRDEC_INVALID_ARGUMENT;
1824
0
  }
1825
1826
257k
  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
565k
  for (sbrElementNum = 0; sbrElementNum < self->numSbrElements;
1833
307k
       sbrElementNum++) {
1834
307k
    if (self->pSbrElement[sbrElementNum] == NULL) {
1835
90
      return SBRDEC_NOT_INITIALIZED;
1836
90
    }
1837
307k
  }
1838
1839
257k
  if (self->numSbrElements != 1 || self->pSbrElement[0]->elementID != ID_SCE) {
1840
113k
    psPossible = 0;
1841
113k
  }
1842
1843
257k
  self->sbrInDataHeadroom = inDataHeadroom;
1844
257k
  *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
257k
  if (psPossible == 0) {
1849
251k
    self->flags &= ~SBRDEC_PS_DECODED;
1850
251k
  }
1851
1852
  /* replaces channel based reset inside sbr_dec() */
1853
257k
  if (((self->flags & SBRDEC_LOW_POWER) ? 1 : 0) !=
1854
257k
      ((self->pQmfDomain->globalConf.flags & QMF_FLAG_LP) ? 1 : 0)) {
1855
10.3k
    if (self->flags & SBRDEC_LOW_POWER) {
1856
9.90k
      self->pQmfDomain->globalConf.flags |= QMF_FLAG_LP;
1857
9.90k
      self->pQmfDomain->globalConf.flags_requested |= QMF_FLAG_LP;
1858
9.90k
    } else {
1859
478
      self->pQmfDomain->globalConf.flags &= ~QMF_FLAG_LP;
1860
478
      self->pQmfDomain->globalConf.flags_requested &= ~QMF_FLAG_LP;
1861
478
    }
1862
10.3k
    if (FDK_QmfDomain_InitFilterBank(self->pQmfDomain, QMF_FLAG_KEEP_STATES)) {
1863
0
      return SBRDEC_UNSUPPORTED_CONFIG;
1864
0
    }
1865
10.3k
  }
1866
257k
  if (self->numSbrChannels > self->pQmfDomain->globalConf.nInputChannels) {
1867
0
    return SBRDEC_UNSUPPORTED_CONFIG;
1868
0
  }
1869
1870
257k
  if (self->flags & SBRDEC_FLUSH) {
1871
    /* flushing is signalized, hence increment the flush frame counter */
1872
23
    self->numFlushedFrames++;
1873
257k
  } else {
1874
    /* no flushing is signalized, hence reset the flush frame counter */
1875
257k
    self->numFlushedFrames = 0;
1876
257k
  }
1877
1878
  /* Loop over SBR elements */
1879
310k
  for (sbrElementNum = 0; sbrElementNum < self->numSbrElements;
1880
306k
       sbrElementNum++) {
1881
306k
    int numElementChan;
1882
1883
306k
    if (psPossible &&
1884
5.86k
        self->pSbrElement[sbrElementNum]->pSbrChannel[1] == NULL) {
1885
      /* Disable PS and try decoding SBR mono. */
1886
0
      psPossible = 0;
1887
0
    }
1888
1889
306k
    numElementChan =
1890
306k
        (self->pSbrElement[sbrElementNum]->elementID == ID_CPE) ? 2 : 1;
1891
1892
    /* If core signal is bad then force upsampling */
1893
306k
    if (!coreDecodedOk) {
1894
110k
      setFrameErrorFlag(self->pSbrElement[sbrElementNum], FRAME_ERROR_ALLSLOTS);
1895
110k
    }
1896
1897
306k
    errorStatus = sbrDecoder_DecodeElement(
1898
306k
        self, input, timeData, timeDataSize, mapDescr, mapIdx, numSbrChannels,
1899
306k
        sbrElementNum,
1900
306k
        numCoreChannels, /* is correct even for USC SCI==2 case */
1901
306k
        &numElementChan, psPossible);
1902
1903
306k
    if (errorStatus != SBRDEC_OK) {
1904
0
      goto bail;
1905
0
    }
1906
1907
306k
    numSbrChannels += numElementChan;
1908
1909
306k
    if (numSbrChannels >= numCoreChannels) {
1910
253k
      break;
1911
253k
    }
1912
306k
  }
1913
1914
  /* Update numChannels and samplerate */
1915
  /* Do not mess with output channels in case of USAC. numSbrChannels !=
1916
   * numChannels for stereoConfigIndex == 2 */
1917
257k
  if (!(self->flags & SBRDEC_SYNTAX_USAC)) {
1918
58.8k
    *numChannels = numSbrChannels;
1919
58.8k
  }
1920
257k
  *sampleRate = self->sampleRateOut;
1921
257k
  *psDecoded = (self->flags & SBRDEC_PS_DECODED) ? 1 : 0;
1922
1923
  /* Clear reset and flush flag because everything seems to be done
1924
   * successfully. */
1925
257k
  self->flags &= ~SBRDEC_FORCE_RESET;
1926
257k
  self->flags &= ~SBRDEC_FLUSH;
1927
1928
257k
bail:
1929
1930
257k
  return errorStatus;
1931
257k
}
1932
1933
23.8k
SBR_ERROR sbrDecoder_Close(HANDLE_SBRDECODER *pSelf) {
1934
23.8k
  HANDLE_SBRDECODER self = *pSelf;
1935
23.8k
  int i;
1936
1937
23.8k
  if (self != NULL) {
1938
23.8k
    if (self->hParametricStereoDec != NULL) {
1939
1.80k
      DeletePsDec(&self->hParametricStereoDec);
1940
1.80k
    }
1941
1942
214k
    for (i = 0; i < (8); i++) {
1943
190k
      sbrDecoder_DestroyElement(self, i);
1944
190k
    }
1945
1946
23.8k
    FreeRam_SbrDecoder(pSelf);
1947
23.8k
  }
1948
1949
23.8k
  return SBRDEC_OK;
1950
23.8k
}
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
243k
UINT sbrDecoder_GetDelay(const HANDLE_SBRDECODER self) {
1984
243k
  UINT outputDelay = 0;
1985
1986
243k
  if (self != NULL) {
1987
243k
    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
243k
    if ((self->numSbrChannels > 0) && (self->numSbrElements > 0)) {
1993
      /* Add QMF synthesis delay */
1994
243k
      if ((flags & SBRDEC_ELD_GRID) && IS_LOWDELAY(self->coreCodec)) {
1995
        /* Low delay SBR: */
1996
34.4k
        if (!(flags & SBRDEC_SKIP_QMF_SYN)) {
1997
33.4k
          outputDelay +=
1998
33.4k
              (flags & SBRDEC_DOWNSAMPLE) ? 32 : 64; /* QMF synthesis */
1999
33.4k
          if (flags & SBRDEC_LD_MPS_QMF) {
2000
1.05k
            outputDelay += 32;
2001
1.05k
          }
2002
33.4k
        }
2003
209k
      } else if (!IS_USAC(self->coreCodec)) {
2004
        /* By the method of elimination this is the GA (AAC-LC, HE-AAC, ...)
2005
         * branch: */
2006
24.4k
        outputDelay += (flags & SBRDEC_DOWNSAMPLE) ? 481 : 962;
2007
24.4k
        if (flags & SBRDEC_SKIP_QMF_SYN) {
2008
0
          outputDelay -= 257; /* QMF synthesis */
2009
0
        }
2010
24.4k
      }
2011
243k
    }
2012
243k
  }
2013
2014
243k
  return (outputDelay);
2015
243k
}