[vlc-commits] directx_va: the context copy is responsible for the va_surface refcount increment

Steve Lhomme git at videolan.org
Thu Jun 22 17:27:03 CEST 2017


vlc | branch: master | Steve Lhomme <robux4 at videolabs.io> | Mon Jun 19 14:20:36 2017 +0200| [056eca0813368c3afa08360b903b9173742acf8a] | committer: Jean-Baptiste Kempf

directx_va: the context copy is responsible for the va_surface refcount increment

Signed-off-by: Jean-Baptiste Kempf <jb at videolan.org>

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=056eca0813368c3afa08360b903b9173742acf8a
---

 modules/codec/avcodec/d3d11va.c    | 18 ++++++++++--------
 modules/codec/avcodec/dxva2.c      | 15 +++++++++------
 modules/codec/avcodec/va_surface.c | 20 +++++++++++---------
 3 files changed, 30 insertions(+), 23 deletions(-)

diff --git a/modules/codec/avcodec/d3d11va.c b/modules/codec/avcodec/d3d11va.c
index 73c45955d1..6a25975548 100644
--- a/modules/codec/avcodec/d3d11va.c
+++ b/modules/codec/avcodec/d3d11va.c
@@ -177,7 +177,7 @@ static int Extract(vlc_va_t *va, picture_t *output, uint8_t *data)
 {
     VLC_UNUSED(va); VLC_UNUSED(data);
     struct va_pic_context *pic_ctx = (struct va_pic_context*)output->context;
-    if (!va->sys->b_extern_pool)
+    if (pic_ctx->va_surface)
         va_surface_AddRef(pic_ctx->va_surface);
     assert(data == (void*)pic_ctx->picsys.decoder);
     return VLC_SUCCESS;
@@ -192,8 +192,7 @@ static void d3d11_pic_context_destroy(struct picture_context_t *opaque)
     free(pic_ctx);
 }
 
