mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-28 20:53:54 +02:00
avcodec/iff: Over-allocate ham_palbuf for HAM6 IFF-PBM
IFF-PBM-HAM6 can read out of array without this overallocation
Fixes: Out of array read
Fixes: 19752/clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_IFF_ILBM_fuzzer-5675331403120640
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 8652f4e7a1
)
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
e1bea6d412
commit
57278dac15
@ -332,13 +332,17 @@ static int extract_header(AVCodecContext *const avctx,
|
|||||||
int i, count = FFMIN(palette_size / 3, 1 << s->ham);
|
int i, count = FFMIN(palette_size / 3, 1 << s->ham);
|
||||||
int ham_count;
|
int ham_count;
|
||||||
const uint8_t *const palette = avctx->extradata + AV_RB16(avctx->extradata);
|
const uint8_t *const palette = avctx->extradata + AV_RB16(avctx->extradata);
|
||||||
|
int extra_space = 1;
|
||||||
|
|
||||||
|
if (avctx->codec_tag == MKTAG('P', 'B', 'M', ' ') && s->ham == 4)
|
||||||
|
extra_space = 4;
|
||||||
|
|
||||||
s->ham_buf = av_malloc((s->planesize * 8) + AV_INPUT_BUFFER_PADDING_SIZE);
|
s->ham_buf = av_malloc((s->planesize * 8) + AV_INPUT_BUFFER_PADDING_SIZE);
|
||||||
if (!s->ham_buf)
|
if (!s->ham_buf)
|
||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
ham_count = 8 * (1 << s->ham);
|
ham_count = 8 * (1 << s->ham);
|
||||||
s->ham_palbuf = av_malloc((ham_count << !!(s->masking == MASK_HAS_MASK)) * sizeof (uint32_t) + AV_INPUT_BUFFER_PADDING_SIZE);
|
s->ham_palbuf = av_malloc(extra_space * (ham_count << !!(s->masking == MASK_HAS_MASK)) * sizeof (uint32_t) + AV_INPUT_BUFFER_PADDING_SIZE);
|
||||||
if (!s->ham_palbuf) {
|
if (!s->ham_palbuf) {
|
||||||
av_freep(&s->ham_buf);
|
av_freep(&s->ham_buf);
|
||||||
return AVERROR(ENOMEM);
|
return AVERROR(ENOMEM);
|
||||||
|
Loading…
Reference in New Issue
Block a user