You've already forked FFmpeg
mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-08-15 14:13:16 +02:00
avformat/asfdec_o: Check size_bmp more fully
Fixes: integer overflow and out of array access Fixes: asfo-crash-46080c4341572a7137a162331af77f6ded45cbd7 Found-by: Paul Ch <paulcher@icloud.com> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
@@ -706,7 +706,8 @@ static int parse_video_info(AVIOContext *pb, AVStream *st)
|
|||||||
st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags, tag);
|
st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags, tag);
|
||||||
size_bmp = FFMAX(size_asf, size_bmp);
|
size_bmp = FFMAX(size_asf, size_bmp);
|
||||||
|
|
||||||
if (size_bmp > BMP_HEADER_SIZE) {
|
if (size_bmp > BMP_HEADER_SIZE &&
|
||||||
|
size_bmp < INT_MAX - AV_INPUT_BUFFER_PADDING_SIZE) {
|
||||||
int ret;
|
int ret;
|
||||||
st->codecpar->extradata_size = size_bmp - BMP_HEADER_SIZE;
|
st->codecpar->extradata_size = size_bmp - BMP_HEADER_SIZE;
|
||||||
if (!(st->codecpar->extradata = av_malloc(st->codecpar->extradata_size +
|
if (!(st->codecpar->extradata = av_malloc(st->codecpar->extradata_size +
|
||||||
|
Reference in New Issue
Block a user