Coverage Report

Created: 2025-11-09 07:00

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/aac/libSBRdec/src/env_extr.cpp
Line
Count
Source
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
15.1k
#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
302k
{
220
302k
  UINT fsMapped = fs, tableSize = 0;
221
302k
  const SR_MAPPING *mappingTable;
222
302k
  int i;
223
224
302k
  if (!isUsac) {
225
167k
    mappingTable = stdSampleRatesMapping;
226
167k
    tableSize = sizeof(stdSampleRatesMapping) / sizeof(SR_MAPPING);
227
167k
  } else {
228
135k
    mappingTable = stdSampleRatesMappingUsac;
229
135k
    tableSize = sizeof(stdSampleRatesMappingUsac) / sizeof(SR_MAPPING);
230
135k
  }
231
232
2.13M
  for (i = tableSize - 1; i >= 0; i--) {
233
2.13M
    if (fs >= mappingTable[i].fsRangeLo) {
234
302k
      fsMapped = mappingTable[i].fsMapped;
235
302k
      break;
236
302k
    }
237
2.13M
  }
238
239
302k
  return (fsMapped);
240
302k
}
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
256k
               const int setDefaultHdr) {
247
256k
  HANDLE_FREQ_BAND_DATA hFreq = &hHeaderData->freqBandData;
248
256k
  SBR_ERROR sbrError = SBRDEC_OK;
249
256k
  int numAnalysisBands;
250
256k
  int sampleRateProc;
251
252
256k
  if (!(flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50))) {
253
167k
    sampleRateProc =
254
167k
        sbrdec_mapToStdSampleRate(sampleRateOut * downscaleFactor, 0);
255
167k
  } else {
256
89.2k
    sampleRateProc = sampleRateOut * downscaleFactor;
257
89.2k
  }
258
259
256k
  if (sampleRateIn == sampleRateOut) {
260
100k
    hHeaderData->sbrProcSmplRate = sampleRateProc << 1;
261
100k
    numAnalysisBands = 32;
262
155k
  } else {
263
155k
    hHeaderData->sbrProcSmplRate = sampleRateProc;
264
155k
    if ((sampleRateOut >> 1) == sampleRateIn) {
265
      /* 1:2 */
266
97.7k
      numAnalysisBands = 32;
267
97.7k
    } else if ((sampleRateOut >> 2) == sampleRateIn) {
268
      /* 1:4 */
269
22.1k
      numAnalysisBands = 16;
270
35.7k
    } else if ((sampleRateOut * 3) >> 3 == (sampleRateIn * 8) >> 3) {
271
      /* 3:8, 3/4 core frame length */
272
35.6k
      numAnalysisBands = 24;
273
35.6k
    } else {
274
102
      sbrError = SBRDEC_UNSUPPORTED_CONFIG;
275
102
      goto bail;
276
102
    }
277
155k
  }
278
256k
  numAnalysisBands /= downscaleFactor;
279
280
256k
  if (setDefaultHdr) {
281
    /* Fill in default values first */
282
254k
    hHeaderData->syncState = SBR_NOT_INITIALIZED;
283
254k
    hHeaderData->status = 0;
284
254k
    hHeaderData->frameErrorFlag = 0;
285
286
254k
    hHeaderData->bs_info.ampResolution = 1;
287
254k
    hHeaderData->bs_info.xover_band = 0;
288
254k
    hHeaderData->bs_info.sbr_preprocessing = 0;
289
254k
    hHeaderData->bs_info.pvc_mode = 0;
290
291
254k
    hHeaderData->bs_data.startFreq = 5;
292
254k
    hHeaderData->bs_data.stopFreq = 0;
293
254k
    hHeaderData->bs_data.freqScale =
294
254k
        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
254k
    hHeaderData->bs_data.alterScale = 1;
300
254k
    hHeaderData->bs_data.noise_bands = 2;
301
254k
    hHeaderData->bs_data.limiterBands = 2;
302
254k
    hHeaderData->bs_data.limiterGains = 2;
303
254k
    hHeaderData->bs_data.interpolFreq = 1;
304
254k
    hHeaderData->bs_data.smoothingLength = 1;
305
306
    /* Patch some entries */
307
254k
    if (sampleRateOut * downscaleFactor >= 96000) {
308
28.1k
      hHeaderData->bs_data.startFreq =
309
28.1k
          4; /*   having read these frequency values from bit stream before. */
310
28.1k
      hHeaderData->bs_data.stopFreq = 3;
311
226k
    } else if (sampleRateOut * downscaleFactor >
312
226k
               24000) { /* Trigger an error if SBR is going to be processed
313
                           without     */
314
78.6k
      hHeaderData->bs_data.startFreq =
315
78.6k
          7; /*   having read these frequency values from bit stream before. */
316
78.6k
      hHeaderData->bs_data.stopFreq = 3;
317
78.6k
    }
318
254k
  }
319
320
256k
  if ((sampleRateOut >> 2) == sampleRateIn) {
321
22.1k
    hHeaderData->timeStep = 4;
322
234k
  } else {
323
234k
    hHeaderData->timeStep = (flags & SBRDEC_ELD_GRID) ? 1 : 2;
324
234k
  }
325
326
  /* Setup pointers to frequency band tables */
327
256k
  hFreq->freqBandTable[0] = hFreq->freqBandTableLo;
328
256k
  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
256k
  hHeaderData->numberTimeSlots =
333
256k
      (samplesPerFrame / numAnalysisBands) >> (hHeaderData->timeStep - 1);
334
256k
  if (hHeaderData->numberTimeSlots > (16)) {
335
0
    sbrError = SBRDEC_UNSUPPORTED_CONFIG;
336
0
  }
337
338
256k
  hHeaderData->numberOfAnalysisBands = numAnalysisBands;
339
256k
  if ((sampleRateOut >> 2) == sampleRateIn) {
340
22.1k
    hHeaderData->numberTimeSlots <<= 1;
341
22.1k
  }
342
343
256k
bail:
344
256k
  return sbrError;
345
256k
}
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.22M
  for (i = 0; i < MAX_FREQ_COEFFS; i++)
360
9.06M
    h_prev_data->sfb_nrg_prev[i] = (FIXP_DBL)0;
361
970k
  for (i = 0; i < MAX_NOISE_COEFFS; i++)
362
808k
    h_prev_data->prevNoiseLevel[i] = (FIXP_DBL)0;
363
970k
  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
727k
                 const UCHAR configMode) {
381
727k
  SBR_HEADER_DATA_BS *pBsData;
382
727k
  SBR_HEADER_DATA_BS lastHeader;
383
727k
  SBR_HEADER_DATA_BS_INFO lastInfo;
384
727k
  int headerExtra1 = 0, headerExtra2 = 0;
385
386
  /* Read and discard new header in config change detection mode */
387
727k
  if (configMode & AC_CM_DET_CFG_CHANGE) {
388
371k
    if (!(flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC))) {
389
      /* ampResolution */
390
255k
      FDKreadBits(hBs, 1);
391
255k
    }
392
    /* startFreq, stopFreq */
393
371k
    FDKpushFor(hBs, 8);
394
371k
    if (!(flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC))) {
395
      /* xover_band */
396
255k
      FDKreadBits(hBs, 3);
397
      /* reserved bits */
398
255k
      FDKreadBits(hBs, 2);
399
255k
    }
400
371k
    headerExtra1 = FDKreadBit(hBs);
401
371k
    headerExtra2 = FDKreadBit(hBs);
402
371k
    FDKpushFor(hBs, 5 * headerExtra1 + 6 * headerExtra2);
403
404
371k
    return HEADER_OK;
405
371k
  }
406
407
  /* Copy SBR bit stream header to temporary header */
408
356k
  lastHeader = hHeaderData->bs_data;
409
356k
  lastInfo = hHeaderData->bs_info;
410
411
  /* Read new header from bitstream */
412
356k
  if ((flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC)) && !fIsSbrData) {
413
64.6k
    pBsData = &hHeaderData->bs_dflt;
414
292k
  } else {
415
292k
    pBsData = &hHeaderData->bs_data;
416
292k
  }
417
418
356k
  if (!(flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC))) {
419
205k
    hHeaderData->bs_info.ampResolution = FDKreadBits(hBs, 1);
420
205k
  }
