mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-03-28 12:32:17 +02:00
avcodec/dpx: Check bits_per_color earlier
Fixes: shift exponent 251 is too large for 32-bit type 'int' Fixes: 32147/clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_DPX_fuzzer-5519111675314176 Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/projects/ffmpeg Signed-off-by: Michael Niedermayer <michael@niedermayer.cc> (cherry picked from commit c093eb30311b7148a4da1c7555498187c8cdf0db) Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
b2a94f5937
commit
b3f458f89f
@ -242,6 +242,9 @@ static int decode_frame(AVCodecContext *avctx,
|
|||||||
return AVERROR_PATCHWELCOME;
|
return AVERROR_PATCHWELCOME;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (bits_per_color > 32)
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
|
||||||
buf += 820;
|
buf += 820;
|
||||||
avctx->sample_aspect_ratio.num = read32(&buf, endian);
|
avctx->sample_aspect_ratio.num = read32(&buf, endian);
|
||||||
avctx->sample_aspect_ratio.den = read32(&buf, endian);
|
avctx->sample_aspect_ratio.den = read32(&buf, endian);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user