Commit 03179c24 authored by Clément Bœsch's avatar Clément Bœsch

lavfi/smartblur: add missing draw slice call.

This fixes output with filtergraphs such as 'split[a][b];
[a]pad=iw*2[src]; [b]smartblur=1:1:1[filt]; [src][filt]overlay=w'
parent 5cac0656
...@@ -248,9 +248,11 @@ static void blur(uint8_t *dst, const int dst_linesize, ...@@ -248,9 +248,11 @@ static void blur(uint8_t *dst, const int dst_linesize,
static int end_frame(AVFilterLink *inlink) static int end_frame(AVFilterLink *inlink)
{ {
int ret;
SmartblurContext *sblur = inlink->dst->priv; SmartblurContext *sblur = inlink->dst->priv;
AVFilterBufferRef *inpic = inlink->cur_buf; AVFilterBufferRef *inpic = inlink->cur_buf;
AVFilterBufferRef *outpic = inlink->dst->outputs[0]->out_buf; AVFilterLink *outlink = inlink->dst->outputs[0];
AVFilterBufferRef *outpic = outlink->out_buf;
int cw = inlink->w >> sblur->hsub; int cw = inlink->w >> sblur->hsub;
int ch = inlink->h >> sblur->vsub; int ch = inlink->h >> sblur->vsub;
...@@ -270,7 +272,9 @@ static int end_frame(AVFilterLink *inlink) ...@@ -270,7 +272,9 @@ static int end_frame(AVFilterLink *inlink)
sblur->chroma.filter_context); sblur->chroma.filter_context);
} }
return ff_end_frame(inlink->dst->outputs[0]); if ((ret = ff_draw_slice(outlink, 0, outlink->h, 1)) < 0)
return ret;
return ff_end_frame(outlink);
} }
AVFilter avfilter_vf_smartblur = { AVFilter avfilter_vf_smartblur = {
......
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