421
422
356k
  pBsData->startFreq = FDKreadBits(hBs, 4);
423
356k
  pBsData->stopFreq = FDKreadBits(hBs, 4);
424
425
356k
  if (!(flags & (SBRDEC_SYNTAX_RSVD50 | SBRDEC_SYNTAX_USAC))) {
426
205k
    hHeaderData->bs_info.xover_band = FDKreadBits(hBs, 3);
427
205k
    FDKreadBits(hBs, 2);
428
205k
  }
429
430
356k
  headerExtra1 = FDKreadBits(hBs, 1);
431
356k
  headerExtra2 = FDKreadBits(hBs, 1);
432
433
  /* Handle extra header information */
434
356k
  if (headerExtra1) {
435
115k
    pBsData->freqScale = FDKreadBits(hBs, 2);
436
115k
    pBsData->alterScale = FDKreadBits(hBs, 1);
437
115k
    pBsData->noise_bands = FDKreadBits(hBs, 2);
438
241k
  } else {
439
241k
    pBsData->freqScale = 2;
440
241k
    pBsData->alterScale = 1;
441
241k
    pBsData->noise_bands = 2;
442
241k
  }
443
444
356k
  if (headerExtra2) {
445
122k
    pBsData->limiterBands = FDKreadBits(hBs, 2);
446
122k
    pBsData->limiterGains = FDKreadBits(hBs, 2);
447
122k
    pBsData->interpolFreq = FDKreadBits(hBs, 1);
448
122k
    pBsData->smoothingLength = FDKreadBits(hBs, 1);
449
234k
  } else {
450
234k
    pBsData->limiterBands = 2;
451
234k
    pBsData->limiterGains = 2;
452
234k
    pBsData->interpolFreq = 1;
453
234k
    pBsData->smoothingLength = 1;
454
234k
  }
455
456
  /* Look for new settings. IEC 14496-3, 4.6.18.3.1 */
457
356k
  if (hHeaderData->syncState < SBR_HEADER ||
458
186k
      lastHeader.startFreq != pBsData->startFreq ||
459
128k
      lastHeader.stopFreq != pBsData->stopFreq ||
460
111k
      lastHeader.freqScale != pBsData->freqScale ||
461
109k
      lastHeader.alterScale != pBsData->alterScale ||
462
106k
      lastHeader.noise_bands != pBsData->noise_bands ||
463
254k
      lastInfo.xover_band != hHeaderData->bs_info.xover_band) {
464
254k
    return HEADER_RESET; /* New settings */
465
254k
  }
466
467
102k
  return HEADER_OK;
468
356k
}
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
405k
                             HANDLE_FDK_BITSTREAM hBs, const UINT flags) {
478
405k
  int i, bitsRead = 0;
479
480
405k
  int add_harmonic_flag = FDKreadBits(hBs, 1);
481
405k
  bitsRead++;
482
483
405k
  if (add_harmonic_flag) {
484
46.5k
    int nSfb = hHeaderData->freqBandData.nSfb[1];
485
139k
    for (i = 0; i < ADD_HARMONICS_FLAGS_SIZE; i++) {
486
      /* read maximum 32 bits and align them to the MSB */
487
93.1k
      int readBits = fMin(32, nSfb);
488
93.1k
      nSfb -= readBits;
489
93.1k
      if (readBits > 0) {
490
48.3k
        hFrameData->addHarmonics[i] = FDKreadBits(hBs, readBits)
491
48.3k
                                      << (32 - readBits);
492
48.3k
      } else {
493
44.7k
        hFrameData->addHarmonics[i] = 0;
494
44.7k
      }
495
496
93.1k
      bitsRead += readBits;
497
93.1k
    }
498
    /* bs_pvc_mode = 0 for Rsvd50 */
499
46.5k
    if (flags & SBRDEC_SYNTAX_USAC) {
500
16.4k
      if (hHeaderData->bs_info.pvc_mode) {
501
5.25k
        int bs_sinusoidal_position = 31;
502
5.25k
        if (FDKreadBit(hBs) /* bs_sinusoidal_position_flag */) {
503
922
          bs_sinusoidal_position = FDKreadBits(hBs, 5);
504
922
        }
505
5.25k
        hFrameData->sinusoidal_position = bs_sinusoidal_position;
506
5.25k
      }
507
16.4k
    }
508
358k
  } else {
509
1.07M
    for (i = 0; i < ADD_HARMONICS_FLAGS_SIZE; i++)
510
717k
      hFrameData->addHarmonics[i] = 0;
511
358k
  }
512
513
405k
  return (bitsRead);
514
405k
}
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
70.4k
) {
531
70.4k
  INT nBitsLeft;
532
70.4k
  int extended_data;
533
70.4k
  int i, frameOk = 1;
534
535
70.4k
  extended_data = FDKreadBits(hBs, 1);
536
537
70.4k
  if (extended_data) {
538
27.9k
    int cnt;
539
27.9k
    int bPsRead = 0;
540
541
27.9k
    cnt = FDKreadBits(hBs, 4);
542
27.9k
    if (cnt == (1 << 4) - 1) cnt += FDKreadBits(hBs, 8);
543
544
27.9k
    nBitsLeft = 8 * cnt;
545
546
    /* sanity check for cnt */
547
27.9k
    if (nBitsLeft > (INT)FDKgetValidBits(hBs)) {
548
      /* limit nBitsLeft */
549
3.23k
      nBitsLeft = (INT)FDKgetValidBits(hBs);
550
      /* set frame error */
551
3.23k
      frameOk = 0;
552
3.23k
    }
553
554
62.1k
    while (nBitsLeft > 7) {
555
34.1k
      int extension_id = FDKreadBits(hBs, 2);
556
34.1k
      nBitsLeft -= 2;
557
558
34.1k
      switch (extension_id) {
559
15.1k
        case EXTENSION_ID_PS_CODING:
560
561
          /* Read PS data from bitstream */
562
563
15.1k
          if (hParametricStereoDec != NULL) {
564
11.0k
            if (bPsRead &&
565
2.75k
                !hParametricStereoDec->bsData[hParametricStereoDec->bsReadSlot]
566
2.75k
                     .mpeg.bPsHeaderValid) {
567
359
              cnt = nBitsLeft >> 3; /* number of remaining bytes */
568
2.43k
              for (i = 0; i < cnt; i++) FDKreadBits(hBs, 8);
569
359
              nBitsLeft -= cnt * 8;
570
10.6k
            } else {
571
10.6k
              nBitsLeft -=
572
10.6k
                  (INT)ReadPsData(hParametricStereoDec, hBs, nBitsLeft);
573
10.6k
              bPsRead = 1;
574
10.6k
            }
575
11.0k
          }
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
15.1k
          break;
591
592
19.0k
        default:
593
19.0k
          cnt = nBitsLeft >> 3; /* number of remaining bytes */
594
257k
          for (i = 0; i < cnt; i++) FDKreadBits(hBs, 8);
595
19.0k
          nBitsLeft -= cnt * 8;
596
19.0k
          break;
597
34.1k
      }
598
34.1k
    }
599
600
27.9k
    if (nBitsLeft < 0) {
601
3.74k
      frameOk = 0;
602
3.74k
      goto bail;
603
24.2k
    } else {
604
      /* Read fill bits for byte alignment */
605
24.2k
      FDKreadBits(hBs, nBitsLeft);
606
24.2k
    }
607
27.9k
  }
608
609
70.4k
bail:
610
70.4k
  return (frameOk);
611
70.4k
}
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
313k
                         const int overlap) {
624
313k
  int i, bs_coupling = COUPLING_OFF;
625
313k
  const int nCh = (hFrameDataRight == NULL) ? 1 : 2;
626
627
313k
  if (!(flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50))) {
628
    /* Reserved bits */
629
78.5k
    if (FDKreadBits(hBs, 1)) { /* bs_data_extra */
630
23.9k
      FDKreadBits(hBs, 4);
631
23.9k
      if ((flags & SBRDEC_SYNTAX_SCAL) || (nCh == 2)) {
632
20.7k
        FDKreadBits(hBs, 4);
633
20.7k
      }
634
23.9k
    }
635
78.5k
  }
636
637
313k
  if (nCh == 2) {
638
    /* Read coupling flag */
639
110k
    bs_coupling = FDKreadBits(hBs, 1);
640
110k
    if (bs_coupling) {
641
31.3k
      hFrameDataLeft->coupling = COUPLING_LEVEL;
642
31.3k
      hFrameDataRight->coupling = COUPLING_BAL;
643
79.0k
    } else {
644
79.0k
      hFrameDataLeft->coupling = COUPLING_OFF;
645
79.0k
      hFrameDataRight->coupling = COUPLING_OFF;
646
79.0k
    }
647
203k
  } else {
648
203k
    if (flags & SBRDEC_SYNTAX_SCAL) {
649
23.9k
      FDKreadBits(hBs, 1); /* bs_coupling */
650
23.9k
    }
651
203k
    hFrameDataLeft->coupling = COUPLING_OFF;
652
203k
  }
653
654
313k
  if (flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50)) {
655
234k
    if (flags & SBRDEC_USAC_HARMONICSBR) {
656
58.0k
      hFrameDataLeft->sbrPatchingMode = FDKreadBit(hBs);
657
58.0k
      if (hFrameDataLeft->sbrPatchingMode == 0) {
658
35.9k
        hFrameDataLeft->sbrOversamplingFlag = FDKreadBit(hBs);
659
35.9k
        if (FDKreadBit(hBs)) { /* sbrPitchInBinsFlag */
660
4.93k
          hFrameDataLeft->sbrPitchInBins = FDKreadBits(hBs, 7);
661
31.0k
        } else {
662
31.0k
          hFrameDataLeft->sbrPitchInBins = 0;
663
31.0k
        }
664
35.9k
      } else {
665
22.1k
        hFrameDataLeft->sbrOversamplingFlag = 0;
666
22.1k
        hFrameDataLeft->sbrPitchInBins = 0;
667
22.1k
      }
668
669
58.0k
      if (nCh == 2) {
670
36.4k
        if (bs_coupling) {
671
17.9k
          hFrameDataRight->sbrPatchingMode = hFrameDataLeft->sbrPatchingMode;
672
17.9k
          hFrameDataRight->sbrOversamplingFlag =
673
17.9k
              hFrameDataLeft->sbrOversamplingFlag;
674
17.9k
          hFrameDataRight->sbrPitchInBins = hFrameDataLeft->sbrPitchInBins;
675
18.4k
        } else {
676
18.4k
          hFrameDataRight->sbrPatchingMode = FDKreadBit(hBs);
677
18.4k
          if (hFrameDataRight->sbrPatchingMode == 0) {
678
11.4k
            hFrameDataRight->sbrOversamplingFlag = FDKreadBit(hBs);
679
11.4k
            if (FDKreadBit(hBs)) { /* sbrPitchInBinsFlag */
680
2.46k
              hFrameDataRight->sbrPitchInBins = FDKreadBits(hBs, 7);
681
8.98k
            } else {
682
8.98k
              hFrameDataRight->sbrPitchInBins = 0;
683
8.98k
            }
684
11.4k
          } else {
685
7.02k
            hFrameDataRight->sbrOversamplingFlag = 0;
686
7.02k
            hFrameDataRight->sbrPitchInBins = 0;
687
7.02k
          }
688
18.4k
        }
689
36.4k
      }
690
176k
    } else {
691
176k
      if (nCh == 2) {
692
42.0k
        hFrameDataRight->sbrPatchingMode = 1;
693
42.0k
        hFrameDataRight->sbrOversamplingFlag = 0;
694
42.0k
        hFrameDataRight->sbrPitchInBins = 0;
695
42.0k
      }
696
697
176k
      hFrameDataLeft->sbrPatchingMode = 1;
698
176k
      hFrameDataLeft->sbrOversamplingFlag = 0;
699
176k
      hFrameDataLeft->sbrPitchInBins = 0;
700
176k
    }
701
234k
  } else {
702
78.5k
    if (nCh == 2) {
703
31.9k
      hFrameDataRight->sbrPatchingMode = 1;
704
31.9k
      hFrameDataRight->sbrOversamplingFlag = 0;
705
31.9k
      hFrameDataRight->sbrPitchInBins = 0;
706
31.9k
    }
707
708
78.5k
    hFrameDataLeft->sbrPatchingMode = 1;
709
78.5k
    hFrameDataLeft->sbrOversamplingFlag = 0;
710
78.5k
    hFrameDataLeft->sbrPitchInBins = 0;
711
78.5k
  }
712
713
  /*
714
    sbr_grid(): Grid control
715
  */
716
313k
  if (hHeaderData->bs_info.pvc_mode) {
717
128k
    FDK_ASSERT(nCh == 1); /* PVC not possible for CPE */
718
128k
    if (!extractPvcFrameInfo(hBs, hHeaderData, hFrameDataLeft,
719
128k
                             hFrameDataLeftPrev, pvc_mode_last, flags))
720
898
      return 0;
721
722
127k
    if (!checkFrameInfo(&hFrameDataLeft->frameInfo,
723
127k
                        hHeaderData->numberTimeSlots, overlap,
724
127k
                        hHeaderData->timeStep))
725
413
      return 0;
726
185k
  } else {
727
185k
    if (!extractFrameInfo(hBs, hHeaderData, hFrameDataLeft, 1, flags)) return 0;
728
729
179k
    if (!checkFrameInfo(&hFrameDataLeft->frameInfo,
730
179k
                        hHeaderData->numberTimeSlots, overlap,
731
179k
                        hHeaderData->timeStep))
732
3.27k
      return 0;
733
179k
  }
734
303k
  if (nCh == 2) {
735
107k
    if (hFrameDataLeft->coupling) {
736
30.0k
      FDKmemcpy(&hFrameDataRight->frameInfo, &hFrameDataLeft->frameInfo,
737
30.0k
                sizeof(FRAME_INFO));
738
30.0k
      hFrameDataRight->ampResolutionCurrentFrame =
739
30.0k
          hFrameDataLeft->ampResolutionCurrentFrame;
740
77.0k
    } else {
741
77.0k
      if (!extractFrameInfo(hBs, hHeaderData, hFrameDataRight, 2, flags))
742
1.62k
        return 0;
743
744
75.4k
      if (!checkFrameInfo(&hFrameDataRight->frameInfo,
745
75.4k
                          hHeaderData->numberTimeSlots, overlap,
746
75.4k
                          hHeaderData->timeStep))
747
938
        return 0;
748
75.4k
    }
749
107k
  }
750
751
  /*
752
    sbr_dtdf(): Fetch domain vectors (time or frequency direction for
753
    delta-coding)
754
  */
755
301k
  sbrGetDirectionControlData(hFrameDataLeft, hBs, flags,
756
301k
                             hHeaderData->bs_info.pvc_mode);
757
301k
  if (nCh == 2) {
758
104k
    sbrGetDirectionControlData(hFrameDataRight, hBs, flags, 0);
759
104k
  }
760
761
  /* sbr_invf() */
762
1.00M
  for (i = 0; i < hHeaderData->freqBandData.nInvfBands; i++) {
763
706k
    hFrameDataLeft->sbr_invf_mode[i] = (INVF_MODE)FDKreadBits(hBs, 2);
764
706k
  }
765
301k
  if (nCh == 2) {
766
104k
    if (hFrameDataLeft->coupling) {
767
100k
      for (i = 0; i < hHeaderData->freqBandData.nInvfBands; i++) {
768
70.2k
        hFrameDataRight->sbr_invf_mode[i] = hFrameDataLeft->sbr_invf_mode[i];
769
70.2k
      }
770
74.4k
    } else {
771
283k
      for (i = 0; i < hHeaderData->freqBandData.nInvfBands; i++) {
772
208k
        hFrameDataRight->sbr_invf_mode[i] = (INVF_MODE)FDKreadBits(hBs, 2);
773
208k
      }
774
74.4k
    }
775
104k
  }
776
777
301k
  if (nCh == 1) {
778
196k
    if (hHeaderData->bs_info.pvc_mode) {
779
127k
      if (!sbrGetPvcEnvelope(hHeaderData, hFrameDataLeft, hBs, flags,
780
127k
                             hHeaderData->bs_info.pvc_mode))
781
520
        return 0;
782
127k
    } else if (!sbrGetEnvelope(hHeaderData, hFrameDataLeft, hBs, flags))
783
0
      return 0;
784
785
196k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataLeft, hBs);
786
196k
  } else if (hFrameDataLeft->coupling) {
787
30.0k
    if (!sbrGetEnvelope(hHeaderData, hFrameDataLeft, hBs, flags)) {
788
0
      return 0;
789
0
    }
790
791
30.0k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataLeft, hBs);
792
793
30.0k
    if (!sbrGetEnvelope(hHeaderData, hFrameDataRight, hBs, flags)) {
794
0
      return 0;
795
0
    }
796
30.0k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataRight, hBs);
797
74.4k
  } else { /* nCh == 2 && no coupling */
798
799
74.4k
    if (!sbrGetEnvelope(hHeaderData, hFrameDataLeft, hBs, flags)) return 0;
800
801
74.4k
    if (!sbrGetEnvelope(hHeaderData, hFrameDataRight, hBs, flags)) return 0;
802
803
74.4k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataLeft, hBs);
804
805
74.4k
    sbrGetNoiseFloorData(hHeaderData, hFrameDataRight, hBs);
806
74.4k
  }
807
808
300k
  sbrGetSyntheticCodedData(hHeaderData, hFrameDataLeft, hBs, flags);
809
300k
  if (nCh == 2) {
810
104k
    sbrGetSyntheticCodedData(hHeaderData, hFrameDataRight, hBs, flags);
811
104k
  }
812
813
300k
  if (!(flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50))) {
814
70.4k
    if (!extractExtendedData(hHeaderData, hBs, hParametricStereoDec)) {
815
5.93k
      return 0;
816
5.93k
    }
817
70.4k
  }
818
819
294k
  return 1;
820
300k
}
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
405k
{
831
405k
  int i;
832
405k
  int indepFlag = 0;
833
834
405k
  if (flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50)) {
835
307k
    indepFlag = flags & SBRDEC_USAC_INDEP;
836
307k
  }
837
838
405k
  if (bs_pvc_mode == 0) {
839
278k
    i = 0;
840
278k
    if (indepFlag) {
841
143k
      h_frame_data->domain_vec[i++] = 0;
842
143k
    }
843
651k
    for (; i < h_frame_data->frameInfo.nEnvelopes; i++) {
844
373k
      h_frame_data->domain_vec[i] = FDKreadBits(hBs, 1);
845
373k
    }
846
278k
  }
847
848
405k
  i = 0;
849
405k
  if (indepFlag) {
850
243k
    h_frame_data->domain_vec_noise[i++] = 0;
851
243k
  }
852
798k
  for (; i < h_frame_data->frameInfo.nNoiseEnvelopes; i++) {
853
393k
    h_frame_data->domain_vec_noise[i] = FDKreadBits(hBs, 1);
854
393k
  }
855
405k
}
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
405k
{
865
405k
  int i, j;
866
405k
  int delta;
867
405k
  COUPLING_MODE coupling;
868
405k
  int noNoiseBands = hHeaderData->freqBandData.nNfb;
869
870
405k
  Huffman hcb_noiseF;
871
405k
  Huffman hcb_noise;
872
405k
  int envDataTableCompFactor;
873
874
405k
  coupling = h_frame_data->coupling;
875
876
  /*
877
    Select huffman codebook depending on coupling mode
878
  */
879
405k
  if (coupling == COUPLING_BAL) {
880
30.0k
    hcb_noise = (Huffman)&FDK_sbrDecoder_sbr_huffBook_NoiseBalance11T;
881
30.0k
    hcb_noiseF =
882
30.0k
        (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance11F; /* "sbr_huffBook_NoiseBalance11F"
883
                                                              */
884
30.0k
    envDataTableCompFactor = 1;
885
375k
  } else {
886
375k
    hcb_noise = (Huffman)&FDK_sbrDecoder_sbr_huffBook_NoiseLevel11T;
887
375k
    hcb_noiseF =
888
375k
        (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel11F; /* "sbr_huffBook_NoiseLevel11F"
889
                                                            */
890
375k
    envDataTableCompFactor = 0;
891
375k
  }
892
893
  /*
894
    Read raw noise-envelope data
895
  */
896
1.04M
  for (i = 0; i < h_frame_data->frameInfo.nNoiseEnvelopes; i++) {
897
636k
    if (h_frame_data->domain_vec_noise[i] == 0) {
898
468k
      if (coupling == COUPLING_BAL) {
899
40.0k
        h_frame_data->sbrNoiseFloorLevel[i * noNoiseBands] =
900
40.0k
            (FIXP_SGL)(((int)FDKreadBits(hBs, 5)) << envDataTableCompFactor);
901
427k
      } else {
902
427k
        h_frame_data->sbrNoiseFloorLevel[i * noNoiseBands] =
903
427k
            (FIXP_SGL)(int)FDKreadBits(hBs, 5);
904
427k
      }
905
906
1.18M
      for (j = 1; j < noNoiseBands; j++) {
907
719k
        delta = DecodeHuffmanCW(hcb_noiseF, hBs);
908
719k
        h_frame_data->sbrNoiseFloorLevel[i * noNoiseBands + j] =
909
719k
            (FIXP_SGL)(delta << envDataTableCompFactor);
910
719k
      }
911
468k
    } else {
912
508k
      for (j = 0; j < noNoiseBands; j++) {
913
340k
        delta = DecodeHuffmanCW(hcb_noise, hBs);
914
340k
        h_frame_data->sbrNoiseFloorLevel[i * noNoiseBands + j] =
915
340k
            (FIXP_SGL)(delta << envDataTableCompFactor);
916
340k
      }
917
168k
    }
918
636k
  }
919
405k
}
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
127k
    const UINT flags, const UINT pvcMode) {
932
127k
  int divMode, nsMode;
933
127k
  int indepFlag = flags & SBRDEC_USAC_INDEP;
934
127k
  UCHAR *pvcID = h_frame_data->pvcID;
935
936
127k
  divMode = FDKreadBits(hBs, PVC_DIVMODE_BITS);
937
127k
  nsMode = FDKreadBit(hBs);
938
127k
  FDK_ASSERT((pvcMode == 1) || (pvcMode == 2));
939
127k
  h_frame_data->ns = mapNsMode2ns[pvcMode - 1][nsMode];
940
941
127k
  if (divMode <= 3) {
942
23.7k
    int i, k = 1, sum_length = 0, reuse_pcvID;
943
944
    /* special treatment for first time slot k=0 */
945
23.7k
    indepFlag ? (reuse_pcvID = 0) : (reuse_pcvID = FDKreadBit(hBs));
946
23.7k
    if (reuse_pcvID) {
947
6.48k
      pvcID[0] = hHeaderData->pvcIDprev;
948
17.2k
    } else {
949
17.2k
      pvcID[0] = FDKreadBits(hBs, PVC_PVCID_BITS);
950
17.2k
    }
951
952
    /* other time slots k>0 */
953
44.8k
    for (i = 0; i < divMode; i++) {
954
21.6k
      int length, numBits = 4;
955
956
21.6k
      if (sum_length >= 13) {
957
1.01k
        numBits = 1;
958
20.5k
      } else if (sum_length >= 11) {
959
248
        numBits = 2;
960
20.3k
      } else if (sum_length >= 7) {
961
1.76k
        numBits = 3;
962
1.76k
      }
963
964
21.6k
      length = FDKreadBits(hBs, numBits);
965
21.6k
      sum_length += length + 1;
966
21.6k
      if (sum_length >= PVC_NTIMESLOT) {
967
520
        return 0; /* parse error */
968
520
      }
969
87.6k
      for (; length--; k++) {
970
66.5k
        pvcID[k] = pvcID[k - 1];
971
66.5k
      }
972
21.0k
      pvcID[k++] = FDKreadBits(hBs, PVC_PVCID_BITS);
973
21.0k
    }
974
287k
    for (; k < 16; k++) {
975
264k
      pvcID[k] = pvcID[k - 1];
976
264k
    }
977
103k
  } else { /* divMode >= 4 */
978
103k
    int num_grid_info, fixed_length, grid_info, j, k = 0;
979
980
103k
    divMode -= 4;
981
103k
    num_grid_info = 2 << divMode;
982
103k
    fixed_length = 8 >> divMode;
983
103k
    FDK_ASSERT(num_grid_info * fixed_length == PVC_NTIMESLOT);
984
985
    /* special treatment for first time slot k=0 */
986
103k
    indepFlag ? (grid_info = 1) : (grid_info = FDKreadBit(hBs));
987
103k
    if (grid_info) {
988
98.4k
      pvcID[k++] = FDKreadBits(hBs, PVC_PVCID_BITS);
989
98.4k
    } else {
990
4.87k
      pvcID[k++] = hHeaderData->pvcIDprev;
991
4.87k
    }
992
103k
    j = fixed_length - 1;
993
800k
    for (; j--; k++) {
994
697k
      pvcID[k] = pvcID[k - 1];
995
697k
    }
996
103k
    num_grid_info--;
997
998
    /* other time slots k>0 */
999
249k
    for (; num_grid_info--;) {
1000
145k
      j = fixed_length;
1001
145k
      grid_info = FDKreadBit(hBs);
1002
145k
      if (grid_info) {
1003
15.3k
        pvcID[k++] = FDKreadBits(hBs, PVC_PVCID_BITS);
1004
15.3k
        j--;
1005
15.3k
      }
1006
982k
      for (; j--; k++) {
1007
836k
        pvcID[k] = pvcID[k - 1];
1008
836k
      }
1009
145k
    }
1010
103k
  }
1011
1012
126k
  hHeaderData->pvcIDprev = pvcID[PVC_NTIMESLOT - 1];
1013
1014
  /* usage of PVC excludes inter-TES tool */
1015
126k
  h_frame_data->iTESactive = (UCHAR)0;
1016
1017
126k
  return 1;
1018
127k
}
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
278k
    const UINT flags) {
1027
278k
  int i, j;
1028
278k
  UCHAR no_band[MAX_ENVELOPES];
1029
278k
  int delta = 0;
1030
278k
  int offset = 0;
1031
278k
  COUPLING_MODE coupling = h_frame_data->coupling;
1032
278k
  int ampRes = hHeaderData->bs_info.ampResolution;
1033
278k
  int nEnvelopes = h_frame_data->frameInfo.nEnvelopes;
1034
278k
  int envDataTableCompFactor;
1035
278k
  int start_bits, start_bits_balance;
1036
278k
  Huffman hcb_t, hcb_f;
1037
1038
278k
  h_frame_data->nScaleFactors = 0;
1039
1040
278k
  if ((h_frame_data->frameInfo.frameClass == 0) && (nEnvelopes == 1)) {
1041
85.3k
    if (flags & SBRDEC_ELD_GRID)
1042
27.6k
      ampRes = h_frame_data->ampResolutionCurrentFrame;
1043
57.6k
    else
1044
57.6k
      ampRes = 0;
1045
85.3k
  }
1046
278k
  h_frame_data->ampResolutionCurrentFrame = ampRes;
1047
1048
  /*
1049
    Set number of bits for first value depending on amplitude resolution
1050
  */
1051
278k
  if (ampRes == 1) {
1052
75.3k
    start_bits = 6;
1053
75.3k
    start_bits_balance = 5;
1054
203k
  } else {
1055
203k
    start_bits = 7;
1056
203k
    start_bits_balance = 6;
1057
203k
  }
1058
1059
  /*
1060
    Calculate number of values for each envelope and alltogether
1061
  */
1062
794k
  for (i = 0; i < nEnvelopes; i++) {
1063
516k
    no_band[i] =
1064
516k
        hHeaderData->freqBandData.nSfb[h_frame_data->frameInfo.freqRes[i]];
1065
516k
    h_frame_data->nScaleFactors += no_band[i];
1066
516k
  }
1067
278k
  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
278k
  if (coupling == COUPLING_BAL) {
1073
30.0k
    envDataTableCompFactor = 1;
1074
30.0k
    if (ampRes == 0) {
1075
24.7k
      hcb_t = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance10T;
1076
24.7k
      hcb_f = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance10F;
1077
24.7k
    } else {
1078
5.25k
      hcb_t = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance11T;
1079
5.25k
      hcb_f = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvBalance11F;
1080
5.25k
    }
1081
248k
  } else {
1082
248k
    envDataTableCompFactor = 0;
1083
248k
    if (ampRes == 0) {
1084
178k
      hcb_t = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel10T;
1085
178k
      hcb_f = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel10F;
1086
178k
    } else {
1087
70.0k
      hcb_t = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel11T;
1088
70.0k
      hcb_f = (Huffman)&FDK_sbrDecoder_sbr_huffBook_EnvLevel11F;
1089
70.0k
    }
1090
248k
  }
1091
1092
278k
  h_frame_data->iTESactive = (UCHAR)0; /* disable inter-TES by default */
1093
  /*
1094
    Now read raw envelope data
1095
  */
1096
794k
  for (j = 0, offset = 0; j < nEnvelopes; j++) {
1097
516k
    if (h_frame_data->domain_vec[j] == 0) {
1098
371k
      if (coupling == COUPLING_BAL) {
1099
54.6k
        h_frame_data->iEnvelope[offset] =
1100
54.6k
            (FIXP_SGL)(((int)FDKreadBits(hBs, start_bits_balance))
1101
54.6k
                       << envDataTableCompFactor);
1102
316k
      } else {
1103
316k
        h_frame_data->iEnvelope[offset] =
1104
316k
            (FIXP_SGL)(int)FDKreadBits(hBs, start_bits);
1105
316k
      }
1106
371k
    }
1107
1108
4.13M
    for (i = (1 - h_frame_data->domain_vec[j]); i < no_band[j]; i++) {
1109
3.62M
      if (h_frame_data->domain_vec[j] == 0) {
1110
2.40M
        delta = DecodeHuffmanCW(hcb_f, hBs);
1111
2.40M
      } else {
1112
1.21M
        delta = DecodeHuffmanCW(hcb_t, hBs);
1113
1.21M
      }
1114
1115
3.62M
      h_frame_data->iEnvelope[offset + i] =
1116
3.62M
          (FIXP_SGL)(delta << envDataTableCompFactor);
1117
3.62M
    }
1118
516k
    if ((flags & SBRDEC_SYNTAX_USAC) && (flags & SBRDEC_USAC_ITES)) {
1119
139k
      int bs_temp_shape = FDKreadBit(hBs);
1120
139k
      FDK_ASSERT(j < 8);
1121
139k
      h_frame_data->iTESactive |= (UCHAR)(bs_temp_shape << j);
1122
139k
      if (bs_temp_shape) {
1123
36.0k
        h_frame_data->interTempShapeMode[j] =
1124
36.0k
            FDKread2Bits(hBs); /* bs_inter_temp_shape_mode */
1125
103k
      } else {
1126
103k
        h_frame_data->interTempShapeMode[j] = 0;
1127
103k
      }
1128
139k
    }
1129
516k
    offset += no_band[j];
1130
516k
  }
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
278k
  return 1;
1141
278k
}
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
7.88k
                              int numberTimeSlots, const UINT flags) {
1152
7.88k
  int nEnv, i, tranIdx;
1153
7.88k
  const int *pTable;
1154
1155
7.88k
  if (tranPosInternal >= numberTimeSlots) {
1156
0
    return 0;
1157
0
  }
1158
1159
7.88k
  switch (numberTimeSlots) {
1160
0
    case 8:
1161
0
      pTable = FDK_sbrDecoder_envelopeTable_8[tranPosInternal];
1162
0
      break;
1163
5.57k
    case 15:
1164
5.57k
      pTable = FDK_sbrDecoder_envelopeTable_15[tranPosInternal];
1165
5.57k
      break;
1166
2.30k
    case 16:
1167
2.30k
      pTable = FDK_sbrDecoder_envelopeTable_16[tranPosInternal];
1168
2.30k
      break;
1169
0
    default:
1170
0
      return 0;
1171
7.88k
  }
1172
1173
  /* look number of envelopes in table */
1174
7.88k
  nEnv = pTable[0];
1175
  /* look up envelope distribution in table */
1176
19.9k
  for (i = 1; i < nEnv; i++) hSbrFrameInfo->borders[i] = pTable[i + 2];
1177
  /* open and close frame border */
1178
7.88k
  hSbrFrameInfo->borders[0] = 0;
1179
7.88k
  hSbrFrameInfo->borders[nEnv] = numberTimeSlots;
1180
7.88k
  hSbrFrameInfo->nEnvelopes = nEnv;
1181
1182
  /* transient idx */
1183
7.88k
  tranIdx = hSbrFrameInfo->tranEnv = pTable[1];
1184
1185
  /* add noise floors */
1186
7.88k
  hSbrFrameInfo->bordersNoise[0] = 0;
1187
7.88k
  hSbrFrameInfo->bordersNoise[1] =
1188
7.88k
      hSbrFrameInfo->borders[tranIdx ? tranIdx : 1];
1189
7.88k
  hSbrFrameInfo->bordersNoise[2] = numberTimeSlots;
1190
  /* nEnv is always > 1, so nNoiseEnvelopes is always 2 (IEC 14496-3 4.6.19.3.2)
1191
   */
1192
7.88k
  hSbrFrameInfo->nNoiseEnvelopes = 2;
1193
1194
7.88k
  return 1;
1195
7.88k
}
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
9.52k
    int timeSlots, const UINT flags) {
1208
9.52k
  FRAME_INFO *pFrameInfo = &h_frame_data->frameInfo;
1209
9.52k
  INT numberTimeSlots = hHeaderData->numberTimeSlots;
1210
9.52k
  INT temp = 0, k;
1211
1212
  /* FIXFIXonly framing case */
1213
9.52k
  h_frame_data->frameInfo.frameClass = 0;
1214
1215
  /* get the transient position from the bitstream */
1216
9.52k
  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.30k
    case 16:
1223
9.52k
    case 15:
1224
      /* 4bit transient position (temp={0;..;15}) */
1225
9.52k
      temp = FDKreadBits(hBitBuf, 4);
1226
9.52k
      break;
1227
1228
0
    default:
1229
0
      return 0;
1230
9.52k
  }
1231
1232
  /* For "case 15" only*/
1233
9.52k
  if (temp >= timeSlots) {
1234
1.63k
    return 0;
1235
1.63k
  }
1236
1237
  /* calculate borders according to the transient position */
1238
7.88k
  if (!generateFixFixOnly(pFrameInfo, temp, numberTimeSlots, flags)) {
1239
0
    return 0;
1240
0
  }
1241
1242
  /* decode freq res: */
1243
27.8k
  for (k = 0; k < pFrameInfo->nEnvelopes; k++) {
1244
19.9k
    pFrameInfo->freqRes[k] =
1245
19.9k
        (UCHAR)FDKreadBits(hBitBuf, 1); /* f = F [1 bits] */
1246
19.9k
  }
1247
1248
7.88k
  return 1;
1249
7.88k
}
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
128k
    const UINT flags) {
1265
128k
  FRAME_INFO *pFrameInfo = &h_frame_data->frameInfo;
1266
128k
  FRAME_INFO *pPrevFrameInfo = &h_prev_frame_data->prevFrameInfo;
1267
128k
  int bs_var_len_hf, bs_noise_position;
1268
128k
  bs_noise_position = FDKreadBits(hBs, 4); /* SBR_PVC_NOISEPOSITION_BITS 4 */
1269
128k
  bs_var_len_hf = FDKreadBit(hBs);
1270
128k
  pFrameInfo->noisePosition = bs_noise_position;
1271
128k
  pFrameInfo->tranEnv = -1;
1272
1273
  /* Init for bs_noise_position == 0 in case a parse error is found below. */
1274
128k
  pFrameInfo->nEnvelopes = 1;
1275
128k
  pFrameInfo->nNoiseEnvelopes = 1;
1276
128k
  pFrameInfo->freqRes[0] = 0;
1277
1278
128k
  if (bs_var_len_hf) { /* 1 or 3 Bits */
1279
104k
    pFrameInfo->varLength = FDKreadBits(hBs, 2) + 1;
1280
104k
    if (pFrameInfo->varLength > 3) {
1281
898
      pFrameInfo->varLength =
1282
898
          0;    /* assume bs_var_len_hf == 0 in case of error */
1283
898
      return 0; /* reserved value -> parse error */
1284
898
    }
1285
104k
  } else {
1286
23.8k
    pFrameInfo->varLength = 0;
1287
23.8k
  }
1288
1289
127k
  if (bs_noise_position) {
1290
106k
    pFrameInfo->nEnvelopes = 2;
1291
106k
    pFrameInfo->nNoiseEnvelopes = 2;
1292
106k
    FDKmemclear(pFrameInfo->freqRes, sizeof(pFrameInfo->freqRes));
1293
106k
  }
1294
1295
  /* frame border calculation */
1296
127k
  if (hHeaderData->bs_info.pvc_mode > 0) {
1297
    /* See "7.5.1.4 HF adjustment of SBR envelope scalefactors" for reference.
1298
     */
1299
1300
127k
    FDK_ASSERT((pFrameInfo->nEnvelopes == 1) || (pFrameInfo->nEnvelopes == 2));
1301
1302
    /* left timeborder-offset: use the timeborder of prev SBR frame */
1303
127k
    if (pPrevFrameInfo->nEnvelopes > 0) {
1304
121k
      pFrameInfo->borders[0] =
1305
121k
          pPrevFrameInfo->borders[pPrevFrameInfo->nEnvelopes] - PVC_NTIMESLOT;
1306
121k
      FDK_ASSERT(pFrameInfo->borders[0] <= 3);
1307
121k
    } else {
1308
5.50k
      pFrameInfo->borders[0] = 0;
1309
5.50k
    }
1310
1311
    /* right timeborder-offset: */
1312
127k
    pFrameInfo->borders[pFrameInfo->nEnvelopes] = 16 + pFrameInfo->varLength;
1313
1314
127k
    if (pFrameInfo->nEnvelopes == 2) {
1315
106k
      pFrameInfo->borders[1] = pFrameInfo->noisePosition;
1316
106k
    }
1317
1318
    /* Calculation of PVC time borders t_EPVC */
1319
127k
    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
11.3k
      pFrameInfo->pvcBorders[0] = pFrameInfo->borders[0];
1323
116k
    } else {
1324
116k
      pFrameInfo->pvcBorders[0] = 0;
1325
116k
    }
1326
127k
    if (pFrameInfo->nEnvelopes == 2) {
1327
106k
      pFrameInfo->pvcBorders[1] = pFrameInfo->borders[1];
1328
106k
    }
1329
127k
    pFrameInfo->pvcBorders[pFrameInfo->nEnvelopes] = 16;
1330
1331
    /* calculation of SBR noise-floor time-border vector: */
1332
489k
    for (INT i = 0; i <= pFrameInfo->nNoiseEnvelopes; i++) {
1333
361k
      pFrameInfo->bordersNoise[i] = pFrameInfo->borders[i];
1334
361k
    }
1335
1336
127k
    pFrameInfo->tranEnv = -1; /* tranEnv not used */
1337
127k
  }
1338
127k
  return 1;
1339
127k
}
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
262k
    const UINT nrOfChannels, const UINT flags) {
1351
262k
  FRAME_INFO *pFrameInfo = &h_frame_data->frameInfo;
1352
262k
  int numberTimeSlots = hHeaderData->numberTimeSlots;
1353
262k
  int pointer_bits = 0, nEnv = 0, b = 0, border, i, n = 0, k, p, aL, aR, nL, nR,
1354
262k
      temp = 0, staticFreqRes;
1355
262k
  UCHAR frameClass;
1356
1357
262k
  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
47.7k
    frameClass = FDKreadBits(hBs, 1); /* frameClass = [1 bit] */
1361
47.7k
    if (frameClass == 1) {
1362
      /* if frameClass == 1, extract LowDelaySbrGrid, otherwise extract normal
1363
       * SBR-Grid for FIXIFX */
1364
      /* extract the AACLD-Sbr-Grid */
1365
9.52k
      pFrameInfo->frameClass = frameClass;
1366
9.52k
      int err = 1;
1367
9.52k
      err = extractLowDelayGrid(hBs, hHeaderData, h_frame_data, numberTimeSlots,
1368
9.52k
                                flags);
1369
9.52k
      return err;
1370
9.52k
    }
1371
214k
  } else {
1372
214k
    frameClass = FDKreadBits(hBs, 2); /* frameClass = C [2 bits] */
1373
214k
  }
