Coverage Report

Created: 2026-01-16 07:48

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
60.8k
{
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
60.8k
    (void) decState;
74
60.8k
    (void) data;
75
60.8k
    (void) len;
76
60.8k
    return SILK_NO_ERROR;
77
60.8k
#endif
78
60.8k
}
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.66M
{
84
1.66M
    opus_int ret = SILK_NO_ERROR;
85
86
1.66M
    *decSizeBytes = sizeof( silk_decoder );
87
88
1.66M
    return ret;
89
1.66M
}
90
91
/* Reset decoder state */
92
opus_int silk_ResetDecoder(                              /* O    Returns error code                              */
93
    void                            *decState           /* I/O  State                                           */
94
)
95
2.20M
{
96
2.20M
    opus_int n, ret = SILK_NO_ERROR;
97
2.20M
    silk_decoder_state *channel_state = ((silk_decoder *)decState)->channel_state;
98
99
6.61M
    for( n = 0; n < DECODER_NUM_CHANNELS; n++ ) {
100
4.41M
        ret  = silk_reset_decoder( &channel_state[ n ] );
101
4.41M
    }
102
2.20M
    silk_memset(&((silk_decoder *)decState)->sStereo, 0, sizeof(((silk_decoder *)decState)->sStereo));
103
    /* Not strictly needed, but it's cleaner that way */
104
2.20M
    ((silk_decoder *)decState)->prev_decode_only_middle = 0;
105
106
2.20M
    return ret;
107
2.20M
}
108
109
110
opus_int silk_InitDecoder(                              /* O    Returns error code                              */
111
    void                            *decState           /* I/O  State                                           */
112
)
113
60.8k
{
114
60.8k
    opus_int n, ret = SILK_NO_ERROR;
115
60.8k
    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
60.8k
#ifndef USE_WEIGHTS_FILE
120
    /* load osce models */
121
60.8k
    silk_LoadOSCEModels(decState, NULL, 0);
122
60.8k
#endif
123
124
182k
    for( n = 0; n < DECODER_NUM_CHANNELS; n++ ) {
125
121k
        ret  = silk_init_decoder( &channel_state[ n ] );
126
121k
    }
127
60.8k
    silk_memset(&((silk_decoder *)decState)->sStereo, 0, sizeof(((silk_decoder *)decState)->sStereo));
128
    /* Not strictly needed, but it's cleaner that way */
129
60.8k
    ((silk_decoder *)decState)->prev_decode_only_middle = 0;
130
131
60.8k
    return ret;
132
60.8k
}
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
304k
{
149
304k
    opus_int   i, n, decode_only_middle = 0, ret = SILK_NO_ERROR;
150
304k
    opus_int32 nSamplesOutDec, LBRR_symbol;
151
304k
    opus_int16 *samplesOut1_tmp[ 2 ];
152
304k
    VARDECL( opus_int16, samplesOut1_tmp_storage1 );
153
304k
    VARDECL( opus_int16, samplesOut2_tmp );
154
304k
    opus_int32 MS_pred_Q13[ 2 ] = { 0 };
155
304k
    opus_int16 *resample_out_ptr;
156
304k
    silk_decoder *psDec = ( silk_decoder * )decState;
157
304k
    silk_decoder_state *channel_state = psDec->channel_state;
158
304k
    opus_int has_side;
159
304k
    opus_int stereo_to_mono;
160
#ifdef ENABLE_OSCE_BWE
161
    VARDECL( opus_int16, resamp_buffer );
162
#endif
163
304k
    SAVE_STACK;
164
165
304k
    celt_assert( decControl->nChannelsInternal == 1 || decControl->nChannelsInternal == 2 );
166
167
    /**********************************/
168
    /* Test if first frame in payload */
169
    /**********************************/
170
304k
    if( newPacketFlag ) {
171
618k
        for( n = 0; n < decControl->nChannelsInternal; n++ ) {
172
341k
            channel_state[ n ].nFramesDecoded = 0;  /* Used to count frames in packet */
173
341k
        }
174
276k
    }
175
176
    /* If Mono -> Stereo transition in bitstream: init state of second channel */
177
304k
    if( decControl->nChannelsInternal > psDec->nChannelsInternal ) {
178
6.74k
        ret += silk_init_decoder( &channel_state[ 1 ] );
179
6.74k
    }
180
181
304k
    stereo_to_mono = decControl->nChannelsInternal == 1 && psDec->nChannelsInternal == 2 &&
182
3.38k
                     ( decControl->internalSampleRate == 1000*channel_state[ 0 ].fs_kHz );
183
184
304k
    if( channel_state[ 0 ].nFramesDecoded == 0 ) {
185
618k
        for( n = 0; n < decControl->nChannelsInternal; n++ ) {
186
341k
            opus_int fs_kHz_dec;
187
341k
            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
341k
            } else if( decControl->payloadSize_ms == 10 ) {
192
235k
                channel_state[ n ].nFramesPerPacket = 1;
193
235k
                channel_state[ n ].nb_subfr = 2;
194
235k
            } else if( decControl->payloadSize_ms == 20 ) {
195
64.6k
                channel_state[ n ].nFramesPerPacket = 1;
196
64.6k
                channel_state[ n ].nb_subfr = 4;
197
64.6k
            } else if( decControl->payloadSize_ms == 40 ) {
198
30.8k
                channel_state[ n ].nFramesPerPacket = 2;
199
30.8k
                channel_state[ n ].nb_subfr = 4;
200
30.8k
            } 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
341k
            fs_kHz_dec = ( decControl->internalSampleRate >> 10 ) + 1;
209
341k
            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
341k
            ret += silk_decoder_set_fs( &channel_state[ n ], fs_kHz_dec, decControl->API_sampleRate );
215
341k
        }
216
276k
    }
217
218
304k
    if( decControl->nChannelsAPI == 2 && decControl->nChannelsInternal == 2 && ( psDec->nChannelsAPI == 1 || psDec->nChannelsInternal == 1 ) ) {
219
3.15k
        silk_memset( psDec->sStereo.pred_prev_Q13, 0, sizeof( psDec->sStereo.pred_prev_Q13 ) );
220
3.15k
        silk_memset( psDec->sStereo.sSide, 0, sizeof( psDec->sStereo.sSide ) );
221
3.15k
        silk_memcpy( &channel_state[ 1 ].resampler_state, &channel_state[ 0 ].resampler_state, sizeof( silk_resampler_state_struct ) );
222
3.15k
    }
223
304k
    psDec->nChannelsAPI      = decControl->nChannelsAPI;
224
304k
    psDec->nChannelsInternal = decControl->nChannelsInternal;
225
226
304k
    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
304k
    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
317k
        for( n = 0; n < decControl->nChannelsInternal; n++ ) {
236
401k
            for( i = 0; i < channel_state[ n ].nFramesPerPacket; i++ ) {
237
226k
                channel_state[ n ].VAD_flags[ i ] = ec_dec_bit_logp(psRangeDec, 1);
238
226k
            }
239
175k
            channel_state[ n ].LBRR_flag = ec_dec_bit_logp(psRangeDec, 1);
240
175k
        }
241
        /* Decode LBRR flags */
242
317k
        for( n = 0; n < decControl->nChannelsInternal; n++ ) {
243
175k
            silk_memset( channel_state[ n ].LBRR_flags, 0, sizeof( channel_state[ n ].LBRR_flags ) );
244
175k
            if( channel_state[ n ].LBRR_flag ) {
245
69.9k
                if( channel_state[ n ].nFramesPerPacket == 1 ) {
246
54.7k
                    channel_state[ n ].LBRR_flags[ 0 ] = 1;
247
54.7k
                } else {
248
15.1k
                    LBRR_symbol = ec_dec_icdf( psRangeDec, silk_LBRR_flags_iCDF_ptr[ channel_state[ n ].nFramesPerPacket - 2 ], 8 ) + 1;
249
51.5k
                    for( i = 0; i < channel_state[ n ].nFramesPerPacket; i++ ) {
250
36.3k
                        channel_state[ n ].LBRR_flags[ i ] = silk_RSHIFT( LBRR_symbol, i ) & 1;
251
36.3k
                    }
252
15.1k
                }
253
69.9k
            }
254
175k
        }
