[FFmpeg-cvslog] avcodec/jpeglsenc: Check for invalid dimensions
Andreas Rheinhardt
git at videolan.org
Sun May 16 01:59:04 EEST 2021
ffmpeg | branch: master | Andreas Rheinhardt <andreas.rheinhardt at outlook.com> | Thu Apr 29 13:38:16 2021 +0200| [79402e2c36301fb0ecb1ff797a8de7f79b178c70] | committer: Andreas Rheinhardt
avcodec/jpeglsenc: Check for invalid dimensions
The dimensions are written on two bytes.
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at outlook.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=79402e2c36301fb0ecb1ff797a8de7f79b178c70
---
libavcodec/jpeglsenc.c | 10 ++++++++++
1 file changed, 10 insertions(+)
diff --git a/libavcodec/jpeglsenc.c b/libavcodec/jpeglsenc.c
index 3e73b04c0e..15d9204b1d 100644
--- a/libavcodec/jpeglsenc.c
+++ b/libavcodec/jpeglsenc.c
@@ -413,6 +413,15 @@ static int encode_picture_ls(AVCodecContext *avctx, AVPacket *pkt,
return 0;
}
+static av_cold int encode_jpegls_init(AVCodecContext *avctx)
+{
+ if ((avctx->width | avctx->height) > UINT16_MAX) {
+ av_log(avctx, AV_LOG_ERROR, "Dimensions exceeding 65535x65535\n");
+ return AVERROR(EINVAL);
+ }
+ return 0;
+}
+
#define OFFSET(x) offsetof(JPEGLSContext, x)
#define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
static const AVOption options[] = {
@@ -439,6 +448,7 @@ const AVCodec ff_jpegls_encoder = {
.priv_data_size = sizeof(JPEGLSContext),
.priv_class = &jpegls_class,
.capabilities = AV_CODEC_CAP_FRAME_THREADS,
+ .init = encode_jpegls_init,
.encode2 = encode_picture_ls,
.pix_fmts = (const enum AVPixelFormat[]) {
AV_PIX_FMT_BGR24, AV_PIX_FMT_RGB24,
More information about the ffmpeg-cvslog
mailing list