Coverage Report

Created: 2026-02-14 06:59

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/opus/silk/dec_API.c
Line
Count
Source
1
/***********************************************************************
2
Copyright (c) 2006-2011, Skype Limited. All rights reserved.
3
Redistribution and use in source and binary forms, with or without
4
modification, are permitted provided that the following conditions
5
are met:
6
- Redistributions of source code must retain the above copyright notice,
7
this list of conditions and the following disclaimer.
8
- Redistributions in binary form must reproduce the above copyright
9
notice, this list of conditions and the following disclaimer in the
10
documentation and/or other materials provided with the distribution.
11
- Neither the name of Internet Society, IETF or IETF Trust, nor the
12
names of specific contributors, may be used to endorse or promote
13
products derived from this software without specific prior written
14
permission.
15
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
19
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25
POSSIBILITY OF SUCH DAMAGE.
26
***********************************************************************/
27
28
#ifdef HAVE_CONFIG_H
29
#include "config.h"
30
#endif
31
#include "API.h"
32
#include "main.h"
33
#include "stack_alloc.h"
34
#include "os_support.h"
35
36
#ifdef ENABLE_OSCE
37
#include "osce.h"
38
#include "osce_structs.h"
39
#ifdef ENABLE_OSCE_BWE
40
#include "osce_features.h"
41
#endif
42
#endif
43
44
/************************/
45
/* Decoder Super Struct */
46
/************************/
47
typedef struct {
48
    silk_decoder_state          channel_state[ DECODER_NUM_CHANNELS ];
49
    stereo_dec_state                sStereo;
50
    opus_int                         nChannelsAPI;
51
    opus_int                         nChannelsInternal;
52
    opus_int                         prev_decode_only_middle;
53
#ifdef ENABLE_OSCE
54
    OSCEModel                        osce_model;
55
#endif
56
} silk_decoder;
57
58
/*********************/
59
/* Decoder functions */
60
/*********************/
61
62
63
64
opus_int silk_LoadOSCEModels(void *decState, const unsigned char *data, int len)
65
61.5k
{
66
#ifdef ENABLE_OSCE
67
    opus_int ret = SILK_NO_ERROR;
68
69
    ret = osce_load_models(&((silk_decoder *)decState)->osce_model, data, len);
70
    ((silk_decoder *)decState)->osce_model.loaded = (ret == 0);
71
    return ret;
72
#else
73
61.5k
    (void) decState;
74
61.5k
    (void) data;
75
61.5k
    (void) len;
76
61.5k
    return SILK_NO_ERROR;
77
61.5k
#endif
78
61.5k
}
79
80
opus_int silk_Get_Decoder_Size(                         /* O    Returns error code                              */
81
    opus_int                        *decSizeBytes       /* O    Number of bytes in SILK decoder state           */
82
)
83
1.23M
{
84
1.23M
    opus_int ret = SILK_NO_ERROR;
85
86
1.23M
    *decSizeBytes = sizeof( silk_decoder );
87
88
1.23M
    return ret;
89
1.23M
}
90
91
/* Reset decoder state */
92
opus_int silk_ResetDecoder(                              /* O    Returns error code                              */
93
    void                            *decState           /* I/O  State                                           */
94
)
95
780k
{
96
780k
    opus_int n, ret = SILK_NO_ERROR;
97
780k
    silk_decoder_state *channel_state = ((silk_decoder *)decState)->channel_state;
98
99
2.34M
    for( n = 0; n < DECODER_NUM_CHANNELS; n++ ) {
100
1.56M
        ret  = silk_reset_decoder( &channel_state[ n ] );
101
1.56M
    }
102
780k
    silk_memset(&((silk_decoder *)decState)->sStereo, 0, sizeof(((silk_decoder *)decState)->sStereo));
103
    /* Not strictly needed, but it's cleaner that way */
104
780k
    ((silk_decoder *)decState)->prev_decode_only_middle = 0;
105
106
780k
    return ret;
107
780k
}
108
109
110
opus_int silk_InitDecoder(                              /* O    Returns error code                              */
111
    void                            *decState           /* I/O  State                                           */
112
)
113
61.5k
{
114
61.5k
    opus_int n, ret = SILK_NO_ERROR;
115
61.5k
    silk_decoder_state *channel_state = ((silk_decoder *)decState)->channel_state;
116
#ifdef ENABLE_OSCE
117
    ((silk_decoder *)decState)->osce_model.loaded = 0;
118
#endif
119
61.5k
#ifndef USE_WEIGHTS_FILE
120
    /* load osce models */
121
61.5k
    silk_LoadOSCEModels(decState, NULL, 0);
122
61.5k
#endif
123
124
184k
    for( n = 0; n < DECODER_NUM_CHANNELS; n++ ) {
125
123k
        ret  = silk_init_decoder( &channel_state[ n ] );
126
123k
    }
127
61.5k
    silk_memset(&((silk_decoder *)decState)->sStereo, 0, sizeof(((silk_decoder *)decState)->sStereo));
128
    /* Not strictly needed, but it's cleaner that way */
129
61.5k
    ((silk_decoder *)decState)->prev_decode_only_middle = 0;
130
131
61.5k
    return ret;
132
61.5k
}
133
134
/* Decode a frame */
135
opus_int silk_Decode(                                   /* O    Returns error code                              */
136
    void*                           decState,           /* I/O  State                                           */
137
    silk_DecControlStruct*          decControl,         /* I/O  Control Structure                               */
138
    opus_int                        lostFlag,           /* I    0: no loss, 1 loss, 2 decode fec                */
139
    opus_int                        newPacketFlag,      /* I    Indicates first decoder call for this packet    */
140
    ec_dec                          *psRangeDec,        /* I/O  Compressor data structure                       */
141
    opus_res                        *samplesOut,        /* O    Decoded output speech vector                    */
142
    opus_int32                      *nSamplesOut,       /* O    Number of samples decoded                       */
143
#ifdef ENABLE_DEEP_PLC
144
    LPCNetPLCState                  *lpcnet,
145
#endif
146
    int                             arch                /* I    Run-time architecture                           */
147
)
148
210k
{
149
210k
    opus_int   i, n, decode_only_middle = 0, ret = SILK_NO_ERROR;
150
210k
    opus_int32 nSamplesOutDec, LBRR_symbol;
151
210k
    opus_int16 *samplesOut1_tmp[ 2 ];
152
210k
    VARDECL( opus_int16, samplesOut1_tmp_storage1 );
153
210k
    VARDECL( opus_int16, samplesOut2_tmp );
154
210k
    opus_int32 MS_pred_Q13[ 2 ] = { 0 };
155
210k
    opus_int16 *resample_out_ptr;
156
210k
    silk_decoder *psDec = ( silk_decoder * )decState;
157
210k
    silk_decoder_state *channel_state = psDec->channel_state;
158
210k
    opus_int has_side;
159
210k
    opus_int stereo_to_mono;
160
#ifdef ENABLE_OSCE_BWE
161
    VARDECL( opus_int16, resamp_buffer );
162
#endif
163
210k
    SAVE_STACK;
164
165
210k
    celt_assert( decControl->nChannelsInternal == 1 || decControl->nChannelsInternal == 2 );
166
167
    /**********************************/
168
    /* Test if first frame in payload */
169
    /**********************************/
170
210k
    if( newPacketFlag ) {
171
426k
        for( n = 0; n < decControl->nChannelsInternal; n++ ) {
172
243k
            channel_state[ n ].nFramesDecoded = 0;  /* Used to count frames in packet */
173
243k
        }
174
182k
    }
175
176
    /* If Mono -> Stereo transition in bitstream: init state of second channel */
177
210k
    if( decControl->nChannelsInternal > psDec->nChannelsInternal ) {
178
6.67k
        ret += silk_init_decoder( &channel_state[ 1 ] );
179
6.67k
    }
180
181
210k
    stereo_to_mono = decControl->nChannelsInternal == 1 && psDec->nChannelsInternal == 2 &&
182
3.41k
                     ( decControl->internalSampleRate == 1000*channel_state[ 0 ].fs_kHz );
183
184
210k
    if( channel_state[ 0 ].nFramesDecoded == 0 ) {
185
426k
        for( n = 0; n < decControl->nChannelsInternal; n++ ) {
186
243k
            opus_int fs_kHz_dec;
187
243k
            if( decControl->payloadSize_ms == 0 ) {
188
                /* Assuming packet loss, use 10 ms */
189
0
                channel_state[ n ].nFramesPerPacket = 1;
190
0
                channel_state[ n ].nb_subfr = 2;
191
243k
            } else if( decControl->payloadSize_ms == 10 ) {
192
141k
                channel_state[ n ].nFramesPerPacket = 1;
193
141k
                channel_state[ n ].nb_subfr = 2;
194
141k
            } else if( decControl->payloadSize_ms == 20 ) {
195
60.0k
                channel_state[ n ].nFramesPerPacket = 1;
196
60.0k
                channel_state[ n ].nb_subfr = 4;
197
60.0k
            } else if( decControl->payloadSize_ms == 40 ) {
198
31.9k
                channel_state[ n ].nFramesPerPacket = 2;
199
31.9k
                channel_state[ n ].nb_subfr = 4;
200
31.9k
            } else if( decControl->payloadSize_ms == 60 ) {
201
10.1k
                channel_state[ n ].nFramesPerPacket = 3;
202
10.1k
                channel_state[ n ].nb_subfr = 4;
203
10.1k
            } else {
204
0
                celt_assert( 0 );
205
0
                RESTORE_STACK;
206
0
                return SILK_DEC_INVALID_FRAME_SIZE;
207
0
            }
208
243k
            fs_kHz_dec = ( decControl->internalSampleRate >> 10 ) + 1;
209
243k
            if( fs_kHz_dec != 8 && fs_kHz_dec != 12 && fs_kHz_dec != 16 ) {
210
0
                celt_assert( 0 );
211
0
                RESTORE_STACK;
212
0
                return SILK_DEC_INVALID_SAMPLING_FREQUENCY;
213
0
            }
214
243k
            ret += silk_decoder_set_fs( &channel_state[ n ], fs_kHz_dec, decControl->API_sampleRate );
215
243k
        }
216
182k
    }
217
218
210k
    if( decControl->nChannelsAPI == 2 && decControl->nChannelsInternal == 2 && ( psDec->nChannelsAPI == 1 || psDec->nChannelsInternal == 1 ) ) {
219
3.10k
        silk_memset( psDec->sStereo.pred_prev_Q13, 0, sizeof( psDec->sStereo.pred_prev_Q13 ) );
220
3.10k
        silk_memset( psDec->sStereo.sSide, 0, sizeof( psDec->sStereo.sSide ) );
221
3.10k
        silk_memcpy( &channel_state[ 1 ].resampler_state, &channel_state[ 0 ].resampler_state, sizeof( silk_resampler_state_struct ) );
222
3.10k
    }
223
210k
    psDec->nChannelsAPI      = decControl->nChannelsAPI;
224
210k
    psDec->nChannelsInternal = decControl->nChannelsInternal;
225
226
210k
    if( decControl->API_sampleRate > (opus_int32)MAX_API_FS_KHZ * 1000 || decControl->API_sampleRate < 8000 ) {
227
0
        ret = SILK_DEC_INVALID_SAMPLING_FREQUENCY;
228
0
        RESTORE_STACK;
229
0
        return( ret );
230
0
    }
231
232
210k
    if( lostFlag != FLAG_PACKET_LOST && channel_state[ 0 ].nFramesDecoded == 0 ) {
233
        /* First decoder call for this payload */
234
        /* Decode VAD flags and LBRR flag */
235
206k
        for( n = 0; n < decControl->nChannelsInternal; n++ ) {
236
290k
            for( i = 0; i < channel_state[ n ].nFramesPerPacket; i++ ) {
237
171k
                channel_state[ n ].VAD_flags[ i ] = ec_dec_bit_logp(psRangeDec, 1);
238
171k
            }
239
119k
            channel_state[ n ].LBRR_flag = ec_dec_bit_logp(psRangeDec, 1);
240
119k
        }
241
        /* Decode LBRR flags */
242
206k
        for( n = 0; n < decControl->nChannelsInternal; n++ ) {
243
119k
            silk_memset( channel_state[ n ].LBRR_flags, 0, sizeof( channel_state[ n ].LBRR_flags ) );
244
119k
            if( channel_state[ n ].LBRR_flag ) {
245
47.0k
                if( channel_state[ n ].nFramesPerPacket == 1 ) {
246
29.5k
                    channel_state[ n ].LBRR_flags[ 0 ] = 1;
247
29.5k
                } else {
248
17.4k
                    LBRR_symbol = ec_dec_icdf( psRangeDec, silk_LBRR_flags_iCDF_ptr[ channel_state[ n ].nFramesPerPacket - 2 ], 8 ) + 1;
249
58.6k
                    for( i = 0; i < channel_state[ n ].nFramesPerPacket; i++ ) {
250
41.1k
                        channel_state[ n ].LBRR_flags[ i ] = silk_RSHIFT( LBRR_symbol, i ) & 1;
251
41.1k
                    }
252
17.4k
                }
253
47.0k
            }
254
119k
        }
255
256
87.1k
        if( lostFlag == FLAG_DECODE_NORMAL ) {
257
            /* Regular decoding: skip all LBRR data */
258
202k
            for( i = 0; i < channel_state[ 0 ].nFramesPerPacket; i++ ) {
259
286k
                for( n = 0; n < decControl->nChannelsInternal; n++ ) {
260
171k
                    if( channel_state[ n ].LBRR_flags[ i ] ) {
261
57.1k
                        opus_int16 pulses[ MAX_FRAME_LENGTH ];
262
57.1k
                        opus_int condCoding;
263
264
57.1k
                        if( decControl->nChannelsInternal == 2 && n == 0 ) {
265
15.2k
                            silk_stereo_decode_pred( psRangeDec, MS_pred_Q13 );
266
15.2k
                            if( channel_state[ 1 ].LBRR_flags[ i ] == 0 ) {
267
4.23k
                                silk_stereo_decode_mid_only( psRangeDec, &decode_only_middle );
268
4.23k
                            }
269
15.2k
                        }
270
                        /* Use conditional coding if previous frame available */
271
57.1k
                        if( i > 0 && channel_state[ n ].LBRR_flags[ i - 1 ] ) {
272
10.0k
                            condCoding = CODE_CONDITIONALLY;
273
47.0k
                        } else {
274
47.0k
                            condCoding = CODE_INDEPENDENTLY;
275
47.0k
                        }
276
57.1k
                        silk_decode_indices( &channel_state[ n ], psRangeDec, i, 1, condCoding );
277
57.1k
                        silk_decode_pulses( psRangeDec, pulses, channel_state[ n ].indices.signalType,
278
57.1k
                            channel_state[ n ].indices.quantOffsetType, channel_state[ n ].frame_length );
279
57.1k
                    }
280
171k
                }
281
115k
            }
282
87.1k
        }
283
87.1k
    }
284
285
    /* Get MS predictor index */
286
210k
    if( decControl->nChannelsInternal == 2 ) {
287
85.5k
        if(   lostFlag == FLAG_DECODE_NORMAL ||
288
29.6k
            ( lostFlag == FLAG_DECODE_LBRR && channel_state[ 0 ].LBRR_flags[ channel_state[ 0 ].nFramesDecoded ] == 1 ) )
289
55.8k
        {
290
55.8k
            silk_stereo_decode_pred( psRangeDec, MS_pred_Q13 );
291
            /* For LBRR data, decode mid-only flag only if side-channel's LBRR flag is false */
292
55.8k
            if( ( lostFlag == FLAG_DECODE_NORMAL && channel_state[ 1 ].VAD_flags[ channel_state[ 0 ].nFramesDecoded ] == 0 ) ||
293
20.3k
                ( lostFlag == FLAG_DECODE_LBRR && channel_state[ 1 ].LBRR_flags[ channel_state[ 0 ].nFramesDecoded ] == 0 ) )
294
35.4k
            {
295
35.4k
                silk_stereo_decode_mid_only( psRangeDec, &decode_only_middle );
296
35.4k
            } else {
297
20.3k
                decode_only_middle = 0;
298
20.3k
            }
299
55.8k
        } else {
300
89.0k
            for( n = 0; n < 2; n++ ) {
301
59.3k
                MS_pred_Q13[ n ] = psDec->sStereo.pred_prev_Q13[ n ];
302
59.3k
            }
303
29.6k
        }
304
85.5k
    }
305
306
    /* Reset side channel decoder prediction memory for first frame with side coding */
307
210k
    if( decControl->nChannelsInternal == 2 && decode_only_middle == 0 && psDec->prev_decode_only_middle == 1 ) {
308
8.60k
        silk_memset( psDec->channel_state[ 1 ].outBuf, 0, sizeof(psDec->channel_state[ 1 ].outBuf) );
309
8.60k
        silk_memset( psDec->channel_state[ 1 ].sLPC_Q14_buf, 0, sizeof(psDec->channel_state[ 1 ].sLPC_Q14_buf) );
310
8.60k
        psDec->channel_state[ 1 ].lagPrev        = 100;
311
8.60k
        psDec->channel_state[ 1 ].LastGainIndex  = 10;
312
8.60k
        psDec->channel_state[ 1 ].prevSignalType = TYPE_NO_VOICE_ACTIVITY;
313
8.60k
        psDec->channel_state[ 1 ].first_frame_after_reset = 1;
314
8.60k
    }
315
316
    /* Check if the temp buffer fits into the output PCM buffer. If it fits,
317
       we can delay allocating the temp buffer until after the SILK peak stack
318
       usage. We need to use a < and not a <= because of the two extra samples. */
319
210k
    ALLOC( samplesOut1_tmp_storage1, decControl->nChannelsInternal*(channel_state[ 0 ].frame_length + 2 ),
320
210k
           opus_int16 );
321
210k
    samplesOut1_tmp[ 0 ] = samplesOut1_tmp_storage1;
322
210k
    samplesOut1_tmp[ 1 ] = samplesOut1_tmp_storage1 + channel_state[ 0 ].frame_length + 2;
323
324
210k
    if( lostFlag == FLAG_DECODE_NORMAL ) {
325
115k
        has_side = !decode_only_middle;
326
115k
    } else {
327
95.1k
        has_side = !psDec->prev_decode_only_middle
328
4.35k
              || (decControl->nChannelsInternal == 2 && lostFlag == FLAG_DECODE_LBRR && channel_state[1].LBRR_flags[ channel_state[1].nFramesDecoded ] == 1 );
329
95.1k
    }
330
210k
    channel_state[ 0 ].sPLC.enable_deep_plc = decControl->enable_deep_plc;
331
    /* Call decoder for one frame */
332
506k
    for( n = 0; n < decControl->nChannelsInternal; n++ ) {
333
296k
        if( n == 0 || has_side ) {
334
285k
            opus_int FrameIndex;
335
285k
            opus_int condCoding;
336
337
285k
            FrameIndex = channel_state[ 0 ].nFramesDecoded - n;
338
            /* Use independent coding if no previous frame available */
339
285k
            if( FrameIndex <= 0 ) {
340
235k
                condCoding = CODE_INDEPENDENTLY;
341
235k
            } else if( lostFlag == FLAG_DECODE_LBRR ) {
342
0
                condCoding = channel_state[ n ].LBRR_flags[ FrameIndex - 1 ] ? CODE_CONDITIONALLY : CODE_INDEPENDENTLY;
343
49.8k
            } else if( n > 0 && psDec->prev_decode_only_middle ) {
344
                /* If we skipped a side frame in this packet, we don't
345
                   need LTP scaling; the LTP state is well-defined. */
346
2.97k
                condCoding = CODE_INDEPENDENTLY_NO_LTP_SCALING;
347
46.8k
            } else {
348
46.8k
                condCoding = CODE_CONDITIONALLY;
349
46.8k
            }
350
#ifdef ENABLE_OSCE
351
            if ( channel_state[n].osce.method != decControl->osce_method ) {
352
                osce_reset( &channel_state[n].osce, decControl->osce_method );
353
            }
354
#endif
355
285k
            ret += silk_decode_frame( &channel_state[ n ], psRangeDec, &samplesOut1_tmp[ n ][ 2 ], &nSamplesOutDec, lostFlag, condCoding,
356
#ifdef ENABLE_DEEP_PLC
357
                n == 0 ? lpcnet : NULL,
358
#endif
359
#ifdef ENABLE_OSCE
360
                &psDec->osce_model,
361
#endif
362
285k
                arch);
363
285k
        } else {
364
10.9k
            silk_memset( &samplesOut1_tmp[ n ][ 2 ], 0, nSamplesOutDec * sizeof( opus_int16 ) );
365
10.9k
        }
366
296k
        channel_state[ n ].nFramesDecoded++;
367
296k
    }
368
369
210k
    if( decControl->nChannelsAPI == 2 && decControl->nChannelsInternal == 2 ) {
370
        /* Convert Mid/Side to Left/Right */
371
75.0k
        silk_stereo_MS_to_LR( &psDec->sStereo, samplesOut1_tmp[ 0 ], samplesOut1_tmp[ 1 ], MS_pred_Q13, channel_state[ 0 ].fs_kHz, nSamplesOutDec );
372
135k
    } else {
373
        /* Buffering */
374
135k
        silk_memcpy( samplesOut1_tmp[ 0 ], psDec->sStereo.sMid, 2 * sizeof( opus_int16 ) );
375
135k
        silk_memcpy( psDec->sStereo.sMid, &samplesOut1_tmp[ 0 ][ nSamplesOutDec ], 2 * sizeof( opus_int16 ) );
376
135k
    }
377
378
    /* Number of output samples */
379
210k
    *nSamplesOut = silk_DIV32( nSamplesOutDec * decControl->API_sampleRate, silk_SMULBB( channel_state[ 0 ].fs_kHz, 1000 ) );
380
381
    /* Set up pointers to temp buffers */
382
210k
    ALLOC( samplesOut2_tmp, *nSamplesOut, opus_int16 );
383
210k
    resample_out_ptr = samplesOut2_tmp;
384
385
#ifdef ENABLE_OSCE_BWE
386
    ALLOC(resamp_buffer, 3 * MAX_FRAME_LENGTH, opus_int16);
387
#endif
388
389
496k
    for( n = 0; n < silk_min( decControl->nChannelsAPI, decControl->nChannelsInternal ); n++ ) {
390
391
#ifdef ENABLE_OSCE_BWE
392
        /* Resample or extend decoded signal to API_sampleRate */
393
        if (decControl->osce_extended_mode == OSCE_MODE_SILK_BBWE) {
394
            silk_assert(decControl->API_sampleRate == 48000);
395
396
            if (decControl->prev_osce_extended_mode != OSCE_MODE_SILK_BBWE) {
397
                /* Reset the BWE state */
398
                osce_bwe_reset( &channel_state[ n ].osce_bwe );
399
            }
400
401
            osce_bwe(&psDec->osce_model, &channel_state[ n ].osce_bwe,
402
                resample_out_ptr, &samplesOut1_tmp[ n ][ 1 ], nSamplesOutDec, arch);
403
404
            if (decControl->prev_osce_extended_mode == OSCE_MODE_SILK_ONLY ||
405
                decControl->prev_osce_extended_mode == OSCE_MODE_HYBRID) {
406
                    /* cross-fade with upsampled signal */
407
                    silk_resampler( &channel_state[ n ].resampler_state, resamp_buffer, &samplesOut1_tmp[ n ][ 1 ], nSamplesOutDec );
408
                    osce_bwe_cross_fade_10ms(resample_out_ptr, resamp_buffer, 480);
409
            }
410
        } else {
411
            ret += silk_resampler( &channel_state[ n ].resampler_state, resample_out_ptr, &samplesOut1_tmp[ n ][ 1 ], nSamplesOutDec );
412
            if (decControl->prev_osce_extended_mode == OSCE_MODE_SILK_BBWE && decControl->internalSampleRate == 16000) {
413
                /* fade out if internal sample rate did not change */
414
                osce_bwe(&psDec->osce_model, &channel_state[ n ].osce_bwe,
415
                    resamp_buffer, &samplesOut1_tmp[ n ][ 1 ], nSamplesOutDec, arch);
416
                /* cross-fade with upsampled signal */
417
                osce_bwe_cross_fade_10ms(resample_out_ptr, resamp_buffer, 480);
418
            }
419
        }
420
#else
421
        /* Resample decoded signal to API_sampleRate */
422
285k
        ret += silk_resampler( &channel_state[ n ].resampler_state, resample_out_ptr, &samplesOut1_tmp[ n ][ 1 ], nSamplesOutDec );
423
285k
#endif
424
        /* Interleave if stereo output and stereo stream */
425
285k
        if( decControl->nChannelsAPI == 2 ) {
426
191M
            for( i = 0; i < *nSamplesOut; i++ ) {
427
190M
                samplesOut[ n + 2 * i ] = INT16TORES(resample_out_ptr[ i ]);
428
190M
            }
429
265k
        } else {
430
16.1M
            for( i = 0; i < *nSamplesOut; i++ ) {
431
16.1M
                samplesOut[ i ] = INT16TORES(resample_out_ptr[ i ]);
432
16.1M
            }
433
20.6k
        }
434
285k
    }
435
436
#ifdef ENABLE_OSCE_BWE
437
    decControl->prev_osce_extended_mode = decControl->osce_extended_mode;
438
#endif
439
440
    /* Create two channel output from mono stream */
441
210k
    if( decControl->nChannelsAPI == 2 && decControl->nChannelsInternal == 1 ) {
442
114k
        if ( stereo_to_mono ){
443
            /* Resample right channel for newly collapsed stereo just in case
444
               we weren't doing collapsing when switching to mono */
445
1.64k
            ret += silk_resampler( &channel_state[ 1 ].resampler_state, resample_out_ptr, &samplesOut1_tmp[ 0 ][ 1 ], nSamplesOutDec );
446
447
993k
            for( i = 0; i < *nSamplesOut; i++ ) {
448
991k
                samplesOut[ 1 + 2 * i ] = INT16TORES(resample_out_ptr[ i ]);
449
991k
            }
450
113k
        } else {
451
69.2M
            for( i = 0; i < *nSamplesOut; i++ ) {
452
69.1M
                samplesOut[ 1 + 2 * i ] = samplesOut[ 0 + 2 * i ];
453
69.1M
            }
454
113k
        }
455
114k
    }
456
457
    /* Export pitch lag, measured at 48 kHz sampling rate */
458
210k
    if( channel_state[ 0 ].prevSignalType == TYPE_VOICED ) {
459
27.9k
        int mult_tab[ 3 ] = { 6, 4, 3 };
460
27.9k
        decControl->prevPitchLag = channel_state[ 0 ].lagPrev * mult_tab[ ( channel_state[ 0 ].fs_kHz - 8 ) >> 2 ];
461
182k
    } else {
462
182k
        decControl->prevPitchLag = 0;
463
182k
    }
464
465
210k
    if( lostFlag == FLAG_PACKET_LOST ) {
466
       /* On packet loss, remove the gain clamping to prevent having the energy "bounce back"
467
          if we lose packets when the energy is going down */
468
219k
       for ( i = 0; i < psDec->nChannelsInternal; i++ )
469
124k
          psDec->channel_state[ i ].LastGainIndex = 10;
470
115k
    } else {
471
115k
       psDec->prev_decode_only_middle = decode_only_middle;
472
115k
    }
473
210k
    RESTORE_STACK;
474
210k
    return ret;
475
210k
}
476
477
#if 0
478
/* Getting table of contents for a packet */
479
opus_int silk_get_TOC(
480
    const opus_uint8                *payload,           /* I    Payload data                                */
481
    const opus_int                  nBytesIn,           /* I    Number of input bytes                       */
482
    const opus_int                  nFramesPerPayload,  /* I    Number of SILK frames per payload           */
483
    silk_TOC_struct                 *Silk_TOC           /* O    Type of content                             */
484
)
485
{
486
    opus_int i, flags, ret = SILK_NO_ERROR;
487
488
    if( nBytesIn < 1 ) {
489
        return -1;
490
    }
491
    if( nFramesPerPayload < 0 || nFramesPerPayload > 3 ) {
492
        return -1;
493
    }
494
495
    silk_memset( Silk_TOC, 0, sizeof( *Silk_TOC ) );
496
497
    /* For stereo, extract the flags for the mid channel */
498
    flags = silk_RSHIFT( payload[ 0 ], 7 - nFramesPerPayload ) & ( silk_LSHIFT( 1, nFramesPerPayload + 1 ) - 1 );
499
500
    Silk_TOC->inbandFECFlag = flags & 1;
501
    for( i = nFramesPerPayload - 1; i >= 0 ; i-- ) {
502
        flags = silk_RSHIFT( flags, 1 );
503
        Silk_TOC->VADFlags[ i ] = flags & 1;
504
        Silk_TOC->VADFlag |= flags & 1;
505
    }
506
507
    return ret;
508
}
509
#endif