Also check output buffer size instead of truncating output.
---
libavcodec/dsicinav.c | 25 ++++++++++++++-----------
1 files changed, 14 insertions(+), 11 deletions(-)
diff --git a/libavcodec/dsicinav.c b/libavcodec/dsicinav.c
index 245b569..a6a4ff1 100644
--- a/libavcodec/dsicinav.c
+++ b/libavcodec/dsicinav.c
@@ -324,32 +324,35 @@ static int cinaudio_decode_frame(AVCodecContext *avctx,
AVPacket *avpkt)
{
const uint8_t *buf = avpkt->data;
- int buf_size = avpkt->size;
CinAudioContext *cin = avctx->priv_data;
- const uint8_t *src = buf;
+ const uint8_t *buf_end = buf + avpkt->size;
int16_t *samples = data;
- int delta;
+ int delta, out_size;
- buf_size = FFMIN(buf_size, *data_size/2);
+ out_size = (avpkt->size - cin->initial_decode_frame) *
+ av_get_bytes_per_sample(avctx->sample_fmt);
+ if (*data_size < out_size) {
+ av_log(avctx, AV_LOG_ERROR, "Output buffer is too small\n");
+ return AVERROR(EINVAL);
+ }
delta = cin->delta;
if (cin->initial_decode_frame) {
cin->initial_decode_frame = 0;
- delta = (int16_t)AV_RL16(src); src += 2;
+ delta = (int16_t)AV_RL16(buf);
+ buf += 2;
*samples++ = delta;
- buf_size -= 2;
}
- while (buf_size > 0) {
- delta += cinaudio_delta16_table[*src++];
+ while (buf < buf_end) {
+ delta += cinaudio_delta16_table[*buf++];
delta = av_clip_int16(delta);
*samples++ = delta;
- --buf_size;
}
cin->delta = delta;
- *data_size = (uint8_t *)samples - (uint8_t *)data;
+ *data_size = out_size;
- return src - buf;
+ return avpkt->size;
}
--
1.7.1
_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel