Commit 301c2784 authored by Ganesh Ajjanagadde's avatar Ganesh Ajjanagadde

lavfi/vf_overlay: fix memory leaks

Recent commits 6aaac24d and
3835554b made progress towards cleaning
up usage of the formats API, and in particular fixed possible NULL pointer
dereferences.

This commit addresses the issue of possible resource leaks when some intermediate
call fails.

Tested with valgrind --leak-check=full --show-leak-kinds=all, and manual simulation
of malloc/realloc failures.

Fixes: CID 1338327.
Signed-off-by: 's avatarGanesh Ajjanagadde <gajjanagadde@gmail.com>
parent 00c32201
...@@ -252,23 +252,31 @@ static int query_formats(AVFilterContext *ctx) ...@@ -252,23 +252,31 @@ static int query_formats(AVFilterContext *ctx)
switch (s->format) { switch (s->format) {
case OVERLAY_FORMAT_YUV420: case OVERLAY_FORMAT_YUV420:
if (!(main_formats = ff_make_format_list(main_pix_fmts_yuv420)) || if (!(main_formats = ff_make_format_list(main_pix_fmts_yuv420)) ||
!(overlay_formats = ff_make_format_list(overlay_pix_fmts_yuv420))) !(overlay_formats = ff_make_format_list(overlay_pix_fmts_yuv420))) {
return AVERROR(ENOMEM); ret = AVERROR(ENOMEM);
goto fail;
}
break; break;
case OVERLAY_FORMAT_YUV422: case OVERLAY_FORMAT_YUV422:
if (!(main_formats = ff_make_format_list(main_pix_fmts_yuv422)) || if (!(main_formats = ff_make_format_list(main_pix_fmts_yuv422)) ||
!(overlay_formats = ff_make_format_list(overlay_pix_fmts_yuv422))) !(overlay_formats = ff_make_format_list(overlay_pix_fmts_yuv422))) {
return AVERROR(ENOMEM); ret = AVERROR(ENOMEM);
goto fail;
}
break; break;
case OVERLAY_FORMAT_YUV444: case OVERLAY_FORMAT_YUV444:
if (!(main_formats = ff_make_format_list(main_pix_fmts_yuv444)) || if (!(main_formats = ff_make_format_list(main_pix_fmts_yuv444)) ||
!(overlay_formats = ff_make_format_list(overlay_pix_fmts_yuv444))) !(overlay_formats = ff_make_format_list(overlay_pix_fmts_yuv444))) {
return AVERROR(ENOMEM); ret = AVERROR(ENOMEM);
goto fail;
}
break; break;
case OVERLAY_FORMAT_RGB: case OVERLAY_FORMAT_RGB:
if (!(main_formats = ff_make_format_list(main_pix_fmts_rgb)) || if (!(main_formats = ff_make_format_list(main_pix_fmts_rgb)) ||
!(overlay_formats = ff_make_format_list(overlay_pix_fmts_rgb))) !(overlay_formats = ff_make_format_list(overlay_pix_fmts_rgb))) {
return AVERROR(ENOMEM); ret = AVERROR(ENOMEM);
goto fail;
}
break; break;
default: default:
av_assert0(0); av_assert0(0);
...@@ -277,9 +285,17 @@ static int query_formats(AVFilterContext *ctx) ...@@ -277,9 +285,17 @@ static int query_formats(AVFilterContext *ctx)
if ((ret = ff_formats_ref(main_formats , &ctx->inputs[MAIN]->out_formats )) < 0 || if ((ret = ff_formats_ref(main_formats , &ctx->inputs[MAIN]->out_formats )) < 0 ||
(ret = ff_formats_ref(overlay_formats, &ctx->inputs[OVERLAY]->out_formats)) < 0 || (ret = ff_formats_ref(overlay_formats, &ctx->inputs[OVERLAY]->out_formats)) < 0 ||
(ret = ff_formats_ref(main_formats , &ctx->outputs[MAIN]->in_formats )) < 0) (ret = ff_formats_ref(main_formats , &ctx->outputs[MAIN]->in_formats )) < 0)
return ret; goto fail;
return 0; return 0;
fail:
if (main_formats)
av_freep(&main_formats->formats);
av_freep(&main_formats);
if (overlay_formats)
av_freep(&overlay_formats->formats);
av_freep(&overlay_formats);
return ret;
} }
static const enum AVPixelFormat alpha_pix_fmts[] = { static const enum AVPixelFormat alpha_pix_fmts[] = {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment