diff --git a/src/opus_decoder.c b/src/opus_decoder.c index 483d918ed6b747d0fc070e19034c7230fce6b435..9113638a000bab2a01977b81c8fd7fb03281750d 100644 --- a/src/opus_decoder.c +++ b/src/opus_decoder.c @@ -769,6 +769,7 @@ int opus_decode_float(OpusDecoder *st, const unsigned char *data, else return OPUS_INVALID_PACKET; } + celt_assert(st->channels == 1 || st->channels == 2); ALLOC(out, frame_size*st->channels, opus_int16); ret = opus_decode_native(st, data, len, out, frame_size, decode_fec, 0, NULL, 0); @@ -806,6 +807,7 @@ int opus_decode(OpusDecoder *st, const unsigned char *data, else return OPUS_INVALID_PACKET; } + celt_assert(st->channels == 1 || st->channels == 2); ALLOC(out, frame_size*st->channels, float); ret = opus_decode_native(st, data, len, out, frame_size, decode_fec, 0, NULL, 1); diff --git a/src/opus_multistream_decoder.c b/src/opus_multistream_decoder.c index 39699fd025b8c6b7cd1bcde1bed72024b8581bf0..f767ea0ded9482e687f64a1b3adcb83b713edfc8 100644 --- a/src/opus_multistream_decoder.c +++ b/src/opus_multistream_decoder.c @@ -202,7 +202,7 @@ int opus_multistream_decode_native( VALIDATE_MS_DECODER(st); /* Limit frame_size to avoid excessive stack allocations. */ - opus_multistream_decoder_ctl(st, OPUS_GET_SAMPLE_RATE(&Fs)); + MUST_SUCCEED(opus_multistream_decoder_ctl(st, OPUS_GET_SAMPLE_RATE(&Fs))); frame_size = IMIN(frame_size, Fs/25*3); ALLOC(buf, 2*frame_size, opus_val16); ptr = (char*)st + align(sizeof(OpusMSDecoder));