Coverage Report

Created: 2025-07-18 06:08

/src/aac/libSBRdec/src/env_extr.cpp
Line
Count
Source (jump to first uncovered line)
1
/* -----------------------------------------------------------------------------
2
Software License for The Fraunhofer FDK AAC Codec Library for Android
3
4
© Copyright  1995 - 2018 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  Envelope extraction
106
  The functions provided by this module are mostly called by applySBR(). After
107
  it is determined that there is valid SBR data, sbrGetHeaderData() might be
108
  called if the current SBR data contains an \ref SBR_HEADER_ELEMENT as opposed
109
  to a \ref SBR_STANDARD_ELEMENT. This function may return various error codes
110
  as defined in #SBR_HEADER_STATUS . Most importantly it returns HEADER_RESET
111
  when decoder settings need to be recalculated according to the SBR
112
  specifications. In that case applySBR() will initiatite the required
113
  re-configuration.
114
115
  The header data is stored in a #SBR_HEADER_DATA structure.
116
117
  The actual SBR data for the current frame is decoded into SBR_FRAME_DATA
118
  stuctures by sbrGetChannelPairElement() [for stereo streams] and
119
  sbrGetSingleChannelElement() [for mono streams]. There is no fractional
120
  arithmetic involved.
121
122
  Once the information is extracted, the data needs to be further prepared
123
  before the actual decoding process. This is done in decodeSbrData().
124
125
  \sa Description of buffer management in applySBR(). \ref documentationOverview
126
127
  <h1>About the SBR data format:</h1>
128
129
  Each frame includes SBR data (side chain information), and can be either the
130
  \ref SBR_HEADER_ELEMENT or the \ref SBR_STANDARD_ELEMENT. Parts of the data
131
  can be protected by a CRC checksum.
132
133
  \anchor SBR_HEADER_ELEMENT <h2>The SBR_HEADER_ELEMENT</h2>
134
135
  The SBR_HEADER_ELEMENT can be transmitted with every frame, however, it
136
  typically is send every second or so. It contains fundamental information such
137
  as SBR sampling frequency and frequency range as well as control signals that
138
  do not require frequent changes. It also includes the \ref
139
  SBR_STANDARD_ELEMENT.
140
141
  Depending on the changes between the information in a current
142
  SBR_HEADER_ELEMENT and the previous SBR_HEADER_ELEMENT, the SBR decoder might
143
  need to be reset and reconfigured (e.g. new tables need to be calculated).
144
145
  \anchor SBR_STANDARD_ELEMENT <h2>The SBR_STANDARD_ELEMENT</h2>
146
147
  This data can be subdivided into "side info" and "raw data", where side info
148
  is defined as signals needed to decode the raw data and some decoder tuning
149
  signals. Raw data is referred to as PCM and Huffman coded envelope and noise
150
  floor estimates. The side info also includes information about the
151
  time-frequency grid for the current frame.
152
153
  \sa \ref documentationOverview
154
*/
155
156
#include "env_extr.h"
157
158
#include "sbr_ram.h"
159
#include "sbr_rom.h"
160
#include "huff_dec.h"
161
162
#include "psbitdec.h"
163
164
#define DRM_PARAMETRIC_STEREO 0
165
16.2k
#define EXTENSION_ID_PS_CODING 2
166
167
static int extractPvcFrameInfo(
168
    HANDLE_FDK_BITSTREAM hBs,           /*!< bitbuffer handle */
169
    HANDLE_SBR_HEADER_DATA hHeaderData, /*!< Static control data */
170
    HANDLE_SBR_FRAME_DATA h_frame_data, /*!< pointer to memory where the
171
                                           frame-info will be stored */
172
    HANDLE_SBR_PREV_FRAME_DATA h_prev_frame_data, /*!< pointer to memory where
173
                                                     the previous frame-info
174
                                                     will be stored */
175
    UCHAR pvc_mode_last,                          /**< PVC mode of last frame */
176
    const UINT flags);
177
static int extractFrameInfo(HANDLE_FDK_BITSTREAM hBs,
178
                            HANDLE_SBR_HEADER_DATA hHeaderData,
179
                            HANDLE_SBR_FRAME_DATA h_frame_data,
180
                            const UINT nrOfChannels, const UINT flags);
181
182
static int sbrGetPvcEnvelope(HANDLE_SBR_HEADER_DATA hHeaderData,
183
                             HANDLE_SBR_FRAME_DATA h_frame_data,
184
                             HANDLE_FDK_BITSTREAM hBs, const UINT flags,
185
                             const UINT pvcMode);
186
static int sbrGetEnvelope(HANDLE_SBR_HEADER_DATA hHeaderData,
187
                          HANDLE_SBR_FRAME_DATA h_frame_data,
188
                          HANDLE_FDK_BITSTREAM hBs, const UINT flags);
189
190
static void sbrGetDirectionControlData(HANDLE_SBR_FRAME_DATA hFrameData,
191
                                       HANDLE_FDK_BITSTREAM hBs,
192
                                       const UINT flags, const int bs_pvc_mode);
193
194
static void sbrGetNoiseFloorData(HANDLE_SBR_HEADER_DATA hHeaderData,
195
                                 HANDLE_SBR_FRAME_DATA h_frame_data,
196
                                 HANDLE_FDK_BITSTREAM hBs);
197
198
static int checkFrameInfo(FRAME_INFO *pFrameInfo, int numberOfTimeSlots,
199
                          int overlap, int timeStep);
200
201
/* Mapping to std samplerate table according to 14496-3 (4.6.18.2.6) */
202
typedef struct SR_MAPPING {
203
  UINT fsRangeLo; /* If fsRangeLo(n+1)>fs>=fsRangeLo(n), it will be mapped to...
204
                   */
205
  UINT fsMapped;  /* fsMapped. */
206
} SR_MAPPING;
207
208
static const SR_MAPPING stdSampleRatesMapping[] = {
209
    {0, 8000},      {9391, 11025},  {11502, 12000}, {13856, 16000},
210
    {18783, 22050}, {23004, 24000}, {27713, 32000}, {37566, 44100},
211
    {46009, 48000}, {55426, 64000}, {75132, 88200}, {92017, 96000}};
212
static const SR_MAPPING stdSampleRatesMappingUsac[] = {
213
    {0, 16000},     {18783, 22050}, {23004, 24000}, {27713, 32000},
214
    {35777, 40000}, {42000, 44100}, {46009, 48000}, {55426, 64000},
215
    {75132, 88200}, {92017, 96000}};
216
217
UINT sbrdec_mapToStdSampleRate(UINT fs,
218
                               UINT isUsac) /*!< Output sampling frequency */
219
307k
{
220
307k
  UINT fsMapped = fs, tableSize = 0;
221
307k
  const SR_MAPPING *mappingTable;
222
307k
  int i;
223
224
307k
  if (!isUsac) {
225
174k
    mappingTable = stdSampleRatesMapping;
226
174k
    tableSize = sizeof(stdSampleRatesMapping) / sizeof(SR_MAPPING);
227
174k
  } else {
228
132k
    mappingTable = stdSampleRatesMappingUsac;
229
132k
    tableSize = sizeof(stdSampleRatesMappingUsac) / sizeof(SR_MAPPING);
230
132k
  }
231
232
2.12M
  for (i = tableSize - 1; i >= 0; i--) {
233
2.12M
    if (fs >= mappingTable[i].fsRangeLo) {
234
307k
      fsMapped = mappingTable[i].fsMapped;
235
307k
      break;
236
307k
    }
237
2.12M
  }
238
239
307k
  return (fsMapped);
240
307k
}
241
242
SBR_ERROR
243
initHeaderData(HANDLE_SBR_HEADER_DATA hHeaderData, const int sampleRateIn,
244
               const int sampleRateOut, const INT downscaleFactor,
245
               const int samplesPerFrame, const UINT flags,
246
262k
               const int setDefaultHdr) {
247
262k
  HANDLE_FREQ_BAND_DATA hFreq = &hHeaderData->freqBandData;
248
262k
  SBR_ERROR sbrError = SBRDEC_OK;
249
262k
  int numAnalysisBands;
250
262k
  int sampleRateProc;
251
252
262k
  if (!(flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50))) {
253
174k
    sampleRateProc =
254
174k
        sbrdec_mapToStdSampleRate(sampleRateOut * downscaleFactor, 0);
255
174k
  } else {
256
87.8k
    sampleRateProc = sampleRateOut * downscaleFactor;
257
87.8k
  }
258
259
262k
  if (sampleRateIn == sampleRateOut) {
260
100k
    hHeaderData->sbrProcSmplRate = sampleRateProc << 1;
261
100k
    numAnalysisBands = 32;
262
161k
  } else {
263
161k
    hHeaderData->sbrProcSmplRate = sampleRateProc;
264
161k
    if ((sampleRateOut >> 1) == sampleRateIn) {
265
      /* 1:2 */
266
98.2k
      numAnalysisBands = 32;
267
98.2k
    } else if ((sampleRateOut >> 2) == sampleRateIn) {
268
      /* 1:4 */
269
24.0k
      numAnalysisBands = 16;
270
39.4k
    } else if ((sampleRateOut * 3) >> 3 == (sampleRateIn * 8) >> 3) {
271
      /* 3:8, 3/4 core frame length */
272
39.3k
      numAnalysisBands = 24;
273
39.3k
    } else {
274
100
      sbrError = SBRDEC_UNSUPPORTED_CONFIG;
275
100
      goto bail;
276
100
    }
277
161k
  }
278
262k
  numAnalysisBands /= downscaleFactor;
279
280
262k
  if (setDefaultHdr) {
281
    /* Fill in default values first */
282
261k
    hHeaderData->syncState = SBR_NOT_INITIALIZED;
283
261k
    hHeaderData->status = 0;
284
261k
    hHeaderData->frameErrorFlag = 0;
285
286
261k
    hHeaderData->bs_info.ampResolution = 1;
287
261k
    hHeaderData->bs_info.xover_band = 0;
288
261k
    hHeaderData->bs_info.sbr_preprocessing = 0;
289
261k
    hHeaderData->bs_info.pvc_mode = 0;
290
291
261k
    hHeaderData->bs_data.startFreq = 5;
292
261k
    hHeaderData->bs_data.stopFreq = 0;
293
261k
    hHeaderData->bs_data.freqScale =
294
261k
        0; /* previously 2; for ELD reduced delay bitstreams
295
           /samplerates initializing of the sbr decoder instance fails if
296
           freqScale is set to 2 because no master table can be generated; in
297
           ELD reduced delay bitstreams this value is always 0; gets overwritten
298
           when header is read */
299
261k
    hHeaderData->bs_data.alterScale = 1;
300
261k
    hHeaderData->bs_data.noise_bands = 2;
301
261k
    hHeaderData->bs_data.limiterBands = 2;
302
261k
    hHeaderData->bs_data.limiterGains = 2;
303
261k
    hHeaderData->bs_data.interpolFreq = 1;
304
261k
    hHeaderData->bs_data.smoothingLength = 1;
305
306
    /* Patch some entries */
307
261k
    if (sampleRateOut * downscaleFactor >= 96000) {
308
35.7k
      hHeaderData->bs_data.startFreq =
309
35.7k
          4; /*   having read these frequency values from bit stream before. */
310
35.7k
      hHeaderData->bs_data.stopFreq = 3;
311
225k
    } else if (sampleRateOut * downscaleFactor >
312
225k
               24000) { /* Trigger an error if SBR is going to be processed
313
                           without     */
314
86.4k
      hHeaderData->bs_data.startFreq =
315
86.4k
          7; /*   having read these frequency values from bit stream before. */
316
86.4k
      hHeaderData->bs_data.stopFreq = 3;
317
86.4k
    }
318
261k
  }
319
320
262k
  if ((sampleRateOut >> 2) == sampleRateIn) {
321
24.0k
    hHeaderData->timeStep = 4;
322
238k
  } else {
323
238k
    hHeaderData->timeStep = (flags & SBRDEC_ELD_GRID) ? 1 : 2;
324
238k
  }
325
326
  /* Setup pointers to frequency band tables */
327
262k
  hFreq->freqBandTable[0] = hFreq->freqBandTableLo;
328
262k
  hFreq->freqBandTable[1] = hFreq->freqBandTableHi;
329
330
  /* One SBR timeslot corresponds to the amount of samples equal to the amount
331
   * of analysis bands, divided by the timestep. */
332
262k
  hHeaderData->numberTimeSlots =
333
262k
      (samplesPerFrame / numAnalysisBands) >> (hHeaderData->timeStep - 1);
334
262k
  if (hHeaderData->numberTimeSlots > (16)) {
335
0
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
336
0
  }
337
338
262k
  hHeaderData->numberOfAnalysisBands = numAnalysisBands;
339
262k
  if ((sampleRateOut >> 2) == sampleRateIn) {
340
24.0k
    hHeaderData->numberTimeSlots <<= 1;
341
24.0k
  }
342
343
262k
bail:
344
262k
  return sbrError;
345
262k
}
346
347
/*!
348
  \brief   Initialize the SBR_PREV_FRAME_DATA struct
349
*/
350
void initSbrPrevFrameData(
351
    HANDLE_SBR_PREV_FRAME_DATA
352
        h_prev_data, /*!< handle to struct SBR_PREV_FRAME_DATA */
353
    int timeSlots)   /*!< Framelength in SBR-timeslots */
354
161k
{
355
161k
  int i;
356
357
  /* Set previous energy and noise levels to 0 for the case
358
     that decoding starts in the middle of a bitstream */
359
9.19M
  for (i = 0; i < MAX_FREQ_COEFFS; i++)
360
9.03M
    h_prev_data->sfb_nrg_prev[i] = (FIXP_DBL)0;
361
968k
  for (i = 0; i < MAX_NOISE_COEFFS; i++)
362
806k
    h_prev_data->prevNoiseLevel[i] = (FIXP_DBL)0;
363
968k
  for (i = 0; i < MAX_INVF_BANDS; i++) h_prev_data->sbr_invf_mode[i] = INVF_OFF;
364
365
161k
  h_prev_data->stopPos = timeSlots;
366
161k
  h_prev_data->coupling = COUPLING_OFF;
367
161k
  h_prev_data->ampRes = 0;
368
369
161k
  FDKmemclear(&h_prev_data->prevFrameInfo, sizeof(h_prev_data->prevFrameInfo));
370
161k
}
371
372
/*!
373
  \brief   Read header data from bitstream
374
375
  \return  error status - 0 if ok
376
*/
377
SBR_HEADER_STATUS
378
sbrGetHeaderData(HANDLE_SBR_HEADER_DATA hHeaderData, HANDLE_FDK_BITSTREAM hBs,
379
                 const UINT flags, const int fIsSbrData,
380
655k
                 const UCHAR configMode) {
381
655k
  SBR_HEADER_DATA_BS *pBsData;
382
655k
  SBR_HEADER_DATA_BS lastHeader;
383
655k
  SBR_HEADER_DATA_BS_INFO lastInfo;
384
655k
  int headerExtra1 = 0, headerExtra2 = 0;
385
386
  /* Read and discard new header in config change detection mode */
387
655k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
388
338k
    if (!(flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC))) {
389
      /* ampResolution */
390
226k
      FDKreadBits(hBs, 1);
391
226k
    }
392
    /* startFreq, stopFreq */
393
338k
    FDKpushFor(hBs, 8);
394
338k
    if (!(flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC))) {
395
      /* xover_band */
396
226k
      FDKreadBits(hBs, 3);
397
      /* reserved bits */
398
226k
      FDKreadBits(hBs, 2);
399
226k
    }
400
338k
    headerExtra1 = FDKreadBit(hBs);
401
338k
    headerExtra2 = FDKreadBit(hBs);
402
338k
    FDKpushFor(hBs, 5 * headerExtra1 + 6 * headerExtra2);
403
404
338k
    return HEADER_OK;
405
338k
  }
406
407
  /* Copy SBR bit stream header to temporary header */
408
317k
  lastHeader = hHeaderData->bs_data;
409
317k
  lastInfo = hHeaderData->bs_info;
410
411
  /* Read new header from bitstream */
412
317k
  if ((flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC)) && !fIsSbrData) {
413
64.6k
    pBsData = &hHeaderData->bs_dflt;
414
252k
  } else {
415
252k
    pBsData = &hHeaderData->bs_data;
416
252k
  }
417
418
317k
  if (!(flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC))) {
419
179k
    hHeaderData->bs_info.ampResolution = FDKreadBits(hBs, 1);
420
179k
  }
421
422
317k
  pBsData->startFreq = FDKreadBits(hBs, 4);
423
317k
  pBsData->stopFreq = FDKreadBits(hBs, 4);
424
425
317k
  if (!(flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC))) {
426
179k
    hHeaderData->bs_info.xover_band = FDKreadBits(hBs, 3);
427
179k
    FDKreadBits(hBs, 2);
428
179k
  }
429
430
317k
  headerExtra1 = FDKreadBits(hBs, 1);
431
317k
  headerExtra2 = FDKreadBits(hBs, 1);
432
433
  /* Handle extra header information */
434
317k
  if (headerExtra1) {
435
100k
    pBsData->freqScale = FDKreadBits(hBs, 2);
436
100k
    pBsData->alterScale = FDKreadBits(hBs, 1);
437
100k
    pBsData->noise_bands = FDKreadBits(hBs, 2);
438
216k
  } else {
439
216k
    pBsData->freqScale = 2;
440
216k
    pBsData->alterScale = 1;
441
216k
    pBsData->noise_bands = 2;
442
216k
  }
443
444
317k
  if (headerExtra2) {
445
105k
    pBsData->limiterBands = FDKreadBits(hBs, 2);
446
105k
    pBsData->limiterGains = FDKreadBits(hBs, 2);
447
105k
    pBsData->interpolFreq = FDKreadBits(hBs, 1);
448
105k
    pBsData->smoothingLength = FDKreadBits(hBs, 1);
449
211k
  } else {
450
211k
    pBsData->limiterBands = 2;
451
211k
    pBsData->limiterGains = 2;
452
211k
    pBsData->interpolFreq = 1;
453
211k
    pBsData->smoothingLength = 1;
454
211k
  }
455
456
  /* Look for new settings. IEC 14496-3, 4.6.18.3.1 */
457
317k
  if (hHeaderData->syncState < SBR_HEADER ||
458
317k
      lastHeader.startFreq != pBsData->startFreq ||
459
317k
      lastHeader.stopFreq != pBsData->stopFreq ||
460
317k
      lastHeader.freqScale != pBsData->freqScale ||
461
317k
      lastHeader.alterScale != pBsData->alterScale ||
462
317k
      lastHeader.noise_bands != pBsData->noise_bands ||
463
317k
      lastInfo.xover_band != hHeaderData->bs_info.xover_band) {
464
248k
    return HEADER_RESET; /* New settings */
465
248k
  }
466
467
68.7k
  return HEADER_OK;
