vlc | branch: master | Steve Lhomme <[email protected]> | Mon May 22 13:22:31 
2017 +0200| [570c797ebf0e0ac8273c2da7a51ba7d316ce62a4] | committer: 
Jean-Baptiste Kempf

directx_va: add a way to lock/unlock a surface

The surface may not be used by the decoder but still being used for 
display/filter.

Signed-off-by: Jean-Baptiste Kempf <[email protected]>

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

 modules/codec/avcodec/directx_va.c | 7 +++++++
 modules/codec/avcodec/directx_va.h | 1 +
 2 files changed, 8 insertions(+)

diff --git a/modules/codec/avcodec/directx_va.c 
b/modules/codec/avcodec/directx_va.c
index 664e686d39..4c86ad10a5 100644
--- a/modules/codec/avcodec/directx_va.c
+++ b/modules/codec/avcodec/directx_va.c
@@ -420,6 +420,13 @@ vlc_va_surface_t *directx_va_Get(vlc_va_t *va, 
directx_sys_t *dx_sys, uint8_t **
     return surface;
 }
 
+void directx_va_AddRef(vlc_va_surface_t *surface)
+{
+    vlc_mutex_lock( surface->p_lock );
+    surface->refcount++;
+    vlc_mutex_unlock( surface->p_lock );
+}
+
 void directx_va_Release(vlc_va_surface_t *surface)
 {
     vlc_mutex_lock( surface->p_lock );
diff --git a/modules/codec/avcodec/directx_va.h 
b/modules/codec/avcodec/directx_va.h
index a7e20d39ea..8bc296550e 100644
--- a/modules/codec/avcodec/directx_va.h
+++ b/modules/codec/avcodec/directx_va.h
@@ -138,6 +138,7 @@ int directx_va_Open(vlc_va_t *, directx_sys_t *, 
AVCodecContext *ctx, const es_f
 void directx_va_Close(vlc_va_t *, directx_sys_t *);
 int directx_va_Setup(vlc_va_t *, directx_sys_t *, AVCodecContext *avctx);
 vlc_va_surface_t *directx_va_Get(vlc_va_t *, directx_sys_t *, uint8_t **data);
+void directx_va_AddRef(vlc_va_surface_t *surface);
 void directx_va_Release(vlc_va_surface_t *surface);
 char *directx_va_GetDecoderName(const GUID *guid);
 

_______________________________________________
vlc-commits mailing list
[email protected]
https://mailman.videolan.org/listinfo/vlc-commits

Reply via email to