-static struct va_pic_context *CreatePicContext(vlc_va_surface_t *,
-                                               ID3D11VideoDecoderOutputView *,
+static struct va_pic_context *CreatePicContext(ID3D11VideoDecoderOutputView *,
                                                ID3D11Resource *,
                                                ID3D11DeviceContext *,
                                                UINT slice,
@@ -202,15 +201,19 @@ static struct va_pic_context *CreatePicContext(vlc_va_surface_t *,
 static struct picture_context_t *d3d11_pic_context_copy(struct picture_context_t *ctx)
 {
     struct va_pic_context *src_ctx = (struct va_pic_context*)ctx;
-    struct va_pic_context *pic_ctx = CreatePicContext(src_ctx->va_surface, src_ctx->picsys.decoder,
+    struct va_pic_context *pic_ctx = CreatePicContext(src_ctx->picsys.decoder,
                                                       src_ctx->picsys.resource[0], src_ctx->picsys.context,
                                                       src_ctx->picsys.slice_index, src_ctx->picsys.resourceView);
     if (unlikely(pic_ctx==NULL))
         return NULL;
+    if (src_ctx->va_surface) {
+        pic_ctx->va_surface = src_ctx->va_surface;
+        va_surface_AddRef(pic_ctx->va_surface);
+    }
     return &pic_ctx->s;
 }
 
-static struct va_pic_context *CreatePicContext(vlc_va_surface_t *va_surface,
+static struct va_pic_context *CreatePicContext(
                                                   ID3D11VideoDecoderOutputView *decoderSurface,
                                                   ID3D11Resource *p_resource,
                                                   ID3D11DeviceContext *context,
@@ -222,7 +225,6 @@ static struct va_pic_context *CreatePicContext(vlc_va_surface_t *va_surface,
         goto done;
     pic_ctx->s.destroy = d3d11_pic_context_destroy;
     pic_ctx->s.copy    = d3d11_pic_context_copy;
-    pic_ctx->va_surface = va_surface;
     pic_ctx->picsys.context = context;
     pic_ctx->picsys.slice_index = slice;
     pic_ctx->picsys.decoder = decoderSurface;
@@ -249,7 +251,7 @@ static struct va_pic_context* NewSurfacePicContext(vlc_va_t *va, ID3D11VideoDeco
     for (int i=0; i<D3D11_MAX_SHADER_VIEW; i++)
         resourceView[i] = va->sys->resourceView[viewDesc.Texture2D.ArraySlice*D3D11_MAX_SHADER_VIEW + i];
 
-    struct va_pic_context *pic_ctx = CreatePicContext(NULL,
+    struct va_pic_context *pic_ctx = CreatePicContext(
                                                   surface,
                                                   p_resource,
                                                   va->sys->d3dctx,
@@ -291,7 +293,7 @@ static int Get(vlc_va_t *va, picture_t *pic, uint8_t **data)
                     return VLC_EGENERIC;
             }
 
-            pic->context = (picture_context_t*)CreatePicContext( NULL,
+            pic->context = (picture_context_t*)CreatePicContext(
                                              pic->p_sys->decoder,
                                              pic->p_sys->resource[KNOWN_DXGI_INDEX],
                                              va->sys->d3dctx,
diff --git a/modules/codec/avcodec/dxva2.c b/modules/codec/avcodec/dxva2.c
index 6efd1a788a..5b002ed752 100644
--- a/modules/codec/avcodec/dxva2.c
+++ b/modules/codec/avcodec/dxva2.c
@@ -193,21 +193,24 @@ static void d3d9_pic_context_destroy(struct picture_context_t *opaque)
     }
 }
 
-static struct va_pic_context *CreatePicContext(vlc_va_surface_t *, IDirect3DSurface9 *);
+static struct va_pic_context *CreatePicContext(IDirect3DSurface9 *);
 
 static struct picture_context_t *d3d9_pic_context_copy(struct picture_context_t *ctx)
 {
     struct va_pic_context *src_ctx = (struct va_pic_context*)ctx;
-    return (picture_context_t*)CreatePicContext(src_ctx->va_surface, src_ctx->picsys.surface);
+    struct va_pic_context *pic_ctx = CreatePicContext(src_ctx->picsys.surface);
+    if (unlikely(pic_ctx==NULL))
+        return NULL;
+    pic_ctx->va_surface = src_ctx->va_surface;
+    va_surface_AddRef(pic_ctx->va_surface);
+    return &pic_ctx->s;
 }
 
-static struct va_pic_context *CreatePicContext(vlc_va_surface_t *va_surface, IDirect3DSurface9 *surface)
+static struct va_pic_context *CreatePicContext(IDirect3DSurface9 *surface)
 {
     struct va_pic_context *pic_ctx = calloc(1, sizeof(*pic_ctx));
     if (unlikely(pic_ctx==NULL))
         return NULL;
-    pic_ctx->va_surface = va_surface;
-    va_surface_AddRef(pic_ctx->va_surface);
     pic_ctx->s.destroy = d3d9_pic_context_destroy;
     pic_ctx->s.copy    = d3d9_pic_context_copy;
     pic_ctx->picsys.surface = surface;
@@ -218,7 +221,7 @@ static struct va_pic_context *CreatePicContext(vlc_va_surface_t *va_surface, IDi
 static struct va_pic_context* NewSurfacePicContext(vlc_va_t *va, IDirect3DSurface9 *surface)
 {
     VLC_UNUSED(va);
-    return CreatePicContext(NULL, surface);
+    return CreatePicContext(surface);
 }
 
 static int Get(vlc_va_t *va, picture_t *pic, uint8_t **data)
diff --git a/modules/codec/avcodec/va_surface.c b/modules/codec/avcodec/va_surface.c
index 9d2bd9175e..5bd7176f92 100644
--- a/modules/codec/avcodec/va_surface.c
+++ b/modules/codec/avcodec/va_surface.c
@@ -95,11 +95,17 @@ int va_pool_Setup(vlc_va_t *va, va_pool_t *va_pool, const AVCodecContext *avctx,
         return VLC_EGENERIC;
 
     for (i = 0; i < count; i++) {
-        struct va_pic_context *p_ctx = va_pool->pf_new_surface_context(va, va_pool->hw_surface[i]);
-        if (unlikely(p_ctx==NULL))
+        struct vlc_va_surface_t *p_surface = malloc(sizeof(*p_surface));
+        if (unlikely(p_surface==NULL))
             goto done;
-        atomic_init(&p_ctx->va_surface->refcount, 1);
-        va_pool->surface[i] = p_ctx;
+        va_pool->surface[i] = va_pool->pf_new_surface_context(va, va_pool->hw_surface[i]);
+        if (unlikely(va_pool->surface[i]==NULL))
+        {
+            free(p_surface);
+            goto done;
+        }
+        va_pool->surface[i]->va_surface = p_surface;
+        atomic_init(&va_pool->surface[i]->va_surface->refcount, 1);
     }
 
     va_pool->surface_width  = surface_width;
@@ -122,11 +128,7 @@ static picture_context_t *GetSurface(va_pool_t *va_pool)
         if (atomic_compare_exchange_strong(&surface->va_surface->refcount, &expected, 2))
         {
             picture_context_t *field = surface->s.copy(&surface->s);
-            if (!field)
-            {
-                atomic_fetch_sub(&surface->va_surface->refcount, 1);
-                continue;
-            }
+            atomic_fetch_sub(&surface->va_surface->refcount, 1);
             return field;
         }
     }



More information about the vlc-commits mailing list