Commit 2d518aec authored by Mark Thompson's avatar Mark Thompson

vf_deinterlace_vaapi: Create filter buffer after context

The Intel proprietary VAAPI driver enforces the restriction that a
buffer must be created inside an existing context, so just ensure
this is always true.
parent 17aeee58
...@@ -278,10 +278,6 @@ static int deint_vaapi_config_output(AVFilterLink *outlink) ...@@ -278,10 +278,6 @@ static int deint_vaapi_config_output(AVFilterLink *outlink)
goto fail; goto fail;
} }
err = deint_vaapi_build_filter_params(avctx);
if (err < 0)
goto fail;
ctx->output_frames_ref = av_hwframe_ctx_alloc(ctx->device_ref); ctx->output_frames_ref = av_hwframe_ctx_alloc(ctx->device_ref);
if (!ctx->output_frames_ref) { if (!ctx->output_frames_ref) {
av_log(avctx, AV_LOG_ERROR, "Failed to create HW frame context " av_log(avctx, AV_LOG_ERROR, "Failed to create HW frame context "
...@@ -319,9 +315,14 @@ static int deint_vaapi_config_output(AVFilterLink *outlink) ...@@ -319,9 +315,14 @@ static int deint_vaapi_config_output(AVFilterLink *outlink)
if (vas != VA_STATUS_SUCCESS) { if (vas != VA_STATUS_SUCCESS) {
av_log(avctx, AV_LOG_ERROR, "Failed to create processing pipeline " av_log(avctx, AV_LOG_ERROR, "Failed to create processing pipeline "
"context: %d (%s).\n", vas, vaErrorStr(vas)); "context: %d (%s).\n", vas, vaErrorStr(vas));
return AVERROR(EIO); err = AVERROR(EIO);
goto fail;
} }
err = deint_vaapi_build_filter_params(avctx);
if (err < 0)
goto fail;
outlink->w = ctx->output_width; outlink->w = ctx->output_width;
outlink->h = ctx->output_height; outlink->h = ctx->output_height;
......
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