255
256
142k
        if( lostFlag == FLAG_DECODE_NORMAL ) {
257
            /* Regular decoding: skip all LBRR data */
258
313k
            for( i = 0; i < channel_state[ 0 ].nFramesPerPacket; i++ ) {
259
396k
                for( n = 0; n < decControl->nChannelsInternal; n++ ) {
260
226k
                    if( channel_state[ n ].LBRR_flags[ i ] ) {
261
79.4k
                        opus_int16 pulses[ MAX_FRAME_LENGTH ];
262
79.4k
                        opus_int condCoding;
263
264
79.4k
                        if( decControl->nChannelsInternal == 2 && n == 0 ) {
265
15.3k
                            silk_stereo_decode_pred( psRangeDec, MS_pred_Q13 );
266
15.3k
                            if( channel_state[ 1 ].LBRR_flags[ i ] == 0 ) {
267
4.31k
                                silk_stereo_decode_mid_only( psRangeDec, &decode_only_middle );
268
4.31k
                            }
269
15.3k
                        }
270
                        /* Use conditional coding if previous frame available */
271
79.4k
                        if( i > 0 && channel_state[ n ].LBRR_flags[ i - 1 ] ) {
272
9.47k
                            condCoding = CODE_CONDITIONALLY;
273
69.9k
                        } else {
274
69.9k
                            condCoding = CODE_INDEPENDENTLY;
275
69.9k
                        }
276
79.4k
                        silk_decode_indices( &channel_state[ n ], psRangeDec, i, 1, condCoding );
277
79.4k
                        silk_decode_pulses( psRangeDec, pulses, channel_state[ n ].indices.signalType,
278
79.4k
                            channel_state[ n ].indices.quantOffsetType, channel_state[ n ].frame_length );
279
79.4k
                    }
280
226k
                }
281
170k
            }
282
142k
        }
283
142k
    }
284
285
    /* Get MS predictor index */
286
304k
    if( decControl->nChannelsInternal == 2 ) {
287
87.7k
        if(   lostFlag == FLAG_DECODE_NORMAL ||
288
31.9k
            ( 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
18.8k
                ( lostFlag == FLAG_DECODE_LBRR && channel_state[ 1 ].LBRR_flags[ channel_state[ 0 ].nFramesDecoded ] == 0 ) )
294
37.0k
            {
295
37.0k
                silk_stereo_decode_mid_only( psRangeDec, &decode_only_middle );
296
37.0k
            } else {
297
18.8k
                decode_only_middle = 0;
298
18.8k
            }
299
55.8k
        } else {
300
95.9k
            for( n = 0; n < 2; n++ ) {
301
63.9k
                MS_pred_Q13[ n ] = psDec->sStereo.pred_prev_Q13[ n ];
302
63.9k
            }
303
31.9k
        }
304
87.7k
    }
305
306
    /* Reset side channel decoder prediction memory for first frame with side coding */
307
304k
    if( decControl->nChannelsInternal == 2 && decode_only_middle == 0 && psDec->prev_decode_only_middle == 1 ) {
308
7.83k
        silk_memset( psDec->channel_state[ 1 ].outBuf, 0, sizeof(psDec->channel_state[ 1 ].outBuf) );
309
7.83k
        silk_memset( psDec->channel_state[ 1 ].sLPC_Q14_buf, 0, sizeof(psDec->channel_state[ 1 ].sLPC_Q14_buf) );
310
7.83k
        psDec->channel_state[ 1 ].lagPrev        = 100;
311
7.83k
        psDec->channel_state[ 1 ].LastGainIndex  = 10;
312
7.83k
        psDec->channel_state[ 1 ].prevSignalType = TYPE_NO_VOICE_ACTIVITY;
313
7.83k
        psDec->channel_state[ 1 ].first_frame_after_reset = 1;
314
7.83k
    }
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
304k
    ALLOC( samplesOut1_tmp_storage1, decControl->nChannelsInternal*(channel_state[ 0 ].frame_length + 2 ),
320
304k
           opus_int16 );
321
304k
    samplesOut1_tmp[ 0 ] = samplesOut1_tmp_storage1;
322
304k
    samplesOut1_tmp[ 1 ] = samplesOut1_tmp_storage1 + channel_state[ 0 ].frame_length + 2;
323
324
304k
    if( lostFlag == FLAG_DECODE_NORMAL ) {
325
170k
        has_side = !decode_only_middle;
326
170k
    } else {
327
134k
        has_side = !psDec->prev_decode_only_middle
328
4.01k
              || (decControl->nChannelsInternal == 2 && lostFlag == FLAG_DECODE_LBRR && channel_state[1].LBRR_flags[ channel_state[1].nFramesDecoded ] == 1 );
329
134k
    }
330
304k
    channel_state[ 0 ].sPLC.enable_deep_plc = decControl->enable_deep_plc;
331
    /* Call decoder for one frame */
332
697k
    for( n = 0; n < decControl->nChannelsInternal; n++ ) {
333
392k
        if( n == 0 || has_side ) {
334
382k
            opus_int FrameIndex;
335
382k
            opus_int condCoding;
336
337
382k
            FrameIndex = channel_state[ 0 ].nFramesDecoded - n;
338
            /* Use independent coding if no previous frame available */
339
382k
            if( FrameIndex <= 0 ) {
340
333k
                condCoding = CODE_INDEPENDENTLY;
341
333k
            } else if( lostFlag == FLAG_DECODE_LBRR ) {
342
0
                condCoding = channel_state[ n ].LBRR_flags[ FrameIndex - 1 ] ? CODE_CONDITIONALLY : CODE_INDEPENDENTLY;
343
48.7k
            } 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.51k
                condCoding = CODE_INDEPENDENTLY_NO_LTP_SCALING;
347
46.2k
            } else {
348
46.2k
                condCoding = CODE_CONDITIONALLY;
349
46.2k
            }
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
382k
            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
382k
                arch);