468
317k
}
469
470
/*!
471
  \brief   Get missing harmonics parameters (only used for AAC+SBR)
472
473
  \return  error status - 0 if ok
474
*/
475
int sbrGetSyntheticCodedData(HANDLE_SBR_HEADER_DATA hHeaderData,
476
                             HANDLE_SBR_FRAME_DATA hFrameData,
477
398k
                             HANDLE_FDK_BITSTREAM hBs, const UINT flags) {
478
398k
  int i, bitsRead = 0;
479
480
398k
  int add_harmonic_flag = FDKreadBits(hBs, 1);
481
398k
  bitsRead++;
482
483
398k
  if (add_harmonic_flag) {
484
50.0k
    int nSfb = hHeaderData->freqBandData.nSfb[1];
485
150k
    for (i = 0; i < ADD_HARMONICS_FLAGS_SIZE; i++) {
486
      /* read maximum 32 bits and align them to the MSB */
487
100k
      int readBits = fMin(32, nSfb);
488
100k
      nSfb -= readBits;
489
100k
      if (readBits > 0) {
490
51.0k
        hFrameData->addHarmonics[i] = FDKreadBits(hBs, readBits)
491
51.0k
                                      << (32 - readBits);
492
51.0k
      } else {
493
48.9k
        hFrameData->addHarmonics[i] = 0;
494
48.9k
      }
495
496
100k
      bitsRead += readBits;
497
100k
    }
498
    /* bs_pvc_mode = 0 for Rsvd50 */
499
50.0k
    if (flags & SBRDEC_SYNTAX_USAC) {
500
16.9k
      if (hHeaderData->bs_info.pvc_mode) {
501
3.84k
        int bs_sinusoidal_position = 31;
502
3.84k
        if (FDKreadBit(hBs) /* bs_sinusoidal_position_flag */) {
503
624
          bs_sinusoidal_position = FDKreadBits(hBs, 5);
504
624
        }
505
3.84k
        hFrameData->sinusoidal_position = bs_sinusoidal_position;
506
3.84k
      }
507
16.9k
    }
508
348k
  } else {
509
1.04M
    for (i = 0; i < ADD_HARMONICS_FLAGS_SIZE; i++)
510
697k
      hFrameData->addHarmonics[i] = 0;
511
348k
  }
512
513
398k
  return (bitsRead);
514
398k
}
515
516
/*!
517
  \brief      Reads extension data from the bitstream
518
519
  The bitstream format allows up to 4 kinds of extended data element.
520
  Extended data may contain several elements, each identified by a 2-bit-ID.
521
  So far, no extended data elements are defined hence the first 2 parameters
522
  are unused. The data should be skipped in order to update the number
523
  of read bits for the consistency check in applySBR().
524
*/
525
static int extractExtendedData(
526
    HANDLE_SBR_HEADER_DATA hHeaderData, /*!< handle to SBR header */
527
    HANDLE_FDK_BITSTREAM hBs            /*!< Handle to the bit buffer */
528
    ,
529
    HANDLE_PS_DEC hParametricStereoDec /*!< Parametric Stereo Decoder */
530
76.8k
) {
531
76.8k
  INT nBitsLeft;
532
76.8k
  int extended_data;
533
76.8k
  int i, frameOk = 1;
534
535
76.8k
  extended_data = FDKreadBits(hBs, 1);
536
537
76.8k
  if (extended_data) {
538
26.6k
    int cnt;
539
26.6k
    int bPsRead = 0;
540
541
26.6k
    cnt = FDKreadBits(hBs, 4);
542
26.6k
    if (cnt == (1 << 4) - 1) cnt += FDKreadBits(hBs, 8);
543
544
26.6k
    nBitsLeft = 8 * cnt;
545
546
    /* sanity check for cnt */
547
26.6k
    if (nBitsLeft > (INT)FDKgetValidBits(hBs)) {
548
      /* limit nBitsLeft */
549
3.72k
      nBitsLeft = (INT)FDKgetValidBits(hBs);
550
      /* set frame error */
551
3.72k
      frameOk = 0;
552
3.72k
    }
553
554
60.2k
    while (nBitsLeft > 7) {
555
33.6k
      int extension_id = FDKreadBits(hBs, 2);
556
33.6k
      nBitsLeft -= 2;
557
558
33.6k
      switch (extension_id) {
559
16.2k
        case EXTENSION_ID_PS_CODING:
560
561
          /* Read PS data from bitstream */
562
563
16.2k
          if (hParametricStereoDec != NULL) {
564
11.5k
            if (bPsRead &&
565
11.5k
                !hParametricStereoDec->bsData[hParametricStereoDec->bsReadSlot]
566
3.48k
                     .mpeg.bPsHeaderValid) {
567
485
              cnt = nBitsLeft >> 3; /* number of remaining bytes */
568
17.2k
              for (i = 0; i < cnt; i++) FDKreadBits(hBs, 8);
569
485
              nBitsLeft -= cnt * 8;
570
11.0k
            } else {
571
11.0k
              nBitsLeft -=
572
11.0k
                  (INT)ReadPsData(hParametricStereoDec, hBs, nBitsLeft);
573
11.0k
              bPsRead = 1;
574
11.0k
            }
575
11.5k
          }
576
577
          /* parametric stereo detected, could set channelMode accordingly here
578
           */
579
          /*                                                                     */
580
          /* "The usage of this parametric stereo extension to HE-AAC is */
581
          /* signalled implicitly in the bitstream. Hence, if an sbr_extension()
582
           */
583
          /* with bs_extension_id==EXTENSION_ID_PS is found in the SBR part of
584
           */
585
          /* the bitstream, a decoder supporting the combination of SBR and PS
586
           */
587
          /* shall operate the PS tool to generate a stereo output signal." */
588
          /* source: ISO/IEC 14496-3:2001/FDAM 2:2004(E) */
589
590
16.2k
          break;
591
592
17.4k
        default:
593
17.4k
          cnt = nBitsLeft >> 3; /* number of remaining bytes */
594
243k
          for (i = 0; i < cnt; i++) FDKreadBits(hBs, 8);
595
17.4k
          nBitsLeft -= cnt * 8;
596
17.4k
          break;
597
33.6k
      }
598
33.6k
    }
599
600
26.6k
    if (nBitsLeft < 0) {
601
3.70k
      frameOk = 0;
602
3.70k
      goto bail;
603
22.9k
    } else {
604
      /* Read fill bits for byte alignment */
605
22.9k
      FDKreadBits(hBs, nBitsLeft);
606
22.9k
    }
607
26.6k
  }
608
609
76.8k
bail:
610
76.8k
  return (frameOk);
611
76.8k
}
612
613
/*!
614
  \brief      Read bitstream elements of a SBR channel element
615
  \return     SbrFrameOK
616
*/
617
int sbrGetChannelElement(HANDLE_SBR_HEADER_DATA hHeaderData,
618
                         HANDLE_SBR_FRAME_DATA hFrameDataLeft,
619
                         HANDLE_SBR_FRAME_DATA hFrameDataRight,
620
                         HANDLE_SBR_PREV_FRAME_DATA hFrameDataLeftPrev,
621
                         UCHAR pvc_mode_last, HANDLE_FDK_BITSTREAM hBs,
622
                         HANDLE_PS_DEC hParametricStereoDec, const UINT flags,
623
311k
                         const int overlap) {
624
311k
  int i, bs_coupling = COUPLING_OFF;
625
311k
  const int nCh = (hFrameDataRight == NULL) ? 1 : 2;
626
627
311k
  if (!(flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50))) {
628
    /* Reserved bits */
629
85.0k
    if (FDKreadBits(hBs, 1)) { /* bs_data_extra */
630
25.5k
      FDKreadBits(hBs, 4);
631
25.5k
      if ((flags & SBRDEC_SYNTAX_SCAL) || (nCh == 2)) {
632
22.5k
        FDKreadBits(hBs, 4);
633
22.5k
      }
634
25.5k
    }
635
85.0k
  }
636
637
311k
  if (nCh == 2) {
638
    /* Read coupling flag */
639
106k
    bs_coupling = FDKreadBits(hBs, 1);
640
106k
    if (bs_coupling) {
641
32.5k
      hFrameDataLeft->coupling = COUPLING_LEVEL;
642
32.5k
      hFrameDataRight->coupling = COUPLING_BAL;
643
73.9k
    } else {
644
73.9k
      hFrameDataLeft->coupling = COUPLING_OFF;
645
73.9k
      hFrameDataRight->coupling = COUPLING_OFF;
646
73.9k
    }
647
205k
  } else {
648
205k
    if (flags & SBRDEC_SYNTAX_SCAL) {
649
23.0k
      FDKreadBits(hBs, 1); /* bs_coupling */
650
23.0k
    }
651
205k
    hFrameDataLeft->coupling = COUPLING_OFF;
652
205k
  }
653
654
311k
  if (flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50)) {
655
226k
    if (flags & SBRDEC_USAC_HARMONICSBR) {
656
58.0k
      hFrameDataLeft->sbrPatchingMode = FDKreadBit(hBs);
657
58.0k
      if (hFrameDataLeft->sbrPatchingMode == 0) {
658
34.6k
        hFrameDataLeft->sbrOversamplingFlag = FDKreadBit(hBs);
659
34.6k
        if (FDKreadBit(hBs)) { /* sbrPitchInBinsFlag */
660
4.71k
          hFrameDataLeft->sbrPitchInBins = FDKreadBits(hBs, 7);
661
29.9k
        } else {
662
29.9k
          hFrameDataLeft->sbrPitchInBins = 0;
663
29.9k
        }
664
34.6k
      } else {
665
23.3k
        hFrameDataLeft->sbrOversamplingFlag = 0;
666
23.3k
        hFrameDataLeft->sbrPitchInBins = 0;
667
23.3k
      }
668
669
58.0k
      if (nCh == 2) {
670
42.6k
        if (bs_coupling) {
671
20.5k
          hFrameDataRight->sbrPatchingMode = hFrameDataLeft->sbrPatchingMode;
672
20.5k
          hFrameDataRight->sbrOversamplingFlag =
673
20.5k
              hFrameDataLeft->sbrOversamplingFlag;
674
20.5k
          hFrameDataRight->sbrPitchInBins = hFrameDataLeft->sbrPitchInBins;
675
22.0k
        } else {
676
22.0k
          hFrameDataRight->sbrPatchingMode = FDKreadBit(hBs);
677
22.0k
          if (hFrameDataRight->sbrPatchingMode == 0) {
678
14.2k
            hFrameDataRight->sbrOversamplingFlag = FDKreadBit(hBs);
679
14.2k
            if (FDKreadBit(hBs)) { /* sbrPitchInBinsFlag */
680
2.24k
              hFrameDataRight->sbrPitchInBins = FDKreadBits(hBs, 7);
681
11.9k
            } else {
682
11.9k
              hFrameDataRight->sbrPitchInBins = 0;
683
11.9k
            }
684
14.2k
          } else {
685
7.86k
            hFrameDataRight->sbrOversamplingFlag = 0;
686
7.86k
            hFrameDataRight->sbrPitchInBins = 0;
687
7.86k
          }
688
22.0k
        }
689
42.6k
      }
690
168k
    } else {
691
168k
      if (nCh == 2) {
692
27.1k
        hFrameDataRight->sbrPatchingMode = 1;
693
27.1k
        hFrameDataRight->sbrOversamplingFlag = 0;
694
27.1k
        hFrameDataRight->sbrPitchInBins = 0;
695
27.1k
      }
696
697
168k
      hFrameDataLeft->sbrPatchingMode = 1;
698
168k
      hFrameDataLeft->sbrOversamplingFlag = 0;
699
168k
      hFrameDataLeft->sbrPitchInBins = 0;
700
168k
    }
701
226k
  } else {
702
85.0k
    if (nCh == 2) {
703
36.6k
      hFrameDataRight->sbrPatchingMode = 1;
704
36.6k
      hFrameDataRight->sbrOversamplingFlag = 0;
705
36.6k
      hFrameDataRight->sbrPitchInBins = 0;
706
36.6k
    }
707
708
85.0k
    hFrameDataLeft->sbrPatchingMode = 1;
709
85.0k
    hFrameDataLeft->sbrOversamplingFlag = 0;
710
85.0k
    hFrameDataLeft->sbrPitchInBins = 0;
711
85.0k
  }