1374
1375
252k
  switch (frameClass) {
1376
132k
    case 0:
1377
132k
      temp = FDKreadBits(hBs, 2); /* E [2 bits ] */
1378
132k
      nEnv = (int)(1 << temp);    /* E -> e */
1379
1380
132k
      if ((flags & SBRDEC_ELD_GRID) && (nEnv == 1))
1381
27.3k
        h_frame_data->ampResolutionCurrentFrame =
1382
27.3k
            FDKreadBits(hBs, 1); /* new ELD Syntax 07-11-09 */
1383
1384
132k
      staticFreqRes = FDKreadBits(hBs, 1);
1385
1386
132k
      if (flags & (SBRDEC_SYNTAX_USAC | SBRDEC_SYNTAX_RSVD50)) {
1387
79.8k
        if (nEnv > MAX_ENVELOPES_USAC) return 0;
1388
79.8k
      } else
1389
1390
52.3k
        b = nEnv + 1;
1391
132k
      switch (nEnv) {
1392
78.2k
        case 1:
1393
78.2k
          switch (numberTimeSlots) {
1394
25.2k
            case 15:
1395
25.2k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info1_15,
1396
25.2k
                        sizeof(FRAME_INFO));
1397
25.2k
              break;
1398
53.0k
            case 16:
1399
53.0k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info1_16,
1400
53.0k
                        sizeof(FRAME_INFO));
1401
53.0k
              break;
1402
0
            default:
1403
0
              FDK_ASSERT(0);
1404
78.2k
          }
1405
78.2k
          break;
1406
78.2k
        case 2:
1407
37.7k
          switch (numberTimeSlots) {
1408
5.94k
            case 15:
1409
5.94k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info2_15,
1410
5.94k
                        sizeof(FRAME_INFO));
1411
5.94k
              break;
1412
31.7k
            case 16:
1413
31.7k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info2_16,
1414
31.7k
                        sizeof(FRAME_INFO));
1415
31.7k
              break;
1416
0
            default:
1417
0
              FDK_ASSERT(0);
1418
37.7k
          }
1419
37.7k
          break;
1420
37.7k
        case 4:
1421
8.30k
          switch (numberTimeSlots) {
1422
4.80k
            case 15:
1423
4.80k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info4_15,
1424
4.80k
                        sizeof(FRAME_INFO));
1425
4.80k
              break;
1426
3.49k
            case 16:
1427
3.49k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info4_16,
1428
3.49k
                        sizeof(FRAME_INFO));
1429
3.49k
              break;
1430
0
            default:
1431
0
              FDK_ASSERT(0);
1432
8.30k
          }
1433
8.30k
          break;
1434
8.30k
        case 8:
1435
7.90k
#if (MAX_ENVELOPES >= 8)
1436
7.90k
          switch (numberTimeSlots) {
1437
2.00k
            case 15:
1438
2.00k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info8_15,
1439
2.00k
                        sizeof(FRAME_INFO));
1440
2.00k
              break;
1441
5.90k
            case 16:
1442
5.90k
              FDKmemcpy(pFrameInfo, &FDK_sbrDecoder_sbr_frame_info8_16,
1443
5.90k
                        sizeof(FRAME_INFO));
1444
5.90k
              break;
1445
0
            default:
1446
0
              FDK_ASSERT(0);
1447
7.90k
          }
1448
7.90k
          break;
1449
#else
1450
          return 0;
1451
#endif
1452
132k
      }
1453
      /* Apply correct freqRes (High is default) */
1454
132k
      if (!staticFreqRes) {
1455
196k
        for (i = 0; i < nEnv; i++) pFrameInfo->freqRes[i] = 0;
1456
80.8k
      }
1457
1458
132k
      break;
1459
48.9k
    case 1:
1460
104k
    case 2:
1461
104k
      temp = FDKreadBits(hBs, 2); /* A [2 bits] */
1462
1463
104k
      n = FDKreadBits(hBs, 2); /* n = N [2 bits] */
1464
1465
104k
      nEnv = n + 1; /* # envelopes */
1466
104k
      b = nEnv + 1; /* # borders   */
1467
1468
104k
      break;
1469
252k
  }
1470
1471
252k
  switch (frameClass) {
1472
48.9k
    case 1:
1473
      /* Decode borders: */
1474
48.9k
      pFrameInfo->borders[0] = 0;      /* first border          */
1475
48.9k
      border = temp + numberTimeSlots; /* A -> aR               */
1476
48.9k
      i = b - 1;                       /* frame info index for last border */
1477
48.9k
      pFrameInfo->borders[i] = border; /* last border                      */
1478
1479
91.0k
      for (k = 0; k < n; k++) {
1480
42.1k
        temp = FDKreadBits(hBs, 2); /* R [2 bits] */
1481
42.1k
        border -= (2 * temp + 2);   /* R -> r                */
1482
42.1k
        pFrameInfo->borders[--i] = border;
1483
42.1k
      }
1484
1485
      /* Decode pointer: */
1486
48.9k
      pointer_bits = DFRACT_BITS - 1 - CountLeadingBits((FIXP_DBL)(n + 1));
1487
48.9k
      p = FDKreadBits(hBs, pointer_bits); /* p = P [pointer_bits bits] */
1488
1489
48.9k
      if (p > n + 1) return 0;
1490
1491
46.9k
      pFrameInfo->tranEnv = p ? n + 2 - p : -1;
1492
1493
      /* Decode freq res: */
1494
131k
      for (k = n; k >= 0; k--) {
1495
84.7k
        pFrameInfo->freqRes[k] = FDKreadBits(hBs, 1); /* f = F [1 bits] */
1496
84.7k
      }
1497
1498
      /* Calculate noise floor middle border: */
1499
46.9k
      if (p == 0 || p == 1)
1500
45.2k
        pFrameInfo->bordersNoise[1] = pFrameInfo->borders[n];
1501
1.72k
      else
1502
1.72k
        pFrameInfo->bordersNoise[1] = pFrameInfo->borders[pFrameInfo->tranEnv];
1503
1504
46.9k
      break;
1505
1506
55.8k
    case 2:
1507
      /* Decode borders: */
1508
55.8k
      border = temp;                   /* A -> aL */
1509
55.8k
      pFrameInfo->borders[0] = border; /* first border */
1510
1511
80.1k
      for (k = 1; k <= n; k++) {
1512
24.2k
        temp = FDKreadBits(hBs, 2); /* R [2 bits] */
1513
24.2k
        border += (2 * temp + 2);   /* R -> r                */
1514
24.2k
        pFrameInfo->borders[k] = border;
1515
24.2k
      }
1516
55.8k
      pFrameInfo->borders[k] = numberTimeSlots; /* last border */
1517
1518
      /* Decode pointer: */
1519
55.8k
      pointer_bits = DFRACT_BITS - 1 - CountLeadingBits((FIXP_DBL)(n + 1));
1520
55.8k
      p = FDKreadBits(hBs, pointer_bits); /* p = P [pointer_bits bits] */
1521
55.8k
      if (p > n + 1) return 0;
1522
1523
54.4k
      if (p == 0 || p == 1)
1524
47.2k
        pFrameInfo->tranEnv = -1;
1525
7.13k
      else
1526
7.13k
        pFrameInfo->tranEnv = p - 1;
1527
1528
      /* Decode freq res: */
1529
129k
      for (k = 0; k <= n; k++) {
1530
75.0k
        pFrameInfo->freqRes[k] = FDKreadBits(hBs, 1); /* f = F [1 bits] */
1531
75.0k
      }
1532
1533
      /* Calculate noise floor middle border: */
1534
54.4k
      switch (p) {
1535
44.3k
        case 0:
1536
44.3k
          pFrameInfo->bordersNoise[1] = pFrameInfo->borders[1];
1537
44.3k
          break;
1538
2.90k
        case 1:
1539
2.90k
          pFrameInfo->bordersNoise[1] = pFrameInfo->borders[n];
1540
2.90k
          break;
1541
7.13k
        default:
1542
7.13k
          pFrameInfo->bordersNoise[1] =
1543
7.13k
              pFrameInfo->borders[pFrameInfo->tranEnv];
1544
7.13k
          break;
1545
54.4k
      }
1546
1547
54.4k
      break;
1548
1549
54.4k
    case 3:
1550
      /* v_ctrlSignal = [frameClass,aL,aR,nL,nR,v_rL,v_rR,p,v_fLR]; */
1551
1552
15.6k
      aL = FDKreadBits(hBs, 2); /* AL [2 bits], AL -> aL */
1553
1554
15.6k
      aR = FDKreadBits(hBs, 2) + numberTimeSlots; /* AR [2 bits], AR -> aR */
1555
1556
15.6k
      nL = FDKreadBits(hBs, 2); /* nL = NL [2 bits] */
1557
1558
15.6k
      nR = FDKreadBits(hBs, 2); /* nR = NR [2 bits] */
1559
1560
      /*-------------------------------------------------------------------------
1561
        Calculate help variables
1562
        --------------------------------------------------------------------------*/
1563
1564
      /* general: */
1565
15.6k
      nEnv = nL + nR + 1; /* # envelopes */
1566
15.6k
      if (nEnv > MAX_ENVELOPES) return 0;
1567
15.6k
      b = nEnv + 1; /* # borders   */
1568
1569
      /*-------------------------------------------------------------------------
1570
        Decode envelopes
1571
        --------------------------------------------------------------------------*/
1572
1573
      /* L-borders:   */
1574
15.6k
      border = aL; /* first border */
1575
15.6k
      pFrameInfo->borders[0] = border;
1576
1577
34.5k
      for (k = 1; k <= nL; k++) {
1578
18.8k
        temp = FDKreadBits(hBs, 2); /* R [2 bits] */
1579
18.8k
        border += (2 * temp + 2);   /* R -> r                */
1580
18.8k
        pFrameInfo->borders[k] = border;
1581
18.8k
      }
1582
1583
      /* R-borders:  */
1584
15.6k
      border = aR; /* last border */
1585
15.6k
      i = nEnv;
1586
1587
15.6k
      pFrameInfo->borders[i] = border;
1588
1589
34.6k
      for (k = 0; k < nR; k++) {
1590
18.9k
        temp = FDKreadBits(hBs, 2); /* R [2 bits] */
1591
18.9k
        border -= (2 * temp + 2);   /* R -> r                */
1592
18.9k
        pFrameInfo->borders[--i] = border;
1593
18.9k
      }
1594
1595
      /* decode pointer: */
1596
15.6k
      pointer_bits =
1597
15.6k
          DFRACT_BITS - 1 - CountLeadingBits((FIXP_DBL)(nL + nR + 1));
1598
15.6k
      p = FDKreadBits(hBs, pointer_bits); /* p = P [pointer_bits bits] */
1599
1600
15.6k
      if (p > nL + nR + 1) return 0;
1601
1602
13.9k
      pFrameInfo->tranEnv = p ? b - p : -1;
1603
1604
      /* decode freq res: */
1605
60.3k
      for (k = 0; k < nEnv; k++) {
1606
46.4k
        pFrameInfo->freqRes[k] = FDKreadBits(hBs, 1); /* f = F [1 bits] */
1607
46.4k
      }
1608
1609
      /*-------------------------------------------------------------------------
1610
        Decode noise floors
1611
        --------------------------------------------------------------------------*/
1612
13.9k
      pFrameInfo->bordersNoise[0] = aL;
1613
1614
13.9k
      if (nEnv == 1) {
1615
        /* 1 noise floor envelope: */
1616
2.27k
        pFrameInfo->bordersNoise[1] = aR;
1617
11.6k
      } else {
1618
        /* 2 noise floor envelopes */
1619
11.6k
        if (p == 0 || p == 1)
1620
9.01k
          pFrameInfo->bordersNoise[1] = pFrameInfo->borders[nEnv - 1];
1621
2.60k
        else
1622
2.60k
          pFrameInfo->bordersNoise[1] =
1623
2.60k
              pFrameInfo->borders[pFrameInfo->tranEnv];
1624
11.6k
        pFrameInfo->bordersNoise[2] = aR;
1625
11.6k
      }
1626
13.9k
      break;
1627
252k
  }
