summaryrefslogtreecommitdiff
path: root/libavcodec/dvbsubdec.c
diff options
context:
space:
mode:
authorVittorio Giovara <vittorio.giovara@gmail.com>2014-11-09 08:48:44 +0100
committerVittorio Giovara <vittorio.giovara@gmail.com>2014-11-11 11:49:54 +0100
commit2383323661f3b8342b2c4d356fcfe8c5d1b045f8 (patch)
tree62b793c7b2cc36a88992ef596a97231f81d42655 /libavcodec/dvbsubdec.c
parent1bdd21d97528d870fbb4388e837abaf390f2f7d7 (diff)
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
Diffstat (limited to 'libavcodec/dvbsubdec.c')
-rw-r--r--libavcodec/dvbsubdec.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/libavcodec/dvbsubdec.c b/libavcodec/dvbsubdec.c
index a4586ad757..839465b09b 100644
--- a/libavcodec/dvbsubdec.c
+++ b/libavcodec/dvbsubdec.c
@@ -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++;