diff --git a/src/opus_decoder.c b/src/opus_decoder.c index 5b56ac1f..ee0c9f56 100644 --- a/src/opus_decoder.c +++ b/src/opus_decoder.c @@ -355,7 +355,7 @@ static int opus_decode_frame(OpusDecoder *st, const unsigned char *data, pcm_ptr[i] = 0; } else { RESTORE_STACK; - return OPUS_INVALID_PACKET; + return OPUS_INTERNAL_ERROR; } } pcm_ptr += silk_frame_size * st->channels; @@ -581,7 +581,7 @@ static int parse_size(const unsigned char *data, opus_int32 len, opus_int16 *siz } } -static int opus_packet_parse_impl(const unsigned char *data, opus_int32 len, +int opus_packet_parse_impl(const unsigned char *data, opus_int32 len, int self_delimited, unsigned char *out_toc, const unsigned char *frames[48], opus_int16 size[48], int *payload_offset) { @@ -710,6 +710,9 @@ static int opus_packet_parse_impl(const unsigned char *data, opus_int32 len, size[count-1] = (opus_int16)last_size; } + if (payload_offset) + *payload_offset = (int)(data-data0); + if (frames) { for (i=0;i frame_size) return OPUS_BUFFER_TOO_SMALL; diff --git a/src/opus_multistream_decoder.c b/src/opus_multistream_decoder.c index f3d2311e..d04a99f3 100644 --- a/src/opus_multistream_decoder.c +++ b/src/opus_multistream_decoder.c @@ -152,6 +152,37 @@ typedef void (*opus_copy_channel_out_func)( int frame_size ); +static int opus_multistream_packet_validate(const unsigned char *data, + opus_int32 len, int nb_streams) +{ + int s; + int i; + int count; + unsigned char toc; + opus_int16 size[48]; + int offset; + int samples=0; + + for (s=0;slayout.nb_streams-1) + { + RESTORE_STACK; return OPUS_INVALID_PACKET; + } + if (!do_plc) + { + int ret = opus_multistream_packet_validate(data, len, st->layout.nb_coupled_streams); + if (ret < 0) + { + RESTORE_STACK; + return ret; + } + } for (s=0;slayout.nb_streams;s++) { OpusDecoder *dec; diff --git a/src/opus_private.h b/src/opus_private.h index 0e739ebb..aaf3cbf1 100644 --- a/src/opus_private.h +++ b/src/opus_private.h @@ -112,6 +112,10 @@ static inline int align(int i) return (i+(int)sizeof(void *)-1)&-(int)sizeof(void *); } +int opus_packet_parse_impl(const unsigned char *data, opus_int32 len, + int self_delimited, unsigned char *out_toc, + const unsigned char *frames[48], opus_int16 size[48], int *payload_offset); + opus_int32 opus_repacketizer_out_range_impl(OpusRepacketizer *rp, int begin, int end, unsigned char *data, opus_int32 maxlen, int self_delimited); #endif /* OPUS_PRIVATE_H */