1628
1629
  /*
1630
    Store number of envelopes, noise floor envelopes and frame class
1631
  */
1632
247k
  pFrameInfo->nEnvelopes = nEnv;
1633
1634
247k
  if (nEnv == 1)
1635
146k
    pFrameInfo->nNoiseEnvelopes = 1;
1636
101k
  else
1637
101k
    pFrameInfo->nNoiseEnvelopes = 2;
1638
1639
247k
  pFrameInfo->frameClass = frameClass;
1640
1641
247k
  if (pFrameInfo->frameClass == 2 || pFrameInfo->frameClass == 1) {
1642
    /* calculate noise floor first and last borders: */
1643
101k
    pFrameInfo->bordersNoise[0] = pFrameInfo->borders[0];
1644
101k
    pFrameInfo->bordersNoise[pFrameInfo->nNoiseEnvelopes] =
1645
101k
        pFrameInfo->borders[nEnv];
1646
101k
  }
1647
1648
247k
  return 1;
1649
252k
}
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
382k
{
1661
382k
  int maxPos, i, j;
1662
382k
  int startPos;
1663
382k
  int stopPos;
1664
382k
  int tranEnv;
1665
382k
  int startPosNoise;
1666
382k
  int stopPosNoise;
1667
382k
  int nEnvelopes = pFrameInfo->nEnvelopes;
1668
382k
  int nNoiseEnvelopes = pFrameInfo->nNoiseEnvelopes;
1669
1670
382k
  if (nEnvelopes < 1 || nEnvelopes > MAX_ENVELOPES) return 0;
1671
1672
382k
  if (nNoiseEnvelopes > MAX_NOISE_ENVELOPES) return 0;
1673
1674
382k
  startPos = pFrameInfo->borders[0];
1675
382k
  stopPos = pFrameInfo->borders[nEnvelopes];
1676
382k
  tranEnv = pFrameInfo->tranEnv;
1677
382k
  startPosNoise = pFrameInfo->bordersNoise[0];
1678
382k
  stopPosNoise = pFrameInfo->bordersNoise[nNoiseEnvelopes];
1679
1680
382k
  if (overlap < 0 || overlap > (3 * (4))) {
1681
0
    return 0;
1682
0
  }
1683
382k
  if (timeStep < 1 || timeStep > (4)) {
1684
0
    return 0;
1685
0
  }
1686
382k
  maxPos = numberOfTimeSlots + (overlap / timeStep);
1687
1688
  /* Check that the start and stop positions of the frame are reasonable values.
1689
   */
1690
382k
  if ((startPos < 0) || (startPos >= stopPos)) return 0;
1691
382k
  if (startPos > maxPos - numberOfTimeSlots) /* First env. must start in or
1692
                                                directly after the overlap
1693
                                                buffer */
1694
0
    return 0;
1695
382k
  if (stopPos < numberOfTimeSlots) /* One complete frame must be ready for
1696
                                      output after processing */
1697
0
    return 0;
1698
382k
  if (stopPos > maxPos) return 0;
1699
1700
  /* Check that the  start border for every envelope is strictly later in time
1701
   */
1702
1.08M
  for (i = 0; i < nEnvelopes; i++) {
1703
702k
    if (pFrameInfo->borders[i] >= pFrameInfo->borders[i + 1]) return 0;
1704
702k
  }
1705
1706
  /* Check that the envelope to be shortened is actually among the envelopes */
1707
378k
  if (tranEnv > nEnvelopes) return 0;
1708
1709
  /* Check the noise borders */
1710
378k
  if (nEnvelopes == 1 && nNoiseEnvelopes > 1) return 0;
1711
1712
378k
  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
967k
  for (i = 0; i < nNoiseEnvelopes; i++) {
1717
589k
    if (pFrameInfo->bordersNoise[i] >= pFrameInfo->bordersNoise[i + 1])
1718
0
      return 0;
1719
589k
  }
1720
1721
  /* Check that every noise border is the same as an envelope border*/
1722
967k
  for (i = 0; i < nNoiseEnvelopes; i++) {
1723
589k
    startPosNoise = pFrameInfo->bordersNoise[i];
1724
1725
859k
    for (j = 0; j < nEnvelopes; j++) {
1726
859k
      if (pFrameInfo->borders[j] == startPosNoise) break;
1727
859k
    }
1728
589k
    if (j == nEnvelopes) return 0;
1729
589k
  }
1730
1731
378k
  return 1;
1732
378k
}