363
382k
        } else {
364
9.96k
            silk_memset( &samplesOut1_tmp[ n ][ 2 ], 0, nSamplesOutDec * sizeof( opus_int16 ) );
365
9.96k
        }
366
392k
        channel_state[ n ].nFramesDecoded++;
367
392k
    }
368
369
304k
    if( decControl->nChannelsAPI == 2 && decControl->nChannelsInternal == 2 ) {
370
        /* Convert Mid/Side to Left/Right */
371
80.2k
        silk_stereo_MS_to_LR( &psDec->sStereo, samplesOut1_tmp[ 0 ], samplesOut1_tmp[ 1 ], MS_pred_Q13, channel_state[ 0 ].fs_kHz, nSamplesOutDec );
372
224k
    } else {
373
        /* Buffering */
374
224k
        silk_memcpy( samplesOut1_tmp[ 0 ], psDec->sStereo.sMid, 2 * sizeof( opus_int16 ) );
375
224k
        silk_memcpy( psDec->sStereo.sMid, &samplesOut1_tmp[ 0 ][ nSamplesOutDec ], 2 * sizeof( opus_int16 ) );
376
224k
    }
377
378
    /* Number of output samples */
379
304k
    *nSamplesOut = silk_DIV32( nSamplesOutDec * decControl->API_sampleRate, silk_SMULBB( channel_state[ 0 ].fs_kHz, 1000 ) );
380
381
    /* Set up pointers to temp buffers */
382
304k
    ALLOC( samplesOut2_tmp, *nSamplesOut, opus_int16 );
383
304k
    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
689k
    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
384k
        ret += silk_resampler( &channel_state[ n ].resampler_state, resample_out_ptr, &samplesOut1_tmp[ n ][ 1 ], nSamplesOutDec );
423
384k
#endif
424
        /* Interleave if stereo output and stereo stream */
425
384k
        if( decControl->nChannelsAPI == 2 ) {
426
246M
            for( i = 0; i < *nSamplesOut; i++ ) {
427
245M
                samplesOut[ n + 2 * i ] = INT16TORES(resample_out_ptr[ i ]);
428
245M
            }
429
369k
        } else {
430
11.4M
            for( i = 0; i < *nSamplesOut; i++ ) {
431
11.4M
                samplesOut[ i ] = INT16TORES(resample_out_ptr[ i ]);
432
11.4M
            }
433
15.0k
        }
434
384k
    }
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
304k
    if( decControl->nChannelsAPI == 2 && decControl->nChannelsInternal == 1 ) {
442
209k
        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.26k
            ret += silk_resampler( &channel_state[ 1 ].resampler_state, resample_out_ptr, &samplesOut1_tmp[ 0 ][ 1 ], nSamplesOutDec );
446
447
825k
            for( i = 0; i < *nSamplesOut; i++ ) {
448
824k
                samplesOut[ 1 + 2 * i ] = INT16TORES(resample_out_ptr[ i ]);
449
824k
            }
450
208k
        } else {
451
117M
            for( i = 0; i < *nSamplesOut; i++ ) {
452
116M
                samplesOut[ 1 + 2 * i ] = samplesOut[ 0 + 2 * i ];
453
116M
            }
454
208k
        }
455
209k
    }
456
457
    /* Export pitch lag, measured at 48 kHz sampling rate */
458
304k
    if( channel_state[ 0 ].prevSignalType == TYPE_VOICED ) {
459
28.9k
        int mult_tab[ 3 ] = { 6, 4, 3 };
460
28.9k
        decControl->prevPitchLag = channel_state[ 0 ].lagPrev * mult_tab[ ( channel_state[ 0 ].fs_kHz - 8 ) >> 2 ];
461
275k
    } else {
462
275k
        decControl->prevPitchLag = 0;
463
275k
    }
464
465
304k
    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
300k
       for ( i = 0; i < psDec->nChannelsInternal; i++ )
469
166k
          psDec->channel_state[ i ].LastGainIndex = 10;
470
170k
    } else {
471
170k
       psDec->prev_decode_only_middle = decode_only_middle;
472
170k
    }
473
304k
    RESTORE_STACK;
474
304k
    return ret;
475
304k
}
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