Commit 15b2c37d authored by Michael Niedermayer's avatar Michael Niedermayer

avfilter/vf_deshake: Free out AVFrame on error

Fixes memleak
Fixes part of CID1197065
Signed-off-by: 's avatarMichael Niedermayer <michael@niedermayer.cc>
parent 3edbc240
...@@ -450,7 +450,7 @@ static int filter_frame(AVFilterLink *link, AVFrame *in) ...@@ -450,7 +450,7 @@ static int filter_frame(AVFilterLink *link, AVFrame *in)
if (CONFIG_OPENCL && deshake->opencl) { if (CONFIG_OPENCL && deshake->opencl) {
ret = ff_opencl_deshake_process_inout_buf(link->dst,in, out); ret = ff_opencl_deshake_process_inout_buf(link->dst,in, out);
if (ret < 0) if (ret < 0)
return ret; goto fail;
} }
if (deshake->cx < 0 || deshake->cy < 0 || deshake->cw < 0 || deshake->ch < 0) { if (deshake->cx < 0 || deshake->cy < 0 || deshake->cw < 0 || deshake->ch < 0) {
...@@ -536,13 +536,16 @@ static int filter_frame(AVFilterLink *link, AVFrame *in) ...@@ -536,13 +536,16 @@ static int filter_frame(AVFilterLink *link, AVFrame *in)
av_frame_free(&deshake->ref); av_frame_free(&deshake->ref);
if (ret < 0) if (ret < 0)
return ret; goto fail;
// Store the current frame as the reference frame for calculating the // Store the current frame as the reference frame for calculating the
// motion of the next frame // motion of the next frame
deshake->ref = in; deshake->ref = in;
return ff_filter_frame(outlink, out); return ff_filter_frame(outlink, out);
fail:
av_frame_free(&out);
return ret;
} }
static const AVFilterPad deshake_inputs[] = { static const AVFilterPad deshake_inputs[] = {
......
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