712
713
  /*
714
    sbr_grid(): Grid control
715
  */
716
311k
  if (hHeaderData->bs_info.pvc_mode) {
717
133k
    FDK_ASSERT(nCh == 1); /* PVC not possible for CPE */
718
133k
    if (!extractPvcFrameInfo(hBs, hHeaderData, hFrameDataLeft,
719
133k
                             hFrameDataLeftPrev, pvc_mode_last, flags))
720
919
      return 0;
721
722
132k
    if (!checkFrameInfo(&hFrameDataLeft->frameInfo,
723
132k
                        hHeaderData->numberTimeSlots, overlap,
724
132k
                        hHeaderData->timeStep))
725
576
      return 0;
726
177k
  } else {
727
177k
    if (!extractFrameInfo(hBs, hHeaderData, hFrameDataLeft, 1, flags)) return 0;
728
729
173k
    if (!checkFrameInfo(&hFrameDataLeft->frameInfo,
730
173k
                        hHeaderData->numberTimeSlots, overlap,
731
173k
                        hHeaderData->timeStep))
732
3.28k
      return 0;
733
173k
  }
734
302k
  if (nCh == 2) {
735
102k
    if (hFrameDataLeft->coupling) {
736
31.3k
      FDKmemcpy(&hFrameDataRight->frameInfo, &hFrameDataLeft->frameInfo,
737
31.3k
                sizeof(FRAME_INFO));
738
31.3k
      hFrameDataRight->ampResolutionCurrentFrame =
739
31.3k
          hFrameDataLeft->ampResolutionCurrentFrame;
740
71.4k
    } else {
741
71.4k
      if (!extractFrameInfo(hBs, hHeaderData, hFrameDataRight, 2, flags))
742
1.82k
        return 0;
743
744
69.6k
      if (!checkFrameInfo(&hFrameDataRight->frameInfo,
745
69.6k
                          hHeaderData->numberTimeSlots, overlap,
746
69.6k
                          hHeaderData->timeStep))
747
947
        return 0;
748
69.6k
    }
749
102k
  }
750
751
  /*
752
    sbr_dtdf(): Fetch domain vectors (time or frequency direction for
753
    delta-coding)
754
  */
755
299k
  sbrGetDirectionControlData(hFrameDataLeft, hBs, flags,
756
299k
                             hHeaderData->bs_info.pvc_mode);
757
299k
  if (nCh == 2) {
758
100k
    sbrGetDirectionControlData(hFrameDataRight, hBs, flags, 0);
759
100k
  }
760
761
  /* sbr_invf() */
762
971k
  for (i = 0; i < hHeaderData->freqBandData.nInvfBands; i++) {
763
672k
    hFrameDataLeft->sbr_invf_mode[i] = (INVF_MODE)FDKreadBits(hBs, 2);
764
672k
  }
765
299k
  if (nCh == 2) {
766
100k
    if (hFrameDataLeft->coupling) {
767
103k
      for (i = 0; i < hHeaderData->freqBandData.nInvfBands; i++) {
768
72.1k
        hFrameDataRight->sbr_invf_mode[i] = hFrameDataLeft->sbr_invf_mode[i];
769
72.1k
      }
770
68.6k
    } else {
771
247k
      for (i = 0; i < hHeaderData->freqBandData.nInvfBands; i++) {
772
178k
        hFrameDataRight->sbr_invf_mode[i] = (INVF_MODE)FDKreadBits(hBs, 2);
773
178k
      }
774
68.6k
    }
775
100k
  }
776
777
299k
  if (nCh == 1) {
778
199k
    if (hHeaderData->bs_info.pvc_mode) {
779
132k
      if (!sbrGetPvcEnvelope(hHeaderData, hFrameDataLeft, hBs, flags,
780
132k
                             hHeaderData->bs_info.pvc_mode))
781
639
        return 0;
782
132k
    } else if (!sbrGetEnvelope(hHeaderData, hFrameDataLeft, hBs, flags))
783
0
      return 0;
784
785
198k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataLeft, hBs);
786
198k
  } else if (hFrameDataLeft->coupling) {
787
31.3k
    if (!sbrGetEnvelope(hHeaderData, hFrameDataLeft, hBs, flags)) {
788
0
      return 0;
789
0
    }
790
791
31.3k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataLeft, hBs);
792
793
31.3k
    if (!sbrGetEnvelope(hHeaderData, hFrameDataRight, hBs, flags)) {
794
0
      return 0;
795
0
    }
796
31.3k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataRight, hBs);
797
68.6k
  } else { /* nCh == 2 && no coupling */
798
799
68.6k
    if (!sbrGetEnvelope(hHeaderData, hFrameDataLeft, hBs, flags)) return 0;
800
801
68.6k
    if (!sbrGetEnvelope(hHeaderData, hFrameDataRight, hBs, flags)) return 0;
802
803
68.6k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataLeft, hBs);
804
805
68.6k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataRight, hBs);
806
68.6k
  }
807
808
298k
  sbrGetSyntheticCodedData(hHeaderData, hFrameDataLeft, hBs, flags);
809
298k
  if (nCh == 2) {
810
100k
    sbrGetSyntheticCodedData(hHeaderData, hFrameDataRight, hBs, flags);
811
100k
  }
812
813
298k
  if (!(flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50))) {
814
76.8k
    if (!extractExtendedData(hHeaderData, hBs, hParametricStereoDec)) {
815
6.29k
      return 0;
816
6.29k
    }
817
76.8k
  }
818
819
292k
  return 1;
820
298k
}
821
822
/*!
823
  \brief   Read direction control data from bitstream
824
*/
825
void sbrGetDirectionControlData(
826
    HANDLE_SBR_FRAME_DATA h_frame_data, /*!< handle to struct SBR_FRAME_DATA */
827
    HANDLE_FDK_BITSTREAM hBs,           /*!< handle to struct BIT_BUF */
828
    const UINT flags, const int bs_pvc_mode)
829
830
399k
{
831
399k
  int i;
832
399k
  int indepFlag = 0;
833
834
399k
  if (flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50)) {
835
290k
    indepFlag = flags & SBRDEC_USAC_INDEP;
836
290k
  }
837
838
399k
  if (bs_pvc_mode == 0) {
839
267k
    i = 0;
840
267k
    if (indepFlag) {
841
125k
      h_frame_data->domain_vec[i++] = 0;
842
125k
    }
843
626k
    for (; i < h_frame_data->frameInfo.nEnvelopes; i++) {
844
359k
      h_frame_data->domain_vec[i] = FDKreadBits(hBs, 1);
845
359k
    }
846
267k
  }
847
848
399k
  i = 0;
849
399k
  if (indepFlag) {
850
238k
    h_frame_data->domain_vec_noise[i++] = 0;
851
238k
  }
852
796k
  for (; i < h_frame_data->frameInfo.nNoiseEnvelopes; i++) {
853
396k
    h_frame_data->domain_vec_noise[i] = FDKreadBits(hBs, 1);
854
396k
  }
855
399k
}
856
857
/*!
858
  \brief   Read noise-floor-level data from bitstream
859
*/
860
void sbrGetNoiseFloorData(
861
    HANDLE_SBR_HEADER_DATA hHeaderData, /*!< Static control data */
862
    HANDLE_SBR_FRAME_DATA h_frame_data, /*!< handle to struct SBR_FRAME_DATA */
863
    HANDLE_FDK_BITSTREAM hBs)           /*!< handle to struct BIT_BUF */
864
398k
{
865
398k
  int i, j;
866
398k
  int delta;
867
398k
  COUPLING_MODE coupling;
868
398k
  int noNoiseBands = hHeaderData->freqBandData.nNfb;
869
870
398k
  Huffman hcb_noiseF;
871
398k
  Huffman hcb_noise;
872
398k
  int envDataTableCompFactor;
873
874
398k
  coupling = h_frame_data->coupling;
875
876
  /*
877
    Select huffman codebook depending on coupling mode
878
  */
879
398k
  if (coupling == COUPLING_BAL) {
880
31.3k
    hcb_noise = (Huffman)&FDK_sbrDecoder_sbr_huffBook_NoiseBalance11T;
881
31.3k
    hcb_noiseF =
882
31.3k
        (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance11F; /* "sbr_huffBook_NoiseBalance11F"
883
                                                              */
884
31.3k
    envDataTableCompFactor = 1;
885
367k
  } else {
886
367k
    hcb_noise = (Huffman)&FDK_sbrDecoder_sbr_huffBook_NoiseLevel11T;
887
367k
    hcb_noiseF =
888
367k
        (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel11F; /* "sbr_huffBook_NoiseLevel11F"
889
                                                            */
890
367k
    envDataTableCompFactor = 0;
891
367k
  }
892
893
  /*
894
    Read raw noise-envelope data
895
  */
896
1.03M
  for (i = 0; i < h_frame_data->frameInfo.nNoiseEnvelopes; i++) {
897
634k
    if (h_frame_data->domain_vec_noise[i] == 0) {
898
455k
      if (coupling == COUPLING_BAL) {
899
44.6k
        h_frame_data->sbrNoiseFloorLevel[i * noNoiseBands] =
900
44.6k
            (FIXP_SGL)(((int)FDKreadBits(hBs, 5)) << envDataTableCompFactor);
901
410k
      } else {
902
410k
        h_frame_data->sbrNoiseFloorLevel[i * noNoiseBands] =
903
410k
            (FIXP_SGL)(int)FDKreadBits(hBs, 5);
904
410k
      }
905
906
1.09M
      for (j = 1; j < noNoiseBands; j++) {
907
634k
        delta = DecodeHuffmanCW(hcb_noiseF, hBs);
908
634k
        h_frame_data->sbrNoiseFloorLevel[i * noNoiseBands + j] =
909
634k
            (FIXP_SGL)(delta << envDataTableCompFactor);
910
634k
      }
911
455k
    } else {
912
538k
      for (j = 0; j < noNoiseBands; j++) {
913
359k
        delta = DecodeHuffmanCW(hcb_noise, hBs);
914
359k
        h_frame_data->sbrNoiseFloorLevel[i * noNoiseBands + j] =
915
359k
            (FIXP_SGL)(delta << envDataTableCompFactor);
916
359k
      }
917
179k
    }
918
634k
  }
919
398k
}
920
921
/* ns = mapNsMode2ns[pvcMode-1][nsMode] */
922
static const UCHAR mapNsMode2ns[2][2] = {
923
    {16, 4}, /* pvcMode = 1 */
924
    {12, 3}  /* pvcMode = 2 */
925
};
926
927
static int sbrGetPvcEnvelope(
928
    HANDLE_SBR_HEADER_DATA hHeaderData, /*!< Static control data */
929
    HANDLE_SBR_FRAME_DATA h_frame_data, /*!< handle to struct SBR_FRAME_DATA */
930
    HANDLE_FDK_BITSTREAM hBs,           /*!< handle to struct BIT_BUF */
931
132k
    const UINT flags, const UINT pvcMode) {
932
132k
  int divMode, nsMode;
933
132k
  int indepFlag = flags & SBRDEC_USAC_INDEP;
934
132k
  UCHAR *pvcID = h_frame_data->pvcID;
935
936
132k
  divMode = FDKreadBits(hBs, PVC_DIVMODE_BITS);
937
132k
  nsMode = FDKreadBit(hBs);
938
132k
  FDK_ASSERT((pvcMode == 1) || (pvcMode == 2));
939
132k
  h_frame_data->ns = mapNsMode2ns[pvcMode - 1][nsMode];
940
941
132k
  if (divMode <= 3) {
942
16.3k
    int i, k = 1, sum_length = 0, reuse_pcvID;
943
944
    /* special treatment for first time slot k=0 */
945
16.3k
    indepFlag ? (reuse_pcvID = 0) : (reuse_pcvID = FDKreadBit(hBs));
946
16.3k
    if (reuse_pcvID) {
947
4.58k
      pvcID[0] = hHeaderData->pvcIDprev;
948
11.7k
    } else {
949
11.7k
      pvcID[0] = FDKreadBits(hBs, PVC_PVCID_BITS);
950
11.7k
    }
951
952
    /* other time slots k>0 */
953
31.8k
    for (i = 0; i < divMode; i++) {
954
16.1k
      int length, numBits = 4;
955
956
16.1k
      if (sum_length >= 13) {
957
1.03k
        numBits = 1;
958
15.1k
      } else if (sum_length >= 11) {
959
372
        numBits = 2;
960
14.7k
      } else if (sum_length >= 7) {
961
1.46k
        numBits = 3;
962
1.46k
      }
963
964
16.1k
      length = FDKreadBits(hBs, numBits);
965
16.1k
      sum_length += length + 1;
966
16.1k
      if (sum_length >= PVC_NTIMESLOT) {
967
639
        return 0; /* parse error */
968
639
      }
969
63.0k
      for (; length--; k++) {
970
47.5k
        pvcID[k] = pvcID[k - 1];
971
47.5k
      }
972
15.5k
      pvcID[k++] = FDKreadBits(hBs, PVC_PVCID_BITS);
973
15.5k
    }
974
193k
    for (; k < 16; k++) {
975
177k
      pvcID[k] = pvcID[k - 1];
976
177k
    }
977
116k
  } else { /* divMode >= 4 */
978
116k
    int num_grid_info, fixed_length, grid_info, j, k = 0;
979
980
116k
    divMode -= 4;
981
116k
    num_grid_info = 2 << divMode;
982
116k
    fixed_length = 8 >> divMode;
983
116k
    FDK_ASSERT(num_grid_info * fixed_length == PVC_NTIMESLOT);
984
985
    /* special treatment for first time slot k=0 */
986
116k
    indepFlag ? (grid_info = 1) : (grid_info = FDKreadBit(hBs));
987
116k
    if (grid_info) {
988
112k
      pvcID[k++] = FDKreadBits(hBs, PVC_PVCID_BITS);
989
112k
    } else {
990
3.95k
      pvcID[k++] = hHeaderData->pvcIDprev;
991
3.95k
    }
992
116k
    j = fixed_length - 1;
993
903k
    for (; j--; k++) {
994
787k
      pvcID[k] = pvcID[k - 1];
995
787k
    }
996
116k
    num_grid_info--;
997
998
    /* other time slots k>0 */
999
273k
    for (; num_grid_info--;) {
1000
157k
      j = fixed_length;
1001
157k
      grid_info = FDKreadBit(hBs);
1002
157k
      if (grid_info) {
1003
16.1k
        pvcID[k++] = FDKreadBits(hBs, PVC_PVCID_BITS);
1004
16.1k
        j--;
1005
16.1k
      }
1006
1.09M
      for (; j--; k++) {
1007
936k
        pvcID[k] = pvcID[k - 1];
1008
936k
      }
1009
157k
    }
1010
116k
  }
1011
1012
131k
  hHeaderData->pvcIDprev = pvcID[PVC_NTIMESLOT - 1];
1013
1014
  /* usage of PVC excludes inter-TES tool */
1015
131k
  h_frame_data->iTESactive = (UCHAR)0;
1016
1017
131k
  return 1;
1018
132k
}
1019
/*!
1020
  \brief   Read envelope data from bitstream
1021
*/
1022
static int sbrGetEnvelope(
1023
    HANDLE_SBR_HEADER_DATA hHeaderData, /*!< Static control data */
1024
    HANDLE_SBR_FRAME_DATA h_frame_data, /*!< handle to struct SBR_FRAME_DATA */
1025
    HANDLE_FDK_BITSTREAM hBs,           /*!< handle to struct BIT_BUF */
1026
267k
    const UINT flags) {
1027
267k
  int i, j;
1028
267k
  UCHAR no_band[MAX_ENVELOPES];
1029
267k
  int delta = 0;
1030
267k
  int offset = 0;
1031
267k
  COUPLING_MODE coupling = h_frame_data->coupling;
1032
267k
  int ampRes = hHeaderData->bs_info.ampResolution;
1033
267k
  int nEnvelopes = h_frame_data->frameInfo.nEnvelopes;
1034
267k
  int envDataTableCompFactor;
1035
267k
  int start_bits, start_bits_balance;
1036
267k
  Huffman hcb_t, hcb_f;
1037
1038
267k
  h_frame_data->nScaleFactors = 0;
1039
1040
267k
  if ((h_frame_data->frameInfo.frameClass == 0) && (nEnvelopes == 1)) {
1041
97.5k
    if (flags & SBRDEC_ELD_GRID)
1042
36.7k
      ampRes = h_frame_data->ampResolutionCurrentFrame;
1043
60.8k
    else
1044
60.8k
      ampRes = 0;
1045
97.5k
  }
1046
267k
  h_frame_data->ampResolutionCurrentFrame = ampRes;
1047
1048
  /*
1049
    Set number of bits for first value depending on amplitude resolution
1050
  */
1051
267k
  if (ampRes == 1) {
1052
73.1k
    start_bits = 6;
1053
73.1k
    start_bits_balance = 5;
1054
193k
  } else {
1055
193k
    start_bits = 7;
1056
193k
    start_bits_balance = 6;
1057
193k
  }
1058
1059
  /*
1060
    Calculate number of values for each envelope and alltogether
1061
  */
1062
752k
  for (i = 0; i < nEnvelopes; i++) {
1063
485k
    no_band[i] =
1064
485k
        hHeaderData->freqBandData.nSfb[h_frame_data->frameInfo.freqRes[i]];
1065
485k
    h_frame_data->nScaleFactors += no_band[i];
1066
485k
  }
1067
267k
  if (h_frame_data->nScaleFactors > MAX_NUM_ENVELOPE_VALUES) return 0;
1068
1069
  /*
1070
    Select Huffman codebook depending on coupling mode and amplitude resolution
1071
  */
1072
267k
  if (coupling == COUPLING_BAL) {
1073
31.3k
    envDataTableCompFactor = 1;
1074
31.3k
    if (ampRes == 0) {
1075
25.6k
      hcb_t = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance10T;
1076
25.6k
      hcb_f = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance10F;
1077
25.6k
    } else {
1078
5.76k
      hcb_t = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance11T;
1079
5.76k
      hcb_f = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance11F;
1080
5.76k
    }
1081
235k
  } else {
1082
235k
    envDataTableCompFactor = 0;
1083
235k
    if (ampRes == 0) {
1084
168k
      hcb_t = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel10T;
1085
168k
      hcb_f = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel10F;
1086
168k
    } else {
1087
67.3k
      hcb_t = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel11T;
1088
67.3k
      hcb_f = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel11F;
1089
67.3k
    }
1090
235k
  }
1091
1092
267k
  h_frame_data->iTESactive = (UCHAR)0; /* disable inter-TES by default */
1093
  /*
1094
    Now read raw envelope data
1095
  */
1096
752k
  for (j = 0, offset = 0; j < nEnvelopes; j++) {
1097
485k
    if (h_frame_data->domain_vec[j] == 0) {
1098
353k
      if (coupling == COUPLING_BAL) {
1099
51.8k
        h_frame_data->iEnvelope[offset] =
1100
51.8k
            (FIXP_SGL)(((int)FDKreadBits(hBs, start_bits_balance))
1101
51.8k
                       << envDataTableCompFactor);
1102
301k
      } else {
1103
301k
        h_frame_data->iEnvelope[offset] =
1104
301k
            (FIXP_SGL)(int)FDKreadBits(hBs, start_bits);
1105
301k
      }
1106
353k
    }
1107
1108
3.80M
    for (i = (1 - h_frame_data->domain_vec[j]); i < no_band[j]; i++) {
1109
3.32M
      if (h_frame_data->domain_vec[j] == 0) {
1110
2.22M
        delta = DecodeHuffmanCW(hcb_f, hBs);
1111
2.22M
      } else {
1112
1.09M
        delta = DecodeHuffmanCW(hcb_t, hBs);
1113
1.09M
      }
1114
1115
3.32M
      h_frame_data->iEnvelope[offset + i] =
1116
3.32M
          (FIXP_SGL)(delta << envDataTableCompFactor);
1117
3.32M
    }
1118
485k
    if ((flags & SBRDEC_SYNTAX_USAC) && (flags & SBRDEC_USAC_ITES)) {
1119
154k
      int bs_temp_shape = FDKreadBit(hBs);
1120
154k
      FDK_ASSERT(j < 8);
1121
154k
      h_frame_data->iTESactive |= (UCHAR)(bs_temp_shape << j);
1122
154k
      if (bs_temp_shape) {
1123
41.4k
        h_frame_data->interTempShapeMode[j] =
1124
41.4k
            FDKread2Bits(hBs); /* bs_inter_temp_shape_mode */
1125
113k
      } else {
1126
113k
        h_frame_data->interTempShapeMode[j] = 0;
1127
113k
      }
1128
154k
    }
1129
485k
    offset += no_band[j];
1130
485k
  }
1131
1132
#if ENV_EXP_FRACT
1133
  /* Convert from int to scaled fract (ENV_EXP_FRACT bits for the fractional
1134
   * part) */
1135
  for (i = 0; i < h_frame_data->nScaleFactors; i++) {
1136
    h_frame_data->iEnvelope[i] <<= ENV_EXP_FRACT;
1137
  }
1138
#endif
1139
1140
267k
  return 1;
1141
267k
}
1142
1143
/***************************************************************************/
1144
/*!
1145
  \brief    Generates frame info for FIXFIXonly frame class used for low delay
1146
 version
1147
1148
  \return   zero for error, one for correct.
1149
 ****************************************************************************/
1150
static int generateFixFixOnly(FRAME_INFO *hSbrFrameInfo, int tranPosInternal,
1151
10.0k
                              int numberTimeSlots, const UINT flags) {
1152
10.0k
  int nEnv, i, tranIdx;
1153
10.0k
  const int *pTable;
1154
1155
10.0k
  if (tranPosInternal >= numberTimeSlots) {
1156
0
    return 0;
1157
0
  }
1158
1159
10.0k
  switch (numberTimeSlots) {
1160
0
    case 8:
1161
0
      pTable = FDK_sbrDecoder_envelopeTable_8[tranPosInternal];
1162
0
      break;
1163
7.85k
    case 15:
1164
7.85k
      pTable = FDK_sbrDecoder_envelopeTable_15[tranPosInternal];
1165
7.85k
      break;
1166
2.16k
    case 16:
1167
2.16k
      pTable = FDK_sbrDecoder_envelopeTable_16[tranPosInternal];
1168
2.16k
      break;
1169
0
    default:
1170
0
      return 0;
1171
10.0k
  }
1172
1173
  /* look number of envelopes in table */
1174
10.0k
  nEnv = pTable[0];
1175
  /* look up envelope distribution in table */
1176
24.1k
  for (i = 1; i < nEnv; i++) hSbrFrameInfo->borders[i] = pTable[i + 2];
1177
  /* open and close frame border */
1178
10.0k
  hSbrFrameInfo->borders[0] = 0;
1179
10.0k
  hSbrFrameInfo->borders[nEnv] = numberTimeSlots;
1180
10.0k
  hSbrFrameInfo->nEnvelopes = nEnv;
1181
1182
  /* transient idx */
1183
10.0k
  tranIdx = hSbrFrameInfo->tranEnv = pTable[1];
1184
1185
  /* add noise floors */
1186
10.0k
  hSbrFrameInfo->bordersNoise[0] = 0;
1187
10.0k
  hSbrFrameInfo->bordersNoise[1] =
1188
10.0k
      hSbrFrameInfo->borders[tranIdx ? tranIdx : 1];
1189
10.0k
  hSbrFrameInfo->bordersNoise[2] = numberTimeSlots;
1190
  /* nEnv is always > 1, so nNoiseEnvelopes is always 2 (IEC 14496-3 4.6.19.3.2)
1191
   */
1192
10.0k
  hSbrFrameInfo->nNoiseEnvelopes = 2;
1193
1194
10.0k
  return 1;
1195
10.0k
}
1196
1197
/*!
1198
  \brief  Extracts LowDelaySBR control data from the bitstream.
1199
1200
  \return zero for bitstream error, one for correct.
1201
*/
1202
static int extractLowDelayGrid(
1203
    HANDLE_FDK_BITSTREAM hBitBuf, /*!< bitbuffer handle */
1204
    HANDLE_SBR_HEADER_DATA hHeaderData,
1205
    HANDLE_SBR_FRAME_DATA
1206
        h_frame_data, /*!< contains the FRAME_INFO struct to be filled */
1207
11.7k
    int timeSlots, const UINT flags) {
1208
11.7k
  FRAME_INFO *pFrameInfo = &h_frame_data->frameInfo;
1209
11.7k
  INT numberTimeSlots = hHeaderData->numberTimeSlots;
1210
11.7k
  INT temp = 0, k;
1211
1212
  /* FIXFIXonly framing case */
1213
11.7k
  h_frame_data->frameInfo.frameClass = 0;
1214
1215
  /* get the transient position from the bitstream */
1216
11.7k
  switch (timeSlots) {
1217
0
    case 8:
1218
      /* 3bit transient position (temp={0;..;7}) */
1219
0
      temp = FDKreadBits(hBitBuf, 3);
1220
0
      break;
1221
1222
2.16k
    case 16:
1223
11.7k
    case 15:
1224
      /* 4bit transient position (temp={0;..;15}) */
1225
11.7k
      temp = FDKreadBits(hBitBuf, 4);
1226
11.7k
      break;
1227
1228
0
    default:
1229
0
      return 0;
1230
11.7k
  }
1231
1232
  /* For "case 15" only*/
1233
11.7k
  if (temp >= timeSlots) {
1234
1.77k
    return 0;
1235
1.77k
  }
1236
1237
  /* calculate borders according to the transient position */
1238
10.0k
  if (!generateFixFixOnly(pFrameInfo, temp, numberTimeSlots, flags)) {
1239
0
    return 0;
1240
0
  }
1241
1242
  /* decode freq res: */
1243
34.1k
  for (k = 0; k < pFrameInfo->nEnvelopes; k++) {
1244
24.1k
    pFrameInfo->freqRes[k] =
1245
24.1k
        (UCHAR)FDKreadBits(hBitBuf, 1); /* f = F [1 bits] */
1246
24.1k
  }
1247
1248
10.0k
  return 1;
1249
10.0k
}
1250
1251
/*!
1252
  \brief   Extract the PVC frame information (structure FRAME_INFO) from the
1253
  bitstream \return  Zero for bitstream error, one for correct.
1254
*/
1255
int extractPvcFrameInfo(
1256
    HANDLE_FDK_BITSTREAM hBs,           /*!< bitbuffer handle */
1257
    HANDLE_SBR_HEADER_DATA hHeaderData, /*!< Static control data */
1258
    HANDLE_SBR_FRAME_DATA h_frame_data, /*!< pointer to memory where the
1259
                                           frame-info will be stored */
1260
    HANDLE_SBR_PREV_FRAME_DATA h_prev_frame_data, /*!< pointer to memory where
1261
                                                     the previous frame-info
1262
                                                     will be stored */
1263
    UCHAR pvc_mode_last,                          /**< PVC mode of last frame */
1264
133k
    const UINT flags) {
1265
133k
  FRAME_INFO *pFrameInfo = &h_frame_data->frameInfo;
1266
133k
  FRAME_INFO *pPrevFrameInfo = &h_prev_frame_data->prevFrameInfo;
1267
133k
  int bs_var_len_hf, bs_noise_position;
1268
133k
  bs_noise_position = FDKreadBits(hBs, 4); /* SBR_PVC_NOISEPOSITION_BITS 4 */
1269
133k
  bs_var_len_hf = FDKreadBit(hBs);
1270
133k
  pFrameInfo->noisePosition = bs_noise_position;
1271
133k
  pFrameInfo->tranEnv = -1;
1272
1273
  /* Init for bs_noise_position == 0 in case a parse error is found below. */
1274
133k
  pFrameInfo->nEnvelopes = 1;
1275
133k
  pFrameInfo->nNoiseEnvelopes = 1;
1276
133k
  pFrameInfo->freqRes[0] = 0;
1277
1278
133k
  if (bs_var_len_hf) { /* 1 or 3 Bits */
1279
115k
    pFrameInfo->varLength = FDKreadBits(hBs, 2) + 1;
1280
115k
    if (pFrameInfo->varLength > 3) {
1281
919
      pFrameInfo->varLength =
1282
919
          0;    /* assume bs_var_len_hf == 0 in case of error */
1283
919
      return 0; /* reserved value -> parse error */
1284
919
    }
1285
115k
  } else {
1286
18.2k
    pFrameInfo->varLength = 0;
1287
18.2k
  }
1288
1289
132k
  if (bs_noise_position) {
1290
118k
    pFrameInfo->nEnvelopes = 2;
1291
118k
    pFrameInfo->nNoiseEnvelopes = 2;
1292
118k
    FDKmemclear(pFrameInfo->freqRes, sizeof(pFrameInfo->freqRes));
1293
118k
  }
1294
1295
  /* frame border calculation */
1296
132k
  if (hHeaderData->bs_info.pvc_mode > 0) {
1297
    /* See "7.5.1.4 HF adjustment of SBR envelope scalefactors" for reference.
1298
     */
1299
1300
132k
    FDK_ASSERT((pFrameInfo->nEnvelopes == 1) || (pFrameInfo->nEnvelopes == 2));
1301
1302
    /* left timeborder-offset: use the timeborder of prev SBR frame */
1303
132k
    if (pPrevFrameInfo->nEnvelopes > 0) {
1304
128k
      pFrameInfo->borders[0] =
1305
128k
          pPrevFrameInfo->borders[pPrevFrameInfo->nEnvelopes] - PVC_NTIMESLOT;
1306
128k
      FDK_ASSERT(pFrameInfo->borders[0] <= 3);
1307
128k
    } else {
1308
4.11k
      pFrameInfo->borders[0] = 0;
1309
4.11k
    }
1310
1311
    /* right timeborder-offset: */
1312
132k
    pFrameInfo->borders[pFrameInfo->nEnvelopes] = 16 + pFrameInfo->varLength;
1313
1314
132k
    if (pFrameInfo->nEnvelopes == 2) {
1315
118k
      pFrameInfo->borders[1] = pFrameInfo->noisePosition;
1316
118k
    }
1317
1318
    /* Calculation of PVC time borders t_EPVC */
1319
132k
    if (pvc_mode_last == 0) {
1320
      /* there was a legacy SBR frame before this frame => use bs_var_len' for
1321
       * first PVC timeslot */
1322
9.37k
      pFrameInfo->pvcBorders[0] = pFrameInfo->borders[0];
1323
123k
    } else {
1324
123k
      pFrameInfo->pvcBorders[0] = 0;
1325
123k
    }
1326
132k
    if (pFrameInfo->nEnvelopes == 2) {
1327
118k
      pFrameInfo->pvcBorders[1] = pFrameInfo->borders[1];
1328
118k
    }
1329
132k
    pFrameInfo->pvcBorders[pFrameInfo->nEnvelopes] = 16;
1330
1331
    /* calculation of SBR noise-floor time-border vector: */
1332
517k
    for (INT i = 0; i <= pFrameInfo->nNoiseEnvelopes; i++) {
1333
384k
      pFrameInfo->bordersNoise[i] = pFrameInfo->borders[i];
1334
384k
    }
1335
1336
132k
    pFrameInfo->tranEnv = -1; /* tranEnv not used */
1337
132k
  }
1338
132k
  return 1;
1339
132k
}
1340
1341
/*!
1342
  \brief   Extract the frame information (structure FRAME_INFO) from the
1343
  bitstream \return  Zero for bitstream error, one for correct.
1344
*/
1345
int extractFrameInfo(
1346
    HANDLE_FDK_BITSTREAM hBs,           /*!< bitbuffer handle */
1347
    HANDLE_SBR_HEADER_DATA hHeaderData, /*!< Static control data */
1348
    HANDLE_SBR_FRAME_DATA h_frame_data, /*!< pointer to memory where the
1349
                                           frame-info will be stored */
1350
249k
    const UINT nrOfChannels, const UINT flags) {
1351
249k
  FRAME_INFO *pFrameInfo = &h_frame_data->frameInfo;
1352
249k
  int numberTimeSlots = hHeaderData->numberTimeSlots;
1353
249k
  int pointer_bits = 0, nEnv = 0, b = 0, border, i, n = 0, k, p, aL, aR, nL, nR,
1354
249k
      temp = 0, staticFreqRes;
1355
249k
  UCHAR frameClass;
1356
1357
249k
  if (flags & SBRDEC_ELD_GRID) {
1358
    /* CODEC_AACLD (LD+SBR) only uses the normal 0 Grid for non-transient Frames
1359
     * and the LowDelayGrid for transient Frames */
1360
62.0k
    frameClass = FDKreadBits(hBs, 1); /* frameClass = [1 bit] */
1361
62.0k
    if (frameClass == 1) {
1362
      /* if frameClass == 1, extract LowDelaySbrGrid, otherwise extract normal
1363
       * SBR-Grid for FIXIFX */
1364
      /* extract the AACLD-Sbr-Grid */
1365
11.7k
      pFrameInfo->frameClass = frameClass;
1366
11.7k
      int err = 1;
1367
11.7k
      err = extractLowDelayGrid(hBs, hHeaderData, h_frame_data, numberTimeSlots,
1368
11.7k
                                flags);
1369
11.7k
      return err;
1370
11.7k
    }
1371
187k
  } else {
1372
187k
    frameClass = FDKreadBits(hBs, 2); /* frameClass = C [2 bits] */
1373
187k
  }
1374
1375
237k
  switch (frameClass) {
1376
133k
    case 0:
1377
133k
      temp = FDKreadBits(hBs, 2); /* E [2 bits ] */
1378
133k
      nEnv = (int)(1 << temp);    /* E -> e */
1379
1380
133k
      if ((flags & SBRDEC_ELD_GRID) && (nEnv == 1))
1381
36.0k
        h_frame_data->ampResolutionCurrentFrame =
1382
36.0k
            FDKreadBits(hBs, 1); /* new ELD Syntax 07-11-09 */
1383
1384
133k
      staticFreqRes = FDKreadBits(hBs, 1);
1385
1386
133k
      if (flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50)) {
1387
71.1k
        if (nEnv > MAX_ENVELOPES_USAC) return 0;
1388
71.1k
      } else
1389
1390
62.7k
        b = nEnv + 1;
1391
133k
      switch (nEnv) {
1392
89.1k
        case 1:
1393
89.1k
          switch (numberTimeSlots) {
1394
32.3k
            case 15:
1395
32.3k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info1_15,
1396
32.3k
                        sizeof(FRAME_INFO));
1397
32.3k
              break;
1398
56.7k
            case 16:
1399
56.7k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info1_16,
1400
56.7k
                        sizeof(FRAME_INFO));
1401
56.7k
              break;
1402
0
            default:
1403
0
              FDK_ASSERT(0);
1404
89.1k
          }
1405
89.1k
          break;
1406
89.1k
        case 2:
1407
28.2k
          switch (numberTimeSlots) {
1408
6.11k
            case 15:
1409
6.11k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info2_15,
1410
6.11k
                        sizeof(FRAME_INFO));
1411
6.11k
              break;
1412
22.1k
            case 16:
1413
22.1k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info2_16,
1414
22.1k
                        sizeof(FRAME_INFO));
1415
22.1k
              break;
1416
0
            default:
1417
0
              FDK_ASSERT(0);
1418
28.2k
          }
