[vlc-commits] dxva2: picture context cleaning
Steve Lhomme
git at videolan.org
Wed Oct 23 15:21:31 CEST 2019
vlc | branch: master | Steve Lhomme <robux4 at ycbcr.xyz> | Wed Oct 23 15:15:23 2019 +0200| [cdf6cff9f093237ed95f5ac8395c7c475707b631] | committer: Steve Lhomme
dxva2: picture context cleaning
Get the surface pointer directly using the va_surface.
Copy the structures, it's faster than pretending we create one from scratch.
Add a static_assert to make sure the structures we use are always compatible
with the main picture_context structure.
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=cdf6cff9f093237ed95f5ac8395c7c475707b631
---
modules/codec/avcodec/dxva2.c | 15 ++++++++-------
1 file changed, 8 insertions(+), 7 deletions(-)
diff --git a/modules/codec/avcodec/dxva2.c b/modules/codec/avcodec/dxva2.c
index c33b246bd6..0d9520804d 100644
--- a/modules/codec/avcodec/dxva2.c
+++ b/modules/codec/avcodec/dxva2.c
@@ -161,24 +161,25 @@ static void SetupAVCodecContext(void *opaque, AVCodecContext *avctx)
avctx->hwaccel_context = &sys->hw;
}
-static void dxva2_pic_context_destroy(picture_context_t *opaque)
+static void dxva2_pic_context_destroy(picture_context_t *ctx)
{
- struct dxva2_pic_context *pic_ctx = DXVA2_PICCONTEXT_FROM_PICCTX(opaque);
+ struct dxva2_pic_context *pic_ctx = DXVA2_PICCONTEXT_FROM_PICCTX(ctx);
struct vlc_va_surface_t *va_surface = pic_ctx->va_surface;
- d3d9_pic_context_destroy(&pic_ctx->ctx.s);
+ static_assert(offsetof(struct dxva2_pic_context, ctx.s) == 0,
+ "Cast assumption failure");
+ d3d9_pic_context_destroy(ctx);
va_surface_Release(va_surface);
}
-static struct dxva2_pic_context *CreatePicContext(IDirect3DSurface9 *, IDirectXVideoDecoder *);
-
static picture_context_t *dxva2_pic_context_copy(picture_context_t *ctx)
{
struct dxva2_pic_context *src_ctx = DXVA2_PICCONTEXT_FROM_PICCTX(ctx);
- struct dxva2_pic_context *pic_ctx = CreatePicContext(src_ctx->ctx.picsys.surface, src_ctx->ctx.picsys.decoder);
+ struct dxva2_pic_context *pic_ctx = malloc(sizeof(*pic_ctx));
if (unlikely(pic_ctx==NULL))
return NULL;
- pic_ctx->va_surface = src_ctx->va_surface;
+ *pic_ctx = *src_ctx;
va_surface_AddRef(pic_ctx->va_surface);
+ AcquireD3D9PictureSys(&pic_ctx->ctx.picsys);
return &pic_ctx->ctx.s;
}
More information about the vlc-commits
mailing list