mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-03-25 04:19:05 +00:00
dvbsubdec: improve error checking
Use av_mallocz_array instead of iterating and check the returned memory. Check returned memory and cleanly exit in case of error during the loop. Avoid a null pointer dereference for invalid data. CC: libav-stable@libav.org Bug-Id: CID 29575
This commit is contained in:
parent
1bdd21d975
commit
2383323661
@ -1321,12 +1321,13 @@ static int dvbsub_display_end_segment(AVCodecContext *avctx, const uint8_t *buf,
|
||||
}
|
||||
|
||||
sub->num_rects = ctx->display_list_size;
|
||||
if (sub->num_rects <= 0)
|
||||
return AVERROR_INVALIDDATA;
|
||||
|
||||
if (sub->num_rects > 0){
|
||||
sub->rects = av_mallocz(sizeof(*sub->rects) * sub->num_rects);
|
||||
for(i=0; i<sub->num_rects; i++)
|
||||
sub->rects[i] = av_mallocz(sizeof(*sub->rects[i]));
|
||||
}
|
||||
sub->rects = av_mallocz_array(sub->num_rects * sub->num_rects,
|
||||
sizeof(*sub->rects));
|
||||
if (!sub->rects)
|
||||
return AVERROR(ENOMEM);
|
||||
|
||||
i = 0;
|
||||
|
||||
@ -1364,9 +1365,18 @@ static int dvbsub_display_end_segment(AVCodecContext *avctx, const uint8_t *buf,
|
||||
}
|
||||
|
||||
rect->pict.data[1] = av_mallocz(AVPALETTE_SIZE);
|
||||
if (!rect->pict.data[1]) {
|
||||
av_free(sub->rects);
|
||||
return AVERROR(ENOMEM);
|
||||
}
|
||||
memcpy(rect->pict.data[1], clut_table, (1 << region->depth) * sizeof(uint32_t));
|
||||
|
||||
rect->pict.data[0] = av_malloc(region->buf_size);
|
||||
if (!rect->pict.data[0]) {
|
||||
av_free(rect->pict.data[1]);
|
||||
av_free(sub->rects);
|
||||
return AVERROR(ENOMEM);
|
||||
}
|
||||
memcpy(rect->pict.data[0], region->pbuf, region->buf_size);
|
||||
|
||||
i++;
|
||||
|
Loading…
Reference in New Issue
Block a user