1419
28.2k
          break;
1420
28.2k
        case 4:
1421
10.2k
          switch (numberTimeSlots) {
1422
6.80k
            case 15:
1423
6.80k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info4_15,
1424
6.80k
                        sizeof(FRAME_INFO));
1425
6.80k
              break;
1426
3.48k
            case 16:
1427
3.48k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info4_16,
1428
3.48k
                        sizeof(FRAME_INFO));
1429
3.48k
              break;
1430
0
            default:
1431
0
              FDK_ASSERT(0);
1432
10.2k
          }
1433
10.2k
          break;
1434
10.2k
        case 8:
1435
6.18k
#if (MAX_ENVELOPES >= 8)
1436
6.18k
          switch (numberTimeSlots) {
1437
1.83k
            case 15:
1438
1.83k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info8_15,
1439
1.83k
                        sizeof(FRAME_INFO));
1440
1.83k
              break;
1441
4.35k
            case 16:
1442
4.35k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info8_16,
1443
4.35k
                        sizeof(FRAME_INFO));
1444
4.35k
              break;
1445
0
            default:
1446
0
              FDK_ASSERT(0);
1447
6.18k
          }
1448
6.18k
          break;
1449
#else
1450
          return 0;
1451
#endif
1452
133k
      }
1453
      /* Apply correct freqRes (High is default) */
