diff options
author | Paul B Mahol <onemda@gmail.com> | 2022-02-10 09:18:36 +0100 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2022-02-10 09:22:36 +0100 |
commit | 9bdb476c40372a2609219e649dcc037ee7c67963 (patch) | |
tree | fd77b4aaea7520d59a3c68ec940ac876be72335b | |
parent | 9809f318ea8812f4185b35d7c5a08899f35e0db0 (diff) | |
download | ffmpeg-9bdb476c40372a2609219e649dcc037ee7c67963.tar.gz |
avfilter/vf_avgblur: fix memory leaks if config_input() is called again
-rw-r--r-- | libavfilter/vf_avgblur.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/libavfilter/vf_avgblur.c b/libavfilter/vf_avgblur.c index e44b9f63c8..bd4471cb8e 100644 --- a/libavfilter/vf_avgblur.c +++ b/libavfilter/vf_avgblur.c @@ -187,12 +187,21 @@ static void build_lut(AVFilterContext *ctx, int max) } } +static av_cold void uninit(AVFilterContext *ctx) +{ + AverageBlurContext *s = ctx->priv; + + av_freep(&s->buffer); +} + static int config_input(AVFilterLink *inlink) { AVFilterContext *ctx = inlink->dst; const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(inlink->format); AverageBlurContext *s = ctx->priv; + uninit(ctx); + s->depth = desc->comp[0].depth; s->max = 1 << s->depth; s->planewidth[1] = s->planewidth[2] = AV_CEIL_RSHIFT(inlink->w, desc->log2_chroma_w); @@ -316,13 +325,6 @@ static int process_command(AVFilterContext *ctx, const char *cmd, const char *ar return 0; } -static av_cold void uninit(AVFilterContext *ctx) -{ - AverageBlurContext *s = ctx->priv; - - av_freep(&s->buffer); -} - static const AVFilterPad avgblur_inputs[] = { { .name = "default", |