aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/s302menc.c
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2015-12-19 21:52:19 +0100
committerPaul B Mahol <onemda@gmail.com>2015-12-20 16:05:37 +0100
commitdb6e337b41fce401e67daa2f05fbe0663f825240 (patch)
tree03db1a095c9aec0f2a80c37e2877aefed540f122 /libavcodec/s302menc.c
parent577f05735511066eca48b9a5fff6bf9b75cd65e6 (diff)
downloadffmpeg-db6e337b41fce401e67daa2f05fbe0663f825240.tar.gz
avcodec/s302menc: check if buf_size can actually be put into 16bit size
This disallows creating unplayable audio. Signed-off-by: Paul B Mahol <onemda@gmail.com>
Diffstat (limited to 'libavcodec/s302menc.c')
-rw-r--r--libavcodec/s302menc.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/libavcodec/s302menc.c b/libavcodec/s302menc.c
index 3706eba4e0..c703e9a305 100644
--- a/libavcodec/s302menc.c
+++ b/libavcodec/s302menc.c
@@ -78,6 +78,11 @@ static int s302m_encode2_frame(AVCodecContext *avctx, AVPacket *avpkt,
uint8_t *o;
PutBitContext pb;
+ if (buf_size - AES3_HEADER_LEN > UINT16_MAX) {
+ av_log(avctx, AV_LOG_ERROR, "number of samples in frame too big\n");
+ return AVERROR(EINVAL);
+ }
+
if ((ret = ff_alloc_packet2(avctx, avpkt, buf_size, 0)) < 0)
return ret;