1454
133k
      if (!staticFreqRes) {
1455
224k
        for (i = 0; i < nEnv; i++) pFrameInfo->freqRes[i] = 0;
1456
92.0k
      }
1457
1458
133k
      break;
1459
48.4k
    case 1:
1460
88.6k
    case 2:
1461
88.6k
      temp = FDKreadBits(hBs, 2); /* A [2 bits] */
1462
1463
88.6k
      n = FDKreadBits(hBs, 2); /* n = N [2 bits] */
1464
1465
88.6k
      nEnv = n + 1; /* # envelopes */
1466
88.6k
      b = nEnv + 1; /* # borders   */
1467
1468
88.6k
      break;
1469
237k
  }
1470
1471
237k
  switch (frameClass) {
1472
48.4k
    case 1:
1473
      /* Decode borders: */
1474
48.4k
      pFrameInfo->borders[0] = 0;      /* first border          */
1475
48.4k
      border = temp + numberTimeSlots; /* A -> aR               */
1476
48.4k
      i = b - 1;                       /* frame info index for last border */
1477
48.4k
      pFrameInfo->borders[i] = border; /* last border                      */
1478
1479
92.0k
      for (k = 0; k < n; k++) {
1480
43.6k
        temp = FDKreadBits(hBs, 2); /* R [2 bits] */
1481
43.6k
        border -= (2 * temp + 2);   /* R -> r                */
1482
43.6k
        pFrameInfo->borders[--i] = border;
1483
43.6k
      }
1484
1485
      /* Decode pointer: */
1486
48.4k
      pointer_bits = DFRACT_BITS - 1 - CountLeadingBits((FIXP_DBL)(n + 1));
1487
48.4k
      p = FDKreadBits(hBs, pointer_bits); /* p = P [pointer_bits bits] */
1488
1489
48.4k
      if (p > n + 1) return 0;
1490
1491
46.9k
      pFrameInfo->tranEnv = p ? n + 2 - p : -1;
1492
1493
      /* Decode freq res: */
1494
133k
      for (k = n; k >= 0; k--) {
1495
86.8k
        pFrameInfo->freqRes[k] = FDKreadBits(hBs, 1); /* f = F [1 bits] */
1496
86.8k
      }
1497
1498
      /* Calculate noise floor middle border: */
1499
46.9k
      if (p == 0 || p == 1)
1500
44.9k
        pFrameInfo->bordersNoise[1] = pFrameInfo->borders[n];
1501
1.97k
      else
1502
1.97k
        pFrameInfo->bordersNoise[1] = pFrameInfo->borders[pFrameInfo->tranEnv];
1503
1504
46.9k
      break;
1505
1506
40.1k
    case 2:
1507
      /* Decode borders: */
1508
40.1k
      border = temp;                   /* A -> aL */
1509
40.1k
      pFrameInfo->borders[0] = border; /* first border */
1510
1511
62.4k
      for (k = 1; k <= n; k++) {
1512
22.2k
        temp = FDKreadBits(hBs, 2); /* R [2 bits] */
1513
22.2k
        border += (2 * temp + 2);   /* R -> r                */
1514
22.2k
        pFrameInfo->borders[k] = border;
1515
22.2k
      }
1516
40.1k
      pFrameInfo->borders[k] = numberTimeSlots; /* last border */
1517
1518
      /* Decode pointer: */
1519
40.1k
      pointer_bits = DFRACT_BITS - 1 - CountLeadingBits((FIXP_DBL)(n + 1));
1520
40.1k
      p = FDKreadBits(hBs, pointer_bits); /* p = P [pointer_bits bits] */
1521
40.1k
      if (p > n + 1) return 0;
1522
1523
38.6k
      if (p == 0 || p == 1)
1524
31.6k
        pFrameInfo->tranEnv = -1;
1525
6.99k
      else
1526
6.99k
        pFrameInfo->tranEnv = p - 1;
1527
1528
      /* Decode freq res: */
1529
95.7k
      for (k = 0; k <= n; k++) {
1530
57.1k
        pFrameInfo->freqRes[k] = FDKreadBits(hBs, 1); /* f = F [1 bits] */
1531
57.1k
      }
1532
1533
      /* Calculate noise floor middle border: */
1534
38.6k
      switch (p) {
1535
29.0k
        case 0:
1536
29.0k
          pFrameInfo->bordersNoise[1] = pFrameInfo->borders[1];
1537
29.0k
          break;
1538
2.58k
        case 1:
1539
2.58k
          pFrameInfo->bordersNoise[1] = pFrameInfo->borders[n];
1540
2.58k
          break;
1541
6.99k
        default:
1542
6.99k
          pFrameInfo->bordersNoise[1] =
1543
6.99k
              pFrameInfo->borders[pFrameInfo->tranEnv];
1544
6.99k
          break;
1545
38.6k
      }
1546
1547
38.6k
      break;
1548
1549
38.6k
    case 3:
1550
      /* v_ctrlSignal = [frameClass,aL,aR,nL,nR,v_rL,v_rR,p,v_fLR]; */
1551
1552
15.1k
      aL = FDKreadBits(hBs, 2); /* AL [2 bits], AL -> aL */
1553
1554
15.1k
      aR = FDKreadBits(hBs, 2) + numberTimeSlots; /* AR [2 bits], AR -> aR */
1555
1556
15.1k
      nL = FDKreadBits(hBs, 2); /* nL = NL [2 bits] */
1557
1558
15.1k
      nR = FDKreadBits(hBs, 2); /* nR = NR [2 bits] */
1559
1560
      /*-------------------------------------------------------------------------
1561
        Calculate help variables
1562
        --------------------------------------------------------------------------*/
1563
1564
      /* general: */
1565
15.1k
      nEnv = nL + nR + 1; /* # envelopes */
1566
15.1k
      if (nEnv > MAX_ENVELOPES) return 0;
1567
15.1k
      b = nEnv + 1; /* # borders   */
1568
1569
      /*-------------------------------------------------------------------------
1570
        Decode envelopes
1571
        --------------------------------------------------------------------------*/
1572
1573
      /* L-borders:   */
1574
15.1k
      border = aL; /* first border */
1575
15.1k
      pFrameInfo->borders[0] = border;
1576
1577
32.4k
      for (k = 1; k <= nL; k++) {
1578
17.3k
        temp = FDKreadBits(hBs, 2); /* R [2 bits] */
1579
17.3k
        border += (2 * temp + 2);   /* R -> r                */
1580
17.3k
        pFrameInfo->borders[k] = border;
1581
17.3k
      }
1582
1583
      /* R-borders:  */
1584
15.1k
      border = aR; /* last border */
1585
15.1k
      i = nEnv;
1586
1587
15.1k
      pFrameInfo->borders[i] = border;
1588
1589
33.9k
      for (k = 0; k < nR; k++) {
1590
18.7k
        temp = FDKreadBits(hBs, 2); /* R [2 bits] */
1591
18.7k
        border -= (2 * temp + 2);   /* R -> r                */
1592
18.7k
        pFrameInfo->borders[--i] = border;
1593
18.7k
      }
1594
1595
      /* decode pointer: */
1596
15.1k
      pointer_bits =
1597
15.1k
          DFRACT_BITS - 1 - CountLeadingBits((FIXP_DBL)(nL + nR + 1));
1598
15.1k
      p = FDKreadBits(hBs, pointer_bits); /* p = P [pointer_bits bits] */
1599
1600
15.1k
      if (p > nL + nR + 1) return 0;
1601
1602
13.2k
      pFrameInfo->tranEnv = p ? b - p : -1;
1603
1604
      /* decode freq res: */
1605
56.4k
      for (k = 0; k < nEnv; k++) {
1606
43.2k
        pFrameInfo->freqRes[k] = FDKreadBits(hBs, 1); /* f = F [1 bits] */
1607
43.2k
      }
1608
1609
      /*-------------------------------------------------------------------------
1610
        Decode noise floors
1611
        --------------------------------------------------------------------------*/
1612
13.2k
      pFrameInfo->bordersNoise[0] = aL;
1613
1614
13.2k
      if (nEnv == 1) {
1615
        /* 1 noise floor envelope: */
1616
2.02k
        pFrameInfo->bordersNoise[1] = aR;
1617
11.1k
      } else {
1618
        /* 2 noise floor envelopes */
1619
11.1k
        if (p == 0 || p == 1)
1620
8.11k
          pFrameInfo->bordersNoise[1] = pFrameInfo->borders[nEnv - 1];
1621
3.07k
        else
1622
3.07k
          pFrameInfo->bordersNoise[1] =
1623
3.07k
              pFrameInfo->borders[pFrameInfo->tranEnv];
1624
11.1k
        pFrameInfo->bordersNoise[2] = aR;
1625
11.1k
      }
1626
13.2k
      break;
1627
237k
  }
