Commit 6c583e90 authored by Michael Niedermayer's avatar Michael Niedermayer

avcodec/opusdec: Fix delayed sample value

Fixes out of array access
Fixes: ffmpeg_opus_crash1.ogg

This solution is likely not optimal in terms of error concealment but
its simple and fixes the out of array access.
Found-by: 's avatarThomas Lindroth <thomas.lindroth@gmail.com>
Tested-by: 's avatarThomas Lindroth <thomas.lindroth@gmail.com>
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 1ae09258
...@@ -449,11 +449,13 @@ static int opus_decode_packet(AVCodecContext *avctx, void *data, ...@@ -449,11 +449,13 @@ static int opus_decode_packet(AVCodecContext *avctx, void *data,
int coded_samples = 0; int coded_samples = 0;
int decoded_samples = 0; int decoded_samples = 0;
int i, ret; int i, ret;
int delayed_samples = 0;
for (i = 0; i < c->nb_streams; i++) { for (i = 0; i < c->nb_streams; i++) {
OpusStreamContext *s = &c->streams[i]; OpusStreamContext *s = &c->streams[i];
s->out[0] = s->out[0] =
s->out[1] = NULL; s->out[1] = NULL;
delayed_samples = FFMAX(delayed_samples, s->delayed_samples);
} }
/* decode the header of the first sub-packet to find out the sample count */ /* decode the header of the first sub-packet to find out the sample count */
...@@ -468,7 +470,7 @@ static int opus_decode_packet(AVCodecContext *avctx, void *data, ...@@ -468,7 +470,7 @@ static int opus_decode_packet(AVCodecContext *avctx, void *data,
c->streams[0].silk_samplerate = get_silk_samplerate(pkt->config); c->streams[0].silk_samplerate = get_silk_samplerate(pkt->config);
} }
frame->nb_samples = coded_samples + c->streams[0].delayed_samples; frame->nb_samples = coded_samples + delayed_samples;
/* no input or buffered data => nothing to do */ /* no input or buffered data => nothing to do */
if (!frame->nb_samples) { if (!frame->nb_samples) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment