[FFmpeg-cvslog] avfilter/drawutils: Check for av_malloc* failures
Michael Niedermayer
git at videolan.org
Thu Jan 22 15:30:35 CET 2015
ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Thu Jan 22 13:54:26 2015 +0100| [f77571f6bb5a252e09fc47049b0c61cc11559fad] | committer: Michael Niedermayer
avfilter/drawutils: Check for av_malloc* failures
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=f77571f6bb5a252e09fc47049b0c61cc11559fad
---
libavfilter/drawutils.c | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/libavfilter/drawutils.c b/libavfilter/drawutils.c
index ac30db2..0b2f17e 100644
--- a/libavfilter/drawutils.c
+++ b/libavfilter/drawutils.c
@@ -76,6 +76,8 @@ int ff_fill_line_with_color(uint8_t *line[4], int pixel_step[4], int w, uint8_t
dst_color[rgba_map[i]] = rgba_color[i];
line[0] = av_malloc_array(w, pixel_step[0]);
+ if (!line[0])
+ return AVERROR(ENOMEM);
for (i = 0; i < w; i++)
memcpy(line[0] + i * pixel_step[0], dst_color, pixel_step[0]);
if (rgba_map_ptr)
@@ -95,6 +97,11 @@ int ff_fill_line_with_color(uint8_t *line[4], int pixel_step[4], int w, uint8_t
pixel_step[plane] = 1;
line_size = FF_CEIL_RSHIFT(w, hsub1) * pixel_step[plane];
line[plane] = av_malloc(line_size);
+ if (!line[plane]) {
+ while(plane && line[plane-1])
+ av_freep(&line[--plane]);
+ return AVERROR(ENOMEM);
+ }
memset(line[plane], dst_color[plane], line_size);
}
}
More information about the ffmpeg-cvslog
mailing list