1628
1629
  /*
1630
    Store number of envelopes, noise floor envelopes and frame class
1631
  */
1632
232k
  pFrameInfo->nEnvelopes = nEnv;
1633
1634
232k
  if (nEnv == 1)
1635
139k
    pFrameInfo->nNoiseEnvelopes = 1;
1636
92.7k
  else
1637
92.7k
    pFrameInfo->nNoiseEnvelopes = 2;
1638
1639
232k
  pFrameInfo->frameClass = frameClass;
1640
1641
232k
  if (pFrameInfo->frameClass == 2 || pFrameInfo->frameClass == 1) {
1642
    /* calculate noise floor first and last borders: */
1643
85.6k
    pFrameInfo->bordersNoise[0] = pFrameInfo->borders[0];
1644
85.6k
    pFrameInfo->bordersNoise[pFrameInfo->nNoiseEnvelopes] =
1645
85.6k
        pFrameInfo->borders[nEnv];
1646
85.6k
  }
1647
1648
232k
  return 1;
1649
237k
}
1650
1651
/*!
1652
  \brief   Check if the frameInfo vector has reasonable values.
1653
  \return  Zero for error, one for correct
1654
*/
1655
static int checkFrameInfo(
1656
    FRAME_INFO *pFrameInfo, /*!< pointer to frameInfo */
1657
    int numberOfTimeSlots,  /*!< QMF time slots per frame */
1658
    int overlap,            /*!< Amount of overlap QMF time slots */
1659
    int timeStep)           /*!< QMF slots to SBR slots step factor */
1660
375k
{
1661
375k
  int maxPos, i, j;
1662
375k
  int startPos;
1663
375k
  int stopPos;
1664
375k
  int tranEnv;
1665
375k
  int startPosNoise;
1666
375k
  int stopPosNoise;
1667
375k
  int nEnvelopes = pFrameInfo->nEnvelopes;
1668
375k
  int nNoiseEnvelopes = pFrameInfo->nNoiseEnvelopes;
1669
1670
375k
  if (nEnvelopes < 1 || nEnvelopes > MAX_ENVELOPES) return 0;
1671
1672
375k
  if (nNoiseEnvelopes > MAX_NOISE_ENVELOPES) return 0;
1673
1674
375k
  startPos = pFrameInfo->borders[0];
1675
375k
  stopPos = pFrameInfo->borders[nEnvelopes];
1676
375k
  tranEnv = pFrameInfo->tranEnv;
1677
375k
  startPosNoise = pFrameInfo->bordersNoise[0];
1678
375k
  stopPosNoise = pFrameInfo->bordersNoise[nNoiseEnvelopes];
1679
1680
375k
  if (overlap < 0 || overlap > (3 * (4))) {
1681
0
    return 0;
1682
0
  }
1683
375k
  if (timeStep < 1 || timeStep > (4)) {
1684
0
    return 0;
1685
0
  }
1686
375k
  maxPos = numberOfTimeSlots + (overlap / timeStep);
1687
1688
  /* Check that the start and stop positions of the frame are reasonable values.
1689
   */
1690
375k
  if ((startPos < 0) || (startPos >= stopPos)) return 0;
1691
375k
  if (startPos > maxPos - numberOfTimeSlots) /* First env. must start in or
1692
                                                directly after the overlap
1693
                                                buffer */
1694
0
    return 0;
1695
375k
  if (stopPos < numberOfTimeSlots) /* One complete frame must be ready for
1696
                                      output after processing */
1697
0
    return 0;
1698
375k
  if (stopPos > maxPos) return 0;
1699
1700
  /* Check that the  start border for every envelope is strictly later in time
1701
   */
1702
1.06M
  for (i = 0; i < nEnvelopes; i++) {
1703
689k
    if (pFrameInfo->borders[i] >= pFrameInfo->borders[i + 1]) return 0;
1704
689k
  }
1705
1706
  /* Check that the envelope to be shortened is actually among the envelopes */
1707
370k
  if (tranEnv > nEnvelopes) return 0;
1708
1709
  /* Check the noise borders */
1710
370k
  if (nEnvelopes == 1 && nNoiseEnvelopes > 1) return 0;
1711
1712
370k
  if (startPos != startPosNoise || stopPos != stopPosNoise) return 0;
1713
1714
  /* Check that the  start border for every noise-envelope is strictly later in
1715
   * time*/
1716
957k
  for (i = 0; i < nNoiseEnvelopes; i++) {
1717
586k
    if (pFrameInfo->bordersNoise[i] >= pFrameInfo->bordersNoise[i + 1])
1718
0
      return 0;
1719
586k
  }
1720
1721
  /* Check that every noise border is the same as an envelope border*/
1722
957k
  for (i = 0; i < nNoiseEnvelopes; i++) {
1723
586k
    startPosNoise = pFrameInfo->bordersNoise[i];
1724
1725
856k
    for (j = 0; j < nEnvelopes; j++) {
1726
856k
      if (pFrameInfo->borders[j] == startPosNoise) break;
1727
856k
    }
1728
586k
    if (j == nEnvelopes) return 0;
1729
586k
  }
1730
1731
370k
  return 1;
1732
370k
}