summaryrefslogtreecommitdiffstats
path: root/video/decode/vd_lavc.c
diff options
context:
space:
mode:
authorwm4 <wm4@nowhere>2017-12-01 06:47:37 +0100
committerwm4 <wm4@nowhere>2017-12-01 08:01:41 +0100
commitc5fac0c2b048b695bf217ae77530269605eebfb9 (patch)
treee2ce5d58346a93173b1e1ee4d1fda152261a54b8 /video/decode/vd_lavc.c
parent643a1fc7de84b234d5a4723fa0ec31f9351e770b (diff)
downloadmpv-c5fac0c2b048b695bf217ae77530269605eebfb9.tar.bz2
mpv-c5fac0c2b048b695bf217ae77530269605eebfb9.tar.xz
vd_lavc: move entrypoint for hwframes_refine
The idea is to get rid of vd_lavc_hwdec, so special functionality like this has to go somewhere else. At this point, hwframes_refine is only needed for d3d11, and it doesn't do much, so for now the new callback has no context. In can be made more fancy if really needed.
Diffstat (limited to 'video/decode/vd_lavc.c')
-rw-r--r--video/decode/vd_lavc.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/video/decode/vd_lavc.c b/video/decode/vd_lavc.c
index 5b5a7c47fb..90217f5b8d 100644
--- a/video/decode/vd_lavc.c
+++ b/video/decode/vd_lavc.c
@@ -754,8 +754,11 @@ static int init_generic_hwaccel(struct dec_video *vd, enum AVPixelFormat hw_fmt)
if (new_fctx->initial_pool_size)
new_fctx->initial_pool_size += HWDEC_EXTRA_SURFACES - 1;
- if (ctx->hwdec->hwframes_refine)
- ctx->hwdec->hwframes_refine(ctx, new_frames_ctx);
+ const struct hwcontext_fns *fns =
+ hwdec_get_hwcontext_fns(new_fctx->device_ctx->type);
+
+ if (fns && fns->refine_hwframes)
+ fns->refine_hwframes(new_frames_ctx);
// We might be able to reuse a previously allocated frame pool.
if (ctx->cached_hw_frames_ctx) {