vulkan: make a gstvulkan library out of the existing API

This commit is contained in:
Matthew Waters 2019-04-08 21:35:22 +10:00
parent 8def3b3743
commit 25dd3b32e5
73 changed files with 618 additions and 577 deletions

View file

@ -532,55 +532,6 @@ if test "x$HAVE_WINSOCK2_H" = "xyes"; then
AC_SUBST(WINSOCK2_LIBS) AC_SUBST(WINSOCK2_LIBS)
fi fi
dnl Vulkan
PKG_CHECK_MODULES(XCB, xcb >= 1.10, GST_VULKAN_HAVE_WINDOW_XCB=1, GST_VULKAN_HAVE_WINDOW_XCB=0)
AM_CONDITIONAL(USE_XCB, test "x$GST_VULKAN_HAVE_WINDOW_XCB" = "x1")
PKG_CHECK_MODULES(VULKAN_WAYLAND, wayland-client >= 1.4, GST_VULKAN_HAVE_WINDOW_WAYLAND=1, GST_VULKAN_HAVE_WINDOW_WAYLAND=0)
AM_CONDITIONAL(USE_WAYLAND, test "x$GST_VULKAN_HAVE_WINDOW_WAYLAND" = "x1")
VULKAN_CONFIG_DEFINES="
#define GST_VULKAN_HAVE_WINDOW_XCB $GST_VULKAN_HAVE_WINDOW_XCB
#define GST_VULKAN_HAVE_WINDOW_WAYLAND $GST_VULKAN_HAVE_WINDOW_WAYLAND"
AC_CONFIG_COMMANDS([ext/vulkan/vkconfig.h], [
outfile=vkconfig.h-tmp
cat > $outfile <<\_______EOF
/* vkconfig.h
*
* This is a generated file. Please modify `configure.ac'
*/
#ifndef __GST_VULKAN_CONFIG_H__
#define __GST_VULKAN_CONFIG_H__
#include <gst/gst.h>
G_BEGIN_DECLS
_______EOF
cat >>$outfile <<_______EOF
$vulkan_config_defines
_______EOF
cat >>$outfile <<_______EOF
G_END_DECLS
#endif /* __GST_VULKAN_CONFIG_H__ */
_______EOF
if cmp -s $outfile ext/vulkan/vkconfig.h; then
AC_MSG_NOTICE([ext/vulkan/vkconfig.h is unchanged])
rm -f $outfile
else
mv $outfile ext/vulkan/vkconfig.h
fi
],[
vulkan_config_defines='$VULKAN_CONFIG_DEFINES'
])
dnl *** sys plug-ins *** dnl *** sys plug-ins ***
dnl DirectSound dnl DirectSound
@ -1974,23 +1925,6 @@ AG_GST_CHECK_FEATURE(GL, [gl elements], gl, [
AM_CONDITIONAL(USE_GL, test "x$HAVE_GL" = "xyes") AM_CONDITIONAL(USE_GL, test "x$HAVE_GL" = "xyes")
AM_CONDITIONAL(USE_OPENGL, test "x$GST_GL_HAVE_API_GL" = "x1") AM_CONDITIONAL(USE_OPENGL, test "x$GST_GL_HAVE_API_GL" = "x1")
dnl *** Vulkan ***
translit(dnm, m, l) AM_CONDITIONAL(USE_VULKAN, true)
AG_GST_CHECK_FEATURE(VULKAN, [Vulkan elements], vulkan, [
AC_CHECK_HEADER(vulkan/vulkan.h, [
AC_CHECK_LIB(vulkan, vkCreateDevice, [
VULKAN_LIBS="-lvulkan"
AC_SUBST(VULKAN_LIBS)
if test "x$GST_VULKAN_HAVE_WINDOW_XCB" = "x1"; then
HAVE_VULKAN="yes"
fi
if test "x$GST_VULKAN_HAVE_WINDOW_WAYLAND" = "x1"; then
HAVE_VULKAN="yes"
fi
], [])
], [])
])
dnl *** teletextdec *** dnl *** teletextdec ***
translit(dnm, m, l) AM_CONDITIONAL(USE_TELETEXTDEC, true) translit(dnm, m, l) AM_CONDITIONAL(USE_TELETEXTDEC, true)
AG_GST_CHECK_FEATURE(TELETEXTDEC, [Teletext decoder], teletextdec, [ AG_GST_CHECK_FEATURE(TELETEXTDEC, [Teletext decoder], teletextdec, [
@ -2397,7 +2331,6 @@ AM_CONDITIONAL(USE_WEBRTCDSP, false)
AM_CONDITIONAL(USE_OPENH264, false) AM_CONDITIONAL(USE_OPENH264, false)
AM_CONDITIONAL(USE_X265, false) AM_CONDITIONAL(USE_X265, false)
AM_CONDITIONAL(USE_DTLS, false) AM_CONDITIONAL(USE_DTLS, false)
AM_CONDITIONAL(USE_VULKAN, false)
AM_CONDITIONAL(USE_TTML, false) AM_CONDITIONAL(USE_TTML, false)
AM_CONDITIONAL(USE_SCTP, false) AM_CONDITIONAL(USE_SCTP, false)
@ -2684,9 +2617,6 @@ ext/srtp/Makefile
ext/teletextdec/Makefile ext/teletextdec/Makefile
ext/gme/Makefile ext/gme/Makefile
ext/wildmidi/Makefile ext/wildmidi/Makefile
ext/vulkan/Makefile
ext/vulkan/xcb/Makefile
ext/vulkan/wayland/Makefile
ext/webp/Makefile ext/webp/Makefile
ext/x265/Makefile ext/x265/Makefile
ext/zbar/Makefile ext/zbar/Makefile

View file

@ -370,12 +370,6 @@ else
DTLS_DIR= DTLS_DIR=
endif endif
if USE_VULKAN
VULKAN_DIR=vulkan
else
VULKAN_DIR=
endif
if USE_WEBRTCDSP if USE_WEBRTCDSP
WEBRTCDSP_DIR=webrtcdsp WEBRTCDSP_DIR=webrtcdsp
else else
@ -464,7 +458,6 @@ SUBDIRS=\
$(WEBP_DIR) \ $(WEBP_DIR) \
$(X265_DIR) \ $(X265_DIR) \
$(DTLS_DIR) \ $(DTLS_DIR) \
$(VULKAN_DIR) \
$(WEBRTCDSP_DIR) \ $(WEBRTCDSP_DIR) \
$(TTML_DIR) \ $(TTML_DIR) \
$(WEBRTC_DIR) \ $(WEBRTC_DIR) \
@ -531,7 +524,6 @@ DIST_SUBDIRS = \
webp \ webp \
x265 \ x265 \
dtls \ dtls \
vulkan \
webrtcdsp \ webrtcdsp \
ttml \ ttml \
webrtc \ webrtc \

View file

@ -1 +0,0 @@
vkconfig.h

View file

@ -1,77 +0,0 @@
plugin_LTLIBRARIES = libgstvulkan.la
SUBDIRS =
DIST_SUBDIRS = xcb wayland
DISTCLEANFILES = vkconfig.h
libgstvulkan_la_SOURCES = \
gstvulkan.c \
vkdevice.c \
vkdisplay.c \
vkerror.c \
vkfence.c \
vkbuffermemory.c \
vkimagememory.c \
vkbufferpool.c \
vkinstance.c \
vkmemory.c \
vkqueue.c \
vktrash.c \
vksink.c \
vkswapper.c \
vkupload.c \
vkutils.c \
vkwindow.c
noinst_HEADERS = \
vk.h \
vkapi.h \
vk_fwd.h \
vkbuffermemory.h \
vkbufferpool.h \
vkconfig.h \
vkdevice.h \
vkdisplay.h \
vkerror.h \
vkfence.h \
vkimagememory.h \
vkinstance.h \
vkmacros.h \
vkmemory.h \
vkqueue.h \
vktrash.h \
vksink.h \
vkswapper.h \
vkupload.h \
vkutils.h \
vkutils_private.h \
vkwindow.h
libgstvulkan_la_CFLAGS = \
-I$(top_srcdir)/gst-libs \
-I$(top_builddir)/gst-libs \
-I$(top_builddir)/ext/vulkan \
$(GST_CFLAGS) \
$(GST_BASE_CFLAGS) \
$(GST_PLUGINS_BASE_CFLAGS) \
$(VULKAN_CFLAGS)
libgstvulkan_la_LIBADD = \
$(GST_BASE_LIBS) \
$(GST_PLUGINS_BASE_LIBS) \
-lgstvideo-$(GST_API_VERSION) \
$(VULKAN_LIBS)
if USE_XCB
SUBDIRS += xcb
libgstvulkan_la_LIBADD += xcb/libgstvulkan-xcb.la
endif
if USE_WAYLAND
SUBDIRS += wayland
libgstvulkan_la_LIBADD += wayland/libgstvulkan-wayland.la
endif
libgstvulkan_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS)

View file

@ -1,132 +1,24 @@
vulkan_sources = [
'gstvulkan.c',
'vkbuffermemory.c',
'vkbufferpool.c',
'vkdevice.c',
'vkdisplay.c',
'vkerror.c',
'vkfence.c',
'vkimagememory.c',
'vkinstance.c',
'vkmemory.c',
'vkqueue.c',
'vksink.c',
'vkswapper.c',
'vktrash.c',
'vkupload.c',
'vkutils.c',
'vkwindow.c',
]
vulkan_objc_args = []
vulkan_defines = []
optional_deps = []
if get_option('vulkan').disabled() if get_option('vulkan').disabled()
subdir_done() subdir_done()
endif endif
if host_system == 'ios' vulkan_sources = [
vulkan_dep = cc.find_library('MoltenVK', required : get_option('vulkan')) 'gstvulkan.c',
else 'vksink.c',
vulkan_dep = cc.find_library('vulkan', required : get_option('vulkan')) 'vkswapper.c',
endif 'vktrash.c',
has_vulkan_header = cc.has_header('vulkan/vulkan.h') 'vkupload.c',
if not has_vulkan_header and get_option('vulkan').enabled() ]
error('vulkan plugin enabled, but vulkan.h not found')
endif
if vulkan_dep.found() and has_vulkan_header gstvulkan_plugin = library('gstvulkan',
have_vulkan_windowing = false
vkconf = configuration_data()
xcb_dep = dependency('xcb', version : '>=1.10', required : get_option('x11'))
if xcb_dep.found()
vulkan_sources += [
'xcb/vkdisplay_xcb.c',
'xcb/vkwindow_xcb.c',
'xcb/xcb_event_source.c',
]
optional_deps += xcb_dep
have_vulkan_windowing = true
vkconf.set10('GST_VULKAN_HAVE_WINDOW_XCB', 1)
endif
wayland_client_dep = dependency('wayland-client', version : '>=1.4', required : get_option('wayland'))
if wayland_client_dep.found()
vulkan_sources += [
'wayland/vkdisplay_wayland.c',
'wayland/vkwindow_wayland.c',
'wayland/wayland_event_source.c',
]
optional_deps += wayland_client_dep
have_vulkan_windowing = true
vkconf.set10('GST_VULKAN_HAVE_WINDOW_WAYLAND', 1)
endif
if ['darwin', 'ios'].contains(host_system)
objc = meson.get_compiler('objc')
if not objc.has_argument('-fobjc-arc')
error('ARC is required for building')
endif
vulkan_objc_args += ['-fobjc-arc']
foundation_dep = dependency('appleframeworks', modules : ['Foundation'], required : get_option('vulkan'))
quartzcore_dep = dependency('appleframeworks', modules : ['QuartzCore'], required : get_option('vulkan'))
corefoundation_dep = dependency('appleframeworks', modules : ['CoreFoundation'], required : get_option('vulkan'))
if foundation_dep.found() and quartzcore_dep.found() and corefoundation_dep.found()
optional_deps += [foundation_dep, corefoundation_dep, quartzcore_dep]
endif
endif
if host_system == 'darwin'
cocoa_dep = dependency('appleframeworks', modules : ['Cocoa'], required : get_option('vulkan'))
if cocoa_dep.found()
vulkan_sources += [
'cocoa/vkdisplay_cocoa.m',
'cocoa/vkwindow_cocoa.m',
]
optional_deps += [cocoa_dep]
have_vulkan_windowing = true
vkconf.set10('GST_VULKAN_HAVE_WINDOW_COCOA', 1)
endif
endif
if host_system == 'ios'
uikit_dep = dependency('appleframeworks', modules : ['UIKit'], required : get_option('vulkan'))
if uikit_dep.found()
vulkan_sources += [
'ios/vkdisplay_ios.m',
'ios/vkwindow_ios.m',
]
optional_deps += [uikit_dep]
have_vulkan_windowing = true
vkconf.set10('GST_VULKAN_HAVE_WINDOW_IOS', 1)
endif
endif
if have_vulkan_windowing
configure_file(input : 'vkconfig.h.meson',
output : 'vkconfig.h',
configuration : vkconf)
gstvulkan = library('gstvulkan',
vulkan_sources, vulkan_sources,
c_args : gst_plugins_bad_args + vulkan_defines, c_args : gst_plugins_bad_args,
objc_args : gst_plugins_bad_args + vulkan_defines + vulkan_objc_args, objc_args : gst_plugins_bad_args,
link_args : noseh_link_args, link_args : noseh_link_args,
include_directories : [configinc], include_directories : [configinc],
dependencies : [gstvideo_dep, gstbase_dep, vulkan_dep] + optional_deps, dependencies : [gstvideo_dep, gstbase_dep, gstvulkan_dep, vulkan_dep],
install : true, install : true,
install_dir : plugins_install_dir, install_dir : plugins_install_dir,
) )
pkgconfig.generate(gstvulkan, install_dir : plugins_pkgconfig_install_dir) pkgconfig.generate(gstvulkan_plugin, install_dir : plugins_pkgconfig_install_dir)
plugins += [gstvulkan] plugins += [gstvulkan_plugin]
endif
endif

View file

@ -33,7 +33,7 @@
//#include <gst/video/videooverlay.h> //#include <gst/video/videooverlay.h>
#include "vksink.h" #include "vksink.h"
#include "vkdevice.h" #include "vkswapper.h"
GST_DEBUG_CATEGORY (gst_debug_vulkan_sink); GST_DEBUG_CATEGORY (gst_debug_vulkan_sink);
#define GST_CAT_DEFAULT gst_debug_vulkan_sink #define GST_CAT_DEFAULT gst_debug_vulkan_sink

View file

@ -24,7 +24,8 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <gst/video/gstvideosink.h> #include <gst/video/gstvideosink.h>
#include <gst/video/video.h> #include <gst/video/video.h>
#include "vk.h" #include <gst/vulkan/vulkan.h>
#include "vkswapper.h"
G_BEGIN_DECLS G_BEGIN_DECLS

View file

@ -25,6 +25,7 @@
#include <string.h> #include <string.h>
#include "vkswapper.h" #include "vkswapper.h"
#include "vktrash.h"
#define GST_CAT_DEFAULT gst_vulkan_swapper_debug #define GST_CAT_DEFAULT gst_vulkan_swapper_debug
GST_DEBUG_CATEGORY (GST_CAT_DEFAULT); GST_DEBUG_CATEGORY (GST_CAT_DEFAULT);

View file

@ -23,7 +23,7 @@
#include <gst/video/video.h> #include <gst/video/video.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
@ -37,6 +37,10 @@ GType gst_vulkan_swapper_get_type (void);
#define GST_VULKAN_SWAPPER_VIDEO_FORMATS " { RGBA, BGRA, RGB, BGR } " #define GST_VULKAN_SWAPPER_VIDEO_FORMATS " { RGBA, BGRA, RGB, BGR } "
typedef struct _GstVulkanSwapper GstVulkanSwapper;
typedef struct _GstVulkanSwapperClass GstVulkanSwapperClass;
typedef struct _GstVulkanSwapperPrivate GstVulkanSwapperPrivate;
struct _GstVulkanSwapper struct _GstVulkanSwapper
{ {
GstObject parent; GstObject parent;

View file

@ -23,7 +23,6 @@
#endif #endif
#include "vktrash.h" #include "vktrash.h"
#include "vkutils_private.h"
GST_DEBUG_CATEGORY (gst_debug_vulkan_trash); GST_DEBUG_CATEGORY (gst_debug_vulkan_trash);
#define GST_CAT_DEFAULT gst_debug_vulkan_trash #define GST_CAT_DEFAULT gst_debug_vulkan_trash

View file

@ -18,15 +18,17 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_TRASH_H_ #ifndef __GST_VULKAN_TRASH_H__
#define _VK_TRASH_H_ #define __GST_VULKAN_TRASH_H__
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
typedef void (*GstVulkanTrashNotify) (GstVulkanDevice * device, gpointer user_data); typedef void (*GstVulkanTrashNotify) (GstVulkanDevice * device, gpointer user_data);
typedef struct _GstVulkanTrash GstVulkanTrash;
struct _GstVulkanTrash struct _GstVulkanTrash
{ {
GstVulkanFence *fence; GstVulkanFence *fence;
@ -50,4 +52,4 @@ gboolean gst_vulkan_trash_list_wait (GList * trash_l
G_END_DECLS G_END_DECLS
#endif /* _VK_INSTANCE_H_ */ #endif /* __GST_VULKAN_TRASH_H__ */

View file

@ -23,7 +23,7 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <gst/video/video.h> #include <gst/video/video.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS

View file

@ -1,42 +0,0 @@
/*
* GStreamer
* Copyright (C) 2015 Matthew Waters <matthew@centricular.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef _VK_UTILS_H_
#define _VK_UTILS_H_
#include <gst/gst.h>
#include <vk.h>
G_BEGIN_DECLS
gboolean gst_vulkan_ensure_element_data (gpointer element,
GstVulkanDisplay **display_ptr, GstVulkanInstance ** instance_ptr);
gboolean gst_vulkan_handle_set_context (GstElement * element, GstContext * context,
GstVulkanDisplay ** display, GstVulkanInstance ** instance);
gboolean gst_vulkan_handle_context_query (GstElement * element, GstQuery * query,
GstVulkanDisplay ** display, GstVulkanInstance ** instance, GstVulkanDevice ** device);
void gst_vulkan_global_context_query (GstElement * element, const gchar * context_type);
GstQuery * gst_vulkan_local_context_query (GstElement * element, const gchar * context_type, gboolean set_context);
gboolean gst_vulkan_run_query (GstElement * element,
GstQuery * query, GstPadDirection direction);
G_END_DECLS
#endif /*_VK_UTILS_H_ */

View file

@ -1,30 +0,0 @@
## Process this file with automake to produce Makefile.in
noinst_LTLIBRARIES = libgstvulkan-wayland.la
libgstvulkan_wayland_la_SOURCES = \
vkdisplay_wayland.c \
vkwindow_wayland.c \
wayland_event_source.c
noinst_HEADERS = \
vkdisplay_wayland.h \
vkwindow_wayland.h \
wayland_event_source.h
libgstvulkan_wayland_la_CFLAGS = \
-I$(top_srcdir)/gst-libs \
-I$(top_builddir)/ext/vulkan \
-I$(top_srcdir)/ext/vulkan \
-I$(top_builddir)/gst-libs \
$(GST_PLUGINS_BASE_CFLAGS) \
$(GST_BASE_CFLAGS) \
$(GST_CFLAGS) \
$(VULKAN_WAYLAND_CFLAGS)
libgstvulkan_wayland_la_LIBADD = \
$(VULKAN_WAYLAND_LIBS)
libgstvulkan_wayland_la_LDFLAGS = \
$(GST_LIB_LDFLAGS) \
$(GST_ALL_LDFLAGS)

View file

@ -1,30 +0,0 @@
## Process this file with automake to produce Makefile.in
noinst_LTLIBRARIES = libgstvulkan-xcb.la
libgstvulkan_xcb_la_SOURCES = \
vkdisplay_xcb.c \
vkwindow_xcb.c \
xcb_event_source.c
noinst_HEADERS = \
vkdisplay_xcb.h \
vkwindow_xcb.h \
xcb_event_source.h
libgstvulkan_xcb_la_CFLAGS = \
-I$(top_srcdir)/gst-libs \
-I$(top_builddir)/ext/vulkan \
-I$(top_srcdir)/ext/vulkan \
-I$(top_builddir)/gst-libs \
$(GST_PLUGINS_BASE_CFLAGS) \
$(GST_BASE_CFLAGS) \
$(GST_CFLAGS) \
$(XCB_CFLAGS)
libgstvulkan_xcb_la_LIBADD = \
$(XCB_LIBS)
libgstvulkan_xcb_la_LDFLAGS = \
$(GST_LIB_LDFLAGS) \
$(GST_ALL_LDFLAGS)

View file

@ -11,5 +11,6 @@ subdir('mpegts')
subdir('opencv') subdir('opencv')
subdir('player') subdir('player')
subdir('sctp') subdir('sctp')
subdir('vulkan')
subdir('wayland') subdir('wayland')
subdir('webrtc') subdir('webrtc')

1
gst-libs/gst/vulkan/.gitignore vendored Normal file
View file

@ -0,0 +1 @@
gstvkconfig.h

View file

@ -24,7 +24,7 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <Cocoa/Cocoa.h> #include <Cocoa/Cocoa.h>
#include "vkwindow_cocoa.h" #include "gstvkwindow_cocoa.h"
G_BEGIN_DECLS G_BEGIN_DECLS

View file

@ -1,6 +1,6 @@
/* /*
* GStreamer * GStreamer
* Copyright (C) 2019 Matthew Waters <ystreet00@gmail.com> * Copyright (C) 2019 Matthew Waters <matthew@centricular.com>
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public * modify it under the terms of the GNU Library General Public
@ -23,13 +23,14 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <vk.h>
#ifndef VK_USE_PLATFORM_MACOS_MVK #ifndef VK_USE_PLATFORM_MACOS_MVK
#error "VK_USE_PLATFORM_MACOS_MVK not defined before including this header" #error "VK_USE_PLATFORM_MACOS_MVK not defined before including this header"
#error "Either include vkapi.h or define VK_USE_PLATFORM_MACOS_MVK before including this header" #error "Either include vkapi.h or define VK_USE_PLATFORM_MACOS_MVK before including this header"
#endif #endif
#include <vulkan/vulkan.h> #include <vulkan/vulkan.h>
#include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
GType gst_vulkan_display_cocoa_get_type (void); GType gst_vulkan_display_cocoa_get_type (void);

View file

@ -22,8 +22,10 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkdisplay_cocoa.h" #include <gst/vulkan/vulkan.h>
#include "vkcocoa_utils.h"
#include "gstvkdisplay_cocoa.h"
#include "gstvkcocoa_utils.h"
#define GST_CAT_DEFAULT gst_vulkan_display_debug #define GST_CAT_DEFAULT gst_vulkan_display_debug
GST_DEBUG_CATEGORY_STATIC (gst_vulkan_display_debug); GST_DEBUG_CATEGORY_STATIC (gst_vulkan_display_debug);

View file

@ -21,7 +21,7 @@
#ifndef __GST_VULKAN_WINDOW_COCOA_H__ #ifndef __GST_VULKAN_WINDOW_COCOA_H__
#define __GST_VULKAN_WINDOW_COCOA_H__ #define __GST_VULKAN_WINDOW_COCOA_H__
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS

View file

@ -27,10 +27,12 @@
#include <gst/gst.h> #include <gst/gst.h>
#include "vkwindow_cocoa.h" #include <gst/vulkan/vulkan.h>
#include "vkdisplay_cocoa.h"
#include "vkcocoa_utils.h" #include "gstvkwindow_cocoa.h"
#include "gstvkdisplay_cocoa.h"
#include "gstvkcocoa_utils.h"
#define GST_VULKAN_WINDOW_COCOA_GET_PRIVATE(o) \ #define GST_VULKAN_WINDOW_COCOA_GET_PRIVATE(o) \
(G_TYPE_INSTANCE_GET_PRIVATE((o), GST_TYPE_VULKAN_WINDOW_COCOA, GstVulkanWindowCocoaPrivate)) (G_TYPE_INSTANCE_GET_PRIVATE((o), GST_TYPE_VULKAN_WINDOW_COCOA, GstVulkanWindowCocoaPrivate))

View file

@ -18,14 +18,15 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_API_H_ #ifndef __GST_VULKAN_API_H__
#define _VK_API_H_ #define __GST_VULKAN_API_H__
#define VK_PROTOTYPES #define VK_PROTOTYPES
#include <vkconfig.h> #include <gst/vulkan/gstvkconfig.h>
#include "vk_fwd.h" #include <gst/vulkan/vulkan-prelude.h>
#include "vkmacros.h" #include <gst/vulkan/vulkan_fwd.h>
#include <gst/vulkan/vulkan-enumtypes.h>
/* Need these defined to have access to winsys functions before including vulkan.h */ /* Need these defined to have access to winsys functions before including vulkan.h */
#if GST_VULKAN_HAVE_WINDOW_XCB #if GST_VULKAN_HAVE_WINDOW_XCB
@ -54,4 +55,4 @@
#include <vulkan/vulkan.h> #include <vulkan/vulkan.h>
#endif /* _VK_H_ */ #endif /* __GST_VULKAN_API_H__ */

View file

@ -22,7 +22,7 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkbuffermemory.h" #include "gstvkbuffermemory.h"
/** /**
* SECTION:vkbuffermemory * SECTION:vkbuffermemory

View file

@ -18,18 +18,19 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_BUFFER_MEMORY_H_ #ifndef __GST_VULKAN_BUFFER_MEMORY_H__
#define _VK_BUFFER_MEMORY_H_ #define __GST_VULKAN_BUFFER_MEMORY_H__
#include <gst/gst.h> #include <gst/gst.h>
#include <gst/gstallocator.h> #include <gst/gstallocator.h>
#include <gst/gstmemory.h> #include <gst/gstmemory.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
#define GST_TYPE_VULKAN_BUFFER_MEMORY_ALLOCATOR (gst_vulkan_buffer_memory_allocator_get_type()) #define GST_TYPE_VULKAN_BUFFER_MEMORY_ALLOCATOR (gst_vulkan_buffer_memory_allocator_get_type())
GST_VULKAN_API
GType gst_vulkan_buffer_memory_allocator_get_type(void); GType gst_vulkan_buffer_memory_allocator_get_type(void);
#define GST_IS_VULKAN_BUFFER_MEMORY_ALLOCATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_VULKAN_BUFFER_MEMORY_ALLOCATOR)) #define GST_IS_VULKAN_BUFFER_MEMORY_ALLOCATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_VULKAN_BUFFER_MEMORY_ALLOCATOR))
@ -81,15 +82,19 @@ struct _GstVulkanBufferMemoryAllocatorClass
GstAllocatorClass parent_class; GstAllocatorClass parent_class;
}; };
GST_VULKAN_API
void gst_vulkan_buffer_memory_init_once (void); void gst_vulkan_buffer_memory_init_once (void);
GST_VULKAN_API
gboolean gst_is_vulkan_buffer_memory (GstMemory * mem); gboolean gst_is_vulkan_buffer_memory (GstMemory * mem);
GST_VULKAN_API
GstMemory * gst_vulkan_buffer_memory_alloc (GstVulkanDevice * device, GstMemory * gst_vulkan_buffer_memory_alloc (GstVulkanDevice * device,
VkFormat format, VkFormat format,
gsize size, gsize size,
VkBufferUsageFlags usage, VkBufferUsageFlags usage,
VkMemoryPropertyFlags mem_prop_flags); VkMemoryPropertyFlags mem_prop_flags);
GST_VULKAN_API
GstMemory * gst_vulkan_buffer_memory_wrapped (GstVulkanDevice * device, GstMemory * gst_vulkan_buffer_memory_wrapped (GstVulkanDevice * device,
VkBuffer buffer, VkBuffer buffer,
VkFormat format, VkFormat format,
@ -99,4 +104,4 @@ GstMemory * gst_vulkan_buffer_memory_wrapped (GstVulkanDevice * devi
G_END_DECLS G_END_DECLS
#endif /* _VK_BUFFER_MEMORY_H_ */ #endif /* __GST_VULKAN_BUFFER_MEMORY_H__ */

View file

@ -22,7 +22,7 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkbufferpool.h" #include "gstvkbufferpool.h"
/** /**
* SECTION:vkbufferpool * SECTION:vkbufferpool

View file

@ -18,18 +18,18 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _GST_VULKAN_BUFFER_POOL_H_ #ifndef __GST_VULKAN_BUFFER_POOL_H__
#define _GST_VULKAN_BUFFER_POOL_H_ #define __GST_VULKAN_BUFFER_POOL_H__
#include <gst/video/video.h> #include <gst/video/video.h>
#include <gst/video/gstvideometa.h> #include <gst/video/gstvideometa.h>
#include <gst/video/gstvideopool.h> #include <gst/video/gstvideopool.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
/* buffer pool functions */ GST_VULKAN_API
GType gst_vulkan_buffer_pool_get_type (void); GType gst_vulkan_buffer_pool_get_type (void);
#define GST_TYPE_VULKAN_BUFFER_POOL (gst_vulkan_buffer_pool_get_type()) #define GST_TYPE_VULKAN_BUFFER_POOL (gst_vulkan_buffer_pool_get_type())
#define GST_IS_VULKAN_BUFFER_POOL(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_VULKAN_BUFFER_POOL)) #define GST_IS_VULKAN_BUFFER_POOL(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_VULKAN_BUFFER_POOL))
@ -60,8 +60,9 @@ struct _GstVulkanBufferPoolClass
GstBufferPoolClass parent_class; GstBufferPoolClass parent_class;
}; };
GST_VULKAN_API
GstBufferPool *gst_vulkan_buffer_pool_new (GstVulkanDevice * device); GstBufferPool *gst_vulkan_buffer_pool_new (GstVulkanDevice * device);
G_END_DECLS G_END_DECLS
#endif /* _GST_VULKAN_BUFFER_POOL_H_ */ #endif /* __GST_VULKAN_BUFFER_POOL_H__ */

View file

@ -22,8 +22,7 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkdevice.h" #include "gstvkdevice.h"
#include "vkutils_private.h"
#include <string.h> #include <string.h>
@ -512,7 +511,7 @@ gst_vulkan_device_run_context_query (GstElement * element,
if ((query = if ((query =
gst_vulkan_local_context_query (element, gst_vulkan_local_context_query (element,
GST_VULKAN_DEVICE_CONTEXT_TYPE_STR, FALSE))) { GST_VULKAN_DEVICE_CONTEXT_TYPE_STR))) {
GstContext *context; GstContext *context;
gst_query_parse_context (query, &context); gst_query_parse_context (query, &context);

View file

@ -18,11 +18,12 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_DEVICE_H_ #ifndef __GST_VULKAN_DEVICE_H__
#define _VK_DEVICE_H_ #define __GST_VULKAN_DEVICE_H__
#include <gst/gst.h> #include <gst/gst.h>
#include "vk.h"
#include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
@ -32,6 +33,7 @@ G_BEGIN_DECLS
#define GST_IS_VULKAN_DEVICE(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_DEVICE)) #define GST_IS_VULKAN_DEVICE(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_DEVICE))
#define GST_IS_VULKAN_DEVICE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), GST_TYPE_VULKAN_DEVICE)) #define GST_IS_VULKAN_DEVICE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), GST_TYPE_VULKAN_DEVICE))
#define GST_VULKAN_DEVICE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_DEVICE, GstVulkanDeviceClass)) #define GST_VULKAN_DEVICE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_DEVICE, GstVulkanDeviceClass))
GST_VULKAN_API
GType gst_vulkan_device_get_type (void); GType gst_vulkan_device_get_type (void);
#define GST_VULKAN_DEVICE_CONTEXT_TYPE_STR "gst.vulkan.device" #define GST_VULKAN_DEVICE_CONTEXT_TYPE_STR "gst.vulkan.device"
@ -66,34 +68,46 @@ struct _GstVulkanDeviceClass
GstObjectClass parent_class; GstObjectClass parent_class;
}; };
GST_VULKAN_API
GstVulkanDevice * gst_vulkan_device_new (GstVulkanInstance * instance); GstVulkanDevice * gst_vulkan_device_new (GstVulkanInstance * instance);
GST_VULKAN_API
GstVulkanInstance * gst_vulkan_device_get_instance (GstVulkanDevice * device); GstVulkanInstance * gst_vulkan_device_get_instance (GstVulkanDevice * device);
GST_VULKAN_API
gboolean gst_vulkan_device_open (GstVulkanDevice * device, gboolean gst_vulkan_device_open (GstVulkanDevice * device,
GError ** error); GError ** error);
GST_VULKAN_API
gpointer gst_vulkan_device_get_proc_address (GstVulkanDevice * device, gpointer gst_vulkan_device_get_proc_address (GstVulkanDevice * device,
const gchar * name); const gchar * name);
GST_VULKAN_API
void gst_vulkan_device_foreach_queue (GstVulkanDevice * device, void gst_vulkan_device_foreach_queue (GstVulkanDevice * device,
GstVulkanDeviceForEachQueueFunc func, GstVulkanDeviceForEachQueueFunc func,
gpointer user_data); gpointer user_data);
GST_VULKAN_API
GstVulkanQueue * gst_vulkan_device_get_queue (GstVulkanDevice * device, GstVulkanQueue * gst_vulkan_device_get_queue (GstVulkanDevice * device,
guint32 queue_family, guint32 queue_family,
guint32 queue_i); guint32 queue_i);
GST_VULKAN_API
VkPhysicalDevice gst_vulkan_device_get_physical_device (GstVulkanDevice * device); VkPhysicalDevice gst_vulkan_device_get_physical_device (GstVulkanDevice * device);
GST_VULKAN_API
gboolean gst_vulkan_device_create_cmd_buffer (GstVulkanDevice * device, gboolean gst_vulkan_device_create_cmd_buffer (GstVulkanDevice * device,
VkCommandBuffer * cmd, VkCommandBuffer * cmd,
GError ** error); GError ** error);
GST_VULKAN_API
void gst_context_set_vulkan_device (GstContext * context, void gst_context_set_vulkan_device (GstContext * context,
GstVulkanDevice * device); GstVulkanDevice * device);
GST_VULKAN_API
gboolean gst_context_get_vulkan_device (GstContext * context, gboolean gst_context_get_vulkan_device (GstContext * context,
GstVulkanDevice ** device); GstVulkanDevice ** device);
GST_VULKAN_API
gboolean gst_vulkan_device_handle_context_query (GstElement * element, gboolean gst_vulkan_device_handle_context_query (GstElement * element,
GstQuery * query, GstQuery * query,
GstVulkanDevice ** device); GstVulkanDevice ** device);
GST_VULKAN_API
gboolean gst_vulkan_device_run_context_query (GstElement * element, gboolean gst_vulkan_device_run_context_query (GstElement * element,
GstVulkanDevice ** device); GstVulkanDevice ** device);
G_END_DECLS G_END_DECLS
#endif /* _VK_DEVICE_H_ */ #endif /* __GST_VULKAN_DEVICE_H__ */

View file

@ -25,19 +25,19 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkdisplay.h" #include "gstvkdisplay.h"
#if GST_VULKAN_HAVE_WINDOW_XCB #if GST_VULKAN_HAVE_WINDOW_XCB
#include "xcb/vkdisplay_xcb.h" #include "xcb/gstvkdisplay_xcb.h"
#endif #endif
#if GST_VULKAN_HAVE_WINDOW_WAYLAND #if GST_VULKAN_HAVE_WINDOW_WAYLAND
#include "wayland/vkdisplay_wayland.h" #include "wayland/gstvkdisplay_wayland.h"
#endif #endif
#if GST_VULKAN_HAVE_WINDOW_COCOA #if GST_VULKAN_HAVE_WINDOW_COCOA
#include "cocoa/vkdisplay_cocoa.h" #include "cocoa/gstvkdisplay_cocoa.h"
#endif #endif
#if GST_VULKAN_HAVE_WINDOW_IOS #if GST_VULKAN_HAVE_WINDOW_IOS
#include "ios/vkdisplay_ios.h" #include "ios/gstvkdisplay_ios.h"
#endif #endif
GST_DEBUG_CATEGORY_STATIC (GST_CAT_CONTEXT); GST_DEBUG_CATEGORY_STATIC (GST_CAT_CONTEXT);

View file

@ -26,7 +26,7 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
@ -37,6 +37,7 @@ G_BEGIN_DECLS
#define GST_IS_VULKAN_DISPLAY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GST_TYPE_VULKAN_DISPLAY)) #define GST_IS_VULKAN_DISPLAY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GST_TYPE_VULKAN_DISPLAY))
#define GST_VULKAN_DISPLAY_CAST(obj) ((GstVulkanDisplay*)(obj)) #define GST_VULKAN_DISPLAY_CAST(obj) ((GstVulkanDisplay*)(obj))
#define GST_VULKAN_DISPLAY_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_DISPLAY, GstVulkanDisplayClass)) #define GST_VULKAN_DISPLAY_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_DISPLAY, GstVulkanDisplayClass))
GST_VULKAN_API
GType gst_vulkan_display_get_type (void); GType gst_vulkan_display_get_type (void);
#define GST_VULKAN_DISPLAY_CONTEXT_TYPE_STR "gst.vulkan.display" #define GST_VULKAN_DISPLAY_CONTEXT_TYPE_STR "gst.vulkan.display"
@ -85,28 +86,40 @@ struct _GstVulkanDisplayClass
GstVulkanWindow * (*create_window) (GstVulkanDisplay * display); GstVulkanWindow * (*create_window) (GstVulkanDisplay * display);
}; };
GST_VULKAN_API
GstVulkanDisplay * gst_vulkan_display_new (GstVulkanInstance *instance); GstVulkanDisplay * gst_vulkan_display_new (GstVulkanInstance *instance);
GST_VULKAN_API
GstVulkanDisplay * gst_vulkan_display_new_with_type (GstVulkanInstance *instance, GstVulkanDisplay * gst_vulkan_display_new_with_type (GstVulkanInstance *instance,
GstVulkanDisplayType type); GstVulkanDisplayType type);
GST_VULKAN_API
GstVulkanDisplayType gst_vulkan_display_choose_type (GstVulkanInstance *instance); GstVulkanDisplayType gst_vulkan_display_choose_type (GstVulkanInstance *instance);
GST_VULKAN_API
const gchar * gst_vulkan_display_type_to_extension_string (GstVulkanDisplayType type); const gchar * gst_vulkan_display_type_to_extension_string (GstVulkanDisplayType type);
GST_VULKAN_API
gpointer gst_vulkan_display_get_handle (GstVulkanDisplay * display); gpointer gst_vulkan_display_get_handle (GstVulkanDisplay * display);
GST_VULKAN_API
GstVulkanDisplayType gst_vulkan_display_get_handle_type (GstVulkanDisplay * display); GstVulkanDisplayType gst_vulkan_display_get_handle_type (GstVulkanDisplay * display);
GST_VULKAN_API
GstVulkanWindow * gst_vulkan_display_create_window (GstVulkanDisplay * display); GstVulkanWindow * gst_vulkan_display_create_window (GstVulkanDisplay * display);
GST_VULKAN_API
gboolean gst_context_get_vulkan_display (GstContext * context, gboolean gst_context_get_vulkan_display (GstContext * context,
GstVulkanDisplay ** display); GstVulkanDisplay ** display);
GST_VULKAN_API
void gst_context_set_vulkan_display (GstContext * context, void gst_context_set_vulkan_display (GstContext * context,
GstVulkanDisplay * display); GstVulkanDisplay * display);
GST_VULKAN_API
gboolean gst_vulkan_display_handle_context_query (GstElement * element, gboolean gst_vulkan_display_handle_context_query (GstElement * element,
GstQuery * query, GstQuery * query,
GstVulkanDisplay ** display); GstVulkanDisplay ** display);
GST_VULKAN_API
gboolean gst_vulkan_display_run_context_query (GstElement * element, gboolean gst_vulkan_display_run_context_query (GstElement * element,
GstVulkanDisplay ** display); GstVulkanDisplay ** display);
/* GstVulkanWindow usage only */ /* GstVulkanWindow usage only */
GST_VULKAN_API
gboolean gst_vulkan_display_remove_window (GstVulkanDisplay * display, GstVulkanWindow * window); gboolean gst_vulkan_display_remove_window (GstVulkanDisplay * display, GstVulkanWindow * window);

View file

@ -24,7 +24,7 @@
#include <glib/gprintf.h> #include <glib/gprintf.h>
#include "vkerror.h" #include "gstvkerror.h"
/* *INDENT-OFF* */ /* *INDENT-OFF* */
static const struct static const struct

View file

@ -18,15 +18,17 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_ERROR_H_ #ifndef __GST_VULKAN_ERROR_H__
#define _VK_ERROR_H_ #define __GST_VULKAN_ERROR_H__
#include <gst/gst.h> #include <gst/gst.h>
#include <vulkan/vulkan.h> #include <vulkan/vulkan.h>
#include <gst/vulkan/vulkan-prelude.h>
G_BEGIN_DECLS G_BEGIN_DECLS
#define GST_VULKAN_ERROR (gst_vulkan_error_quark ()) #define GST_VULKAN_ERROR (gst_vulkan_error_quark ())
GST_VULKAN_API
GQuark gst_vulkan_error_quark (void); GQuark gst_vulkan_error_quark (void);
/* custom error values */ /* custom error values */
@ -36,8 +38,9 @@ typedef enum
} GstVulkanError; } GstVulkanError;
/* only fills error iff error != NULL and result < 0 */ /* only fills error iff error != NULL and result < 0 */
GST_VULKAN_API
VkResult gst_vulkan_error_to_g_error (VkResult result, GError ** error, const char * format, ...) G_GNUC_PRINTF (3, 4); VkResult gst_vulkan_error_to_g_error (VkResult result, GError ** error, const char * format, ...) G_GNUC_PRINTF (3, 4);
G_END_DECLS G_END_DECLS
#endif /* _VK_INSTANCE_H_ */ #endif /* __GST_VULKAN_ERROR_H__ */

View file

@ -22,8 +22,7 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkfence.h" #include "gstvkfence.h"
#include "vkutils_private.h"
GST_DEBUG_CATEGORY (gst_debug_vulkan_fence); GST_DEBUG_CATEGORY (gst_debug_vulkan_fence);
#define GST_CAT_DEFAULT gst_debug_vulkan_fence #define GST_CAT_DEFAULT gst_debug_vulkan_fence

View file

@ -18,12 +18,13 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_FENCE_H_ #ifndef __GST_VULKAN_FENCE_H__
#define _VK_FENCE_H_ #define __GST_VULKAN_FENCE_H__
#include <vk.h> #include <gst/vulkan/vulkan.h>
#define GST_TYPE_VULKAN_FENCE (gst_vulkan_fence_get_type ()) #define GST_TYPE_VULKAN_FENCE (gst_vulkan_fence_get_type ())
GST_VULKAN_API
GType gst_vulkan_fence_get_type (void); GType gst_vulkan_fence_get_type (void);
#define GST_VULKAN_FENCE_CAST(f) ((GstVulkanFence *) f) #define GST_VULKAN_FENCE_CAST(f) ((GstVulkanFence *) f)
@ -40,10 +41,13 @@ struct _GstVulkanFence
VkFence fence; VkFence fence;
}; };
GST_VULKAN_API
GstVulkanFence * gst_vulkan_fence_new (GstVulkanDevice * device, GstVulkanFence * gst_vulkan_fence_new (GstVulkanDevice * device,
VkFenceCreateFlags flags, VkFenceCreateFlags flags,
GError ** error); GError ** error);
GST_VULKAN_API
GstVulkanFence * gst_vulkan_fence_wait (GstVulkanFence * fence); GstVulkanFence * gst_vulkan_fence_wait (GstVulkanFence * fence);
GST_VULKAN_API
gboolean gst_vulkan_fence_is_signaled (GstVulkanFence * fence); gboolean gst_vulkan_fence_is_signaled (GstVulkanFence * fence);
static inline GstVulkanFence * static inline GstVulkanFence *
@ -60,4 +64,4 @@ gst_vulkan_fence_unref (GstVulkanFence * fence)
G_END_DECLS G_END_DECLS
#endif /* _VK_FENCE_H_ */ #endif /* __GST_VULKAN_FENCE_H__ */

View file

@ -22,7 +22,7 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkimagememory.h" #include "gstvkimagememory.h"
/** /**
* SECTION:vkimagememory * SECTION:vkimagememory

View file

@ -18,8 +18,8 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_IMAGE_MEMORY_H_ #ifndef __GST_VULKAN_IMAGE_MEMORY_H__
#define _VK_IMAGE_MEMORY_H_ #define __GST_VULKAN_IMAGE_MEMORY_H__
#include <gst/gst.h> #include <gst/gst.h>
#include <gst/gstallocator.h> #include <gst/gstallocator.h>
@ -27,11 +27,12 @@
#include <gst/video/video.h> #include <gst/video/video.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
#define GST_TYPE_VULKAN_IMAGE_MEMORY_ALLOCATOR (gst_vulkan_image_memory_allocator_get_type()) #define GST_TYPE_VULKAN_IMAGE_MEMORY_ALLOCATOR (gst_vulkan_image_memory_allocator_get_type())
GST_VULKAN_API
GType gst_vulkan_image_memory_allocator_get_type(void); GType gst_vulkan_image_memory_allocator_get_type(void);
#define GST_IS_VULKAN_IMAGE_MEMORY_ALLOCATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_VULKAN_IMAGE_MEMORY_ALLOCATOR)) #define GST_IS_VULKAN_IMAGE_MEMORY_ALLOCATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_VULKAN_IMAGE_MEMORY_ALLOCATOR))
@ -86,9 +87,12 @@ struct _GstVulkanImageMemoryAllocatorClass
GstAllocatorClass parent_class; GstAllocatorClass parent_class;
}; };
GST_VULKAN_API
void gst_vulkan_image_memory_init_once (void); void gst_vulkan_image_memory_init_once (void);
GST_VULKAN_API
gboolean gst_is_vulkan_image_memory (GstMemory * mem); gboolean gst_is_vulkan_image_memory (GstMemory * mem);
GST_VULKAN_API
GstMemory * gst_vulkan_image_memory_alloc (GstVulkanDevice * device, GstMemory * gst_vulkan_image_memory_alloc (GstVulkanDevice * device,
VkFormat format, VkFormat format,
gsize width, gsize width,
@ -97,6 +101,7 @@ GstMemory * gst_vulkan_image_memory_alloc (GstVulkanDevice * devic
VkImageUsageFlags usage, VkImageUsageFlags usage,
VkMemoryPropertyFlags mem_prop_flags); VkMemoryPropertyFlags mem_prop_flags);
GST_VULKAN_API
GstMemory * gst_vulkan_image_memory_wrapped (GstVulkanDevice * device, GstMemory * gst_vulkan_image_memory_wrapped (GstVulkanDevice * device,
VkImage image, VkImage image,
VkFormat format, VkFormat format,
@ -107,16 +112,20 @@ GstMemory * gst_vulkan_image_memory_wrapped (GstVulkanDevice * devic
gpointer user_data, gpointer user_data,
GDestroyNotify notify); GDestroyNotify notify);
GST_VULKAN_API
gboolean gst_vulkan_image_memory_set_layout (GstVulkanImageMemory * vk_mem, gboolean gst_vulkan_image_memory_set_layout (GstVulkanImageMemory * vk_mem,
VkImageLayout, VkImageLayout,
VkImageMemoryBarrier * barrier); VkImageMemoryBarrier * barrier);
GST_VULKAN_API
guint32 gst_vulkan_image_memory_get_width (GstVulkanImageMemory * image); guint32 gst_vulkan_image_memory_get_width (GstVulkanImageMemory * image);
GST_VULKAN_API
guint32 gst_vulkan_image_memory_get_height (GstVulkanImageMemory * image); guint32 gst_vulkan_image_memory_get_height (GstVulkanImageMemory * image);
GST_VULKAN_API
VkFormat gst_vulkan_format_from_video_format (GstVideoFormat v_format, VkFormat gst_vulkan_format_from_video_format (GstVideoFormat v_format,
guint plane); guint plane);
G_END_DECLS G_END_DECLS
#endif /* _VK_IMAGE_MEMORY_H_ */ #endif /* __GST_VULKAN_IMAGE_MEMORY_H__ */

View file

@ -22,8 +22,7 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkinstance.h" #include "gstvkinstance.h"
#include "vkutils_private.h"
#include <string.h> #include <string.h>

View file

@ -18,10 +18,10 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_INSTANCE_H_ #ifndef __GST_VULKAN_INSTANCE_H__
#define _VK_INSTANCE_H_ #define __GST_VULKAN_INSTANCE_H__
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
@ -31,6 +31,7 @@ G_BEGIN_DECLS
#define GST_IS_VULKAN_INSTANCE(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_INSTANCE)) #define GST_IS_VULKAN_INSTANCE(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_INSTANCE))
#define GST_IS_VULKAN_INSTANCE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), GST_TYPE_VULKAN_INSTANCE)) #define GST_IS_VULKAN_INSTANCE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), GST_TYPE_VULKAN_INSTANCE))
#define GST_VULKAN_INSTANCE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_INSTANCE, GstVulkanInstanceClass)) #define GST_VULKAN_INSTANCE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_INSTANCE, GstVulkanInstanceClass))
GST_VULKAN_API
GType gst_vulkan_instance_get_type (void); GType gst_vulkan_instance_get_type (void);
#define GST_VULKAN_INSTANCE_CONTEXT_TYPE_STR "gst.vulkan.instance" #define GST_VULKAN_INSTANCE_CONTEXT_TYPE_STR "gst.vulkan.instance"
@ -56,26 +57,34 @@ struct _GstVulkanInstanceClass
GstObjectClass parent_class; GstObjectClass parent_class;
}; };
GST_VULKAN_API
GstVulkanInstance * gst_vulkan_instance_new (void); GstVulkanInstance * gst_vulkan_instance_new (void);
GST_VULKAN_API
gboolean gst_vulkan_instance_open (GstVulkanInstance * instance, gboolean gst_vulkan_instance_open (GstVulkanInstance * instance,
GError ** error); GError ** error);
GST_VULKAN_API
gpointer gst_vulkan_instance_get_proc_address (GstVulkanInstance * instance, gpointer gst_vulkan_instance_get_proc_address (GstVulkanInstance * instance,
const gchar * name); const gchar * name);
GST_VULKAN_API
GstVulkanDevice * gst_vulkan_instance_create_device (GstVulkanInstance * instance, GstVulkanDevice * gst_vulkan_instance_create_device (GstVulkanInstance * instance,
GError ** error); GError ** error);
GST_VULKAN_API
void gst_context_set_vulkan_instance (GstContext * context, void gst_context_set_vulkan_instance (GstContext * context,
GstVulkanInstance * instance); GstVulkanInstance * instance);
GST_VULKAN_API
gboolean gst_context_get_vulkan_instance (GstContext * context, gboolean gst_context_get_vulkan_instance (GstContext * context,
GstVulkanInstance ** instance); GstVulkanInstance ** instance);
GST_VULKAN_API
gboolean gst_vulkan_instance_handle_context_query (GstElement * element, gboolean gst_vulkan_instance_handle_context_query (GstElement * element,
GstQuery * query, GstQuery * query,
GstVulkanInstance ** instance); GstVulkanInstance ** instance);
GST_VULKAN_API
gboolean gst_vulkan_instance_run_context_query (GstElement * element, gboolean gst_vulkan_instance_run_context_query (GstElement * element,
GstVulkanInstance ** instance); GstVulkanInstance ** instance);
G_END_DECLS G_END_DECLS
#endif /* _VK_INSTANCE_H_ */ #endif /* __GST_VULKAN_INSTANCE_H__ */

View file

@ -17,11 +17,11 @@
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_MACROS_H_ #ifndef __GST_VULKAN_MACROS_H__
#define _VK_MACROS_H_ #define __GST_VULKAN_MACROS_H__
#include <gst/gst.h> #include <gst/gst.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
@ -121,4 +121,4 @@ G_BEGIN_DECLS
G_END_DECLS G_END_DECLS
#endif /*_VK_MACROS_H_ */ #endif /*__GST_VULKAN_MACROS_H__ */

View file

@ -24,7 +24,7 @@
#include <string.h> #include <string.h>
#include "vkmemory.h" #include "gstvkmemory.h"
/** /**
* SECTION:vkmemory * SECTION:vkmemory

View file

@ -18,18 +18,19 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _GST_VULKAN_BASE_BUFFER_H_ #ifndef __GST_VULKAN_BASE_BUFFER_H__
#define _GST_VULKAN_BASE_BUFFER_H_ #define __GST_VULKAN_BASE_BUFFER_H__
#include <gst/gst.h> #include <gst/gst.h>
#include <gst/gstallocator.h> #include <gst/gstallocator.h>
#include <gst/gstmemory.h> #include <gst/gstmemory.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
#define GST_TYPE_VULKAN_MEMORY_ALLOCATOR (gst_vulkan_memory_allocator_get_type()) #define GST_TYPE_VULKAN_MEMORY_ALLOCATOR (gst_vulkan_memory_allocator_get_type())
GST_VULKAN_API
GType gst_vulkan_memory_allocator_get_type(void); GType gst_vulkan_memory_allocator_get_type(void);
#define GST_IS_VULKAN_MEMORY_ALLOCATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_VULKAN_MEMORY_ALLOCATOR)) #define GST_IS_VULKAN_MEMORY_ALLOCATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_VULKAN_MEMORY_ALLOCATOR))
@ -87,15 +88,19 @@ struct _GstVulkanMemoryAllocatorClass
GstAllocatorClass parent_class; GstAllocatorClass parent_class;
}; };
GST_VULKAN_API
void gst_vulkan_memory_init_once (void); void gst_vulkan_memory_init_once (void);
GST_VULKAN_API
gboolean gst_is_vulkan_memory (GstMemory * mem); gboolean gst_is_vulkan_memory (GstMemory * mem);
GST_VULKAN_API
GstMemory * gst_vulkan_memory_alloc (GstVulkanDevice * device, GstMemory * gst_vulkan_memory_alloc (GstVulkanDevice * device,
guint32 memory_type_index, guint32 memory_type_index,
GstAllocationParams * params, GstAllocationParams * params,
gsize size, gsize size,
VkMemoryPropertyFlags mem_prop_flags); VkMemoryPropertyFlags mem_prop_flags);
GST_VULKAN_API
gboolean gst_vulkan_memory_find_memory_type_index_with_type_properties (GstVulkanDevice * device, gboolean gst_vulkan_memory_find_memory_type_index_with_type_properties (GstVulkanDevice * device,
guint32 typeBits, guint32 typeBits,
VkMemoryPropertyFlags properties, VkMemoryPropertyFlags properties,

View file

@ -22,7 +22,7 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkqueue.h" #include "gstvkqueue.h"
#define GST_CAT_DEFAULT gst_vulkan_queue_debug #define GST_CAT_DEFAULT gst_vulkan_queue_debug
GST_DEBUG_CATEGORY (GST_CAT_DEFAULT); GST_DEBUG_CATEGORY (GST_CAT_DEFAULT);
@ -168,7 +168,7 @@ gst_vulkan_queue_run_context_query (GstElement * element,
if ((query = if ((query =
gst_vulkan_local_context_query (element, gst_vulkan_local_context_query (element,
GST_VULKAN_QUEUE_CONTEXT_TYPE_STR, FALSE))) { GST_VULKAN_QUEUE_CONTEXT_TYPE_STR))) {
GstContext *context; GstContext *context;
gst_query_parse_context (query, &context); gst_query_parse_context (query, &context);

View file

@ -18,10 +18,10 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_QUEUE_H_ #ifndef __GST_VULKAN_QUEUE_H__
#define _VK_QUEUE_H_ #define __GST_VULKAN_QUEUE_H__
#include "vk.h" #include <gst/vulkan/vulkan.h>
#define GST_TYPE_VULKAN_QUEUE (gst_vulkan_queue_get_type()) #define GST_TYPE_VULKAN_QUEUE (gst_vulkan_queue_get_type())
#define GST_VULKAN_QUEUE(o) (G_TYPE_CHECK_INSTANCE_CAST((o), GST_TYPE_VULKAN_QUEUE, GstVulkanQueue)) #define GST_VULKAN_QUEUE(o) (G_TYPE_CHECK_INSTANCE_CAST((o), GST_TYPE_VULKAN_QUEUE, GstVulkanQueue))
@ -29,6 +29,7 @@
#define GST_IS_VULKAN_QUEUE(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_QUEUE)) #define GST_IS_VULKAN_QUEUE(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_QUEUE))
#define GST_IS_VULKAN_QUEUE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), GST_TYPE_VULKAN_QUEUE)) #define GST_IS_VULKAN_QUEUE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), GST_TYPE_VULKAN_QUEUE))
#define GST_VULKAN_QUEUE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_QUEUE, GstVulkanQueueClass)) #define GST_VULKAN_QUEUE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_QUEUE, GstVulkanQueueClass))
GST_VULKAN_API
GType gst_vulkan_queue_get_type (void); GType gst_vulkan_queue_get_type (void);
#define GST_VULKAN_QUEUE_CONTEXT_TYPE_STR "gst.vulkan.queue" #define GST_VULKAN_QUEUE_CONTEXT_TYPE_STR "gst.vulkan.queue"
@ -49,16 +50,21 @@ struct _GstVulkanQueueClass
GstObjectClass parent_class; GstObjectClass parent_class;
}; };
GST_VULKAN_API
GstVulkanDevice * gst_vulkan_queue_get_device (GstVulkanQueue * queue); GstVulkanDevice * gst_vulkan_queue_get_device (GstVulkanQueue * queue);
GST_VULKAN_API
void gst_context_set_vulkan_queue (GstContext * context, void gst_context_set_vulkan_queue (GstContext * context,
GstVulkanQueue * queue); GstVulkanQueue * queue);
GST_VULKAN_API
gboolean gst_context_get_vulkan_queue (GstContext * context, gboolean gst_context_get_vulkan_queue (GstContext * context,
GstVulkanQueue ** queue); GstVulkanQueue ** queue);
GST_VULKAN_API
gboolean gst_vulkan_queue_handle_context_query (GstElement * element, gboolean gst_vulkan_queue_handle_context_query (GstElement * element,
GstQuery * query, GstQuery * query,
GstVulkanQueue ** queue); GstVulkanQueue ** queue);
GST_VULKAN_API
gboolean gst_vulkan_queue_run_context_query (GstElement * element, gboolean gst_vulkan_queue_run_context_query (GstElement * element,
GstVulkanQueue ** queue); GstVulkanQueue ** queue);
#endif /* _VK_QUEUE_H_ */ #endif /* __GST_VULKAN_QUEUE_H__ */

View file

@ -22,8 +22,7 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkutils.h" #include "gstvkutils.h"
#include "vkutils_private.h"
GST_DEBUG_CATEGORY_STATIC (GST_CAT_CONTEXT); GST_DEBUG_CATEGORY_STATIC (GST_CAT_CONTEXT);
@ -85,38 +84,8 @@ gst_vulkan_run_query (GstElement * element, GstQuery * query,
return g_value_get_boolean (&res); return g_value_get_boolean (&res);
} }
void static GstQuery *
gst_vulkan_global_context_query (GstElement * element, _vulkan_local_context_query (GstElement * element,
const gchar * context_type)
{
GstQuery *query;
GstMessage *msg;
if ((query = gst_vulkan_local_context_query (element, context_type, TRUE))) {
gst_query_unref (query);
return;
}
/* 3) Post a GST_MESSAGE_NEED_CONTEXT message on the bus with
* the required context type and afterwards check if a
* usable context was set now as in 1). The message could
* be handled by the parent bins of the element and the
* application.
*/
GST_CAT_INFO_OBJECT (GST_CAT_CONTEXT, element,
"posting need context message");
msg = gst_message_new_need_context (GST_OBJECT_CAST (element), context_type);
gst_element_post_message (element, msg);
/*
* Whomever responds to the need-context message performs a
* GstElement::set_context() with the required context in which the element
* is required to update the display_ptr or call gst_vulkan_handle_set_context().
*/
}
GstQuery *
gst_vulkan_local_context_query (GstElement * element,
const gchar * context_type, gboolean set_context) const gchar * context_type, gboolean set_context)
{ {
GstQuery *query; GstQuery *query;
@ -149,6 +118,43 @@ gst_vulkan_local_context_query (GstElement * element,
return query; return query;
} }
void
gst_vulkan_global_context_query (GstElement * element,
const gchar * context_type)
{
GstQuery *query;
GstMessage *msg;
if ((query = _vulkan_local_context_query (element, context_type, TRUE))) {
gst_query_unref (query);
return;
}
/* 3) Post a GST_MESSAGE_NEED_CONTEXT message on the bus with
* the required context type and afterwards check if a
* usable context was set now as in 1). The message could
* be handled by the parent bins of the element and the
* application.
*/
GST_CAT_INFO_OBJECT (GST_CAT_CONTEXT, element,
"posting need context message");
msg = gst_message_new_need_context (GST_OBJECT_CAST (element), context_type);
gst_element_post_message (element, msg);
/*
* Whomever responds to the need-context message performs a
* GstElement::set_context() with the required context in which the element
* is required to update the display_ptr or call gst_vulkan_handle_set_context().
*/
}
GstQuery *
gst_vulkan_local_context_query (GstElement * element,
const gchar * context_type)
{
return _vulkan_local_context_query (element, context_type, FALSE);
}
static void static void
_vk_display_context_query (GstElement * element, _vk_display_context_query (GstElement * element,
GstVulkanDisplay ** display_ptr) GstVulkanDisplay ** display_ptr)

View file

@ -0,0 +1,57 @@
/*
* GStreamer
* Copyright (C) 2015 Matthew Waters <matthew@centricular.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef _VK_UTILS_H_
#define _VK_UTILS_H_
#include <gst/gst.h>
#include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS
GST_VULKAN_API
gboolean gst_vulkan_ensure_element_data (gpointer element,
GstVulkanDisplay ** display_ptr,
GstVulkanInstance ** instance_ptr);
GST_VULKAN_API
gboolean gst_vulkan_handle_set_context (GstElement * element,
GstContext * context,
GstVulkanDisplay ** display,
GstVulkanInstance ** instance);
GST_VULKAN_API
gboolean gst_vulkan_handle_context_query (GstElement * element,
GstQuery * query,
GstVulkanDisplay ** display,
GstVulkanInstance ** instance,
GstVulkanDevice ** device);
GST_VULKAN_API
void gst_vulkan_global_context_query (GstElement * element,
const gchar * context_type);
GST_VULKAN_API
GstQuery * gst_vulkan_local_context_query (GstElement * element,
const gchar * context_type);
GST_VULKAN_API
gboolean gst_vulkan_run_query (GstElement * element,
GstQuery * query,
GstPadDirection direction);
G_END_DECLS
#endif /*_VK_UTILS_H_ */

View file

@ -35,19 +35,19 @@
#include <gmodule.h> #include <gmodule.h>
#include <stdio.h> #include <stdio.h>
#include "vkwindow.h" #include "gstvkwindow.h"
#if GST_VULKAN_HAVE_WINDOW_XCB #if GST_VULKAN_HAVE_WINDOW_XCB
#include "xcb/vkwindow_xcb.h" #include "xcb/gstvkwindow_xcb.h"
#endif #endif
#if GST_VULKAN_HAVE_WINDOW_WAYLAND #if GST_VULKAN_HAVE_WINDOW_WAYLAND
#include "wayland/vkwindow_wayland.h" #include "wayland/gstvkwindow_wayland.h"
#endif #endif
#if GST_VULKAN_HAVE_WINDOW_COCOA #if GST_VULKAN_HAVE_WINDOW_COCOA
#include "cocoa/vkwindow_cocoa.h" #include "cocoa/gstvkwindow_cocoa.h"
#endif #endif
#if GST_VULKAN_HAVE_WINDOW_IOS #if GST_VULKAN_HAVE_WINDOW_IOS
#include "ios/vkwindow_ios.h" #include "ios/gstvkwindow_ios.h"
#endif #endif
#define GST_CAT_DEFAULT gst_vulkan_window_debug #define GST_CAT_DEFAULT gst_vulkan_window_debug

View file

@ -24,7 +24,7 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
@ -34,6 +34,7 @@ G_BEGIN_DECLS
#define GST_IS_VULKAN_WINDOW(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_WINDOW)) #define GST_IS_VULKAN_WINDOW(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_WINDOW))
#define GST_IS_VULKAN_WINDOW_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), GST_TYPE_VULKAN_WINDOW)) #define GST_IS_VULKAN_WINDOW_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE((k), GST_TYPE_VULKAN_WINDOW))
#define GST_VULKAN_WINDOW_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_WINDOW, GstVulkanWindowClass)) #define GST_VULKAN_WINDOW_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS((o), GST_TYPE_VULKAN_WINDOW, GstVulkanWindowClass))
GST_VULKAN_API
GType gst_vulkan_window_get_type (void); GType gst_vulkan_window_get_type (void);
#define GST_VULKAN_WINDOW_LOCK(w) g_mutex_lock(&GST_VULKAN_WINDOW(w)->lock) #define GST_VULKAN_WINDOW_LOCK(w) g_mutex_lock(&GST_VULKAN_WINDOW(w)->lock)
@ -41,6 +42,7 @@ GType gst_vulkan_window_get_type (void);
#define GST_VULKAN_WINDOW_GET_LOCK(w) (&GST_VULKAN_WINDOW(w)->lock) #define GST_VULKAN_WINDOW_GET_LOCK(w) (&GST_VULKAN_WINDOW(w)->lock)
#define GST_VULKAN_WINDOW_ERROR (gst_vulkan_window_error_quark ()) #define GST_VULKAN_WINDOW_ERROR (gst_vulkan_window_error_quark ())
GST_VULKAN_API
GQuark gst_vulkan_window_error_quark (void); GQuark gst_vulkan_window_error_quark (void);
typedef enum typedef enum
@ -94,24 +96,33 @@ struct _GstVulkanWindowClass {
gpointer _reserved[GST_PADDING]; gpointer _reserved[GST_PADDING];
}; };
GST_VULKAN_API
GstVulkanWindow * gst_vulkan_window_new (GstVulkanDisplay *display); GstVulkanWindow * gst_vulkan_window_new (GstVulkanDisplay *display);
GST_VULKAN_API
GstVulkanDisplay * gst_vulkan_window_get_display (GstVulkanWindow *window); GstVulkanDisplay * gst_vulkan_window_get_display (GstVulkanWindow *window);
GST_VULKAN_API
VkSurfaceKHR gst_vulkan_window_get_surface (GstVulkanWindow *window, VkSurfaceKHR gst_vulkan_window_get_surface (GstVulkanWindow *window,
GError **error); GError **error);
GST_VULKAN_API
gboolean gst_vulkan_window_get_presentation_support (GstVulkanWindow *window, gboolean gst_vulkan_window_get_presentation_support (GstVulkanWindow *window,
GstVulkanDevice *device, GstVulkanDevice *device,
guint32 queue_family_idx); guint32 queue_family_idx);
GST_VULKAN_API
void gst_vulkan_window_set_window_handle (GstVulkanWindow *window, void gst_vulkan_window_set_window_handle (GstVulkanWindow *window,
guintptr handle); guintptr handle);
GST_VULKAN_API
gboolean gst_vulkan_window_open (GstVulkanWindow *window, gboolean gst_vulkan_window_open (GstVulkanWindow *window,
GError ** error); GError ** error);
GST_VULKAN_API
void gst_vulkan_window_close (GstVulkanWindow *window); void gst_vulkan_window_close (GstVulkanWindow *window);
GST_VULKAN_API
void gst_vulkan_window_resize (GstVulkanWindow *window, void gst_vulkan_window_resize (GstVulkanWindow *window,
gint width, gint width,
gint height); gint height);
GST_VULKAN_API
void gst_vulkan_window_redraw (GstVulkanWindow *window); void gst_vulkan_window_redraw (GstVulkanWindow *window);
G_END_DECLS G_END_DECLS

View file

@ -1,6 +1,6 @@
/* /*
* GStreamer * GStreamer
* Copyright (C) 2019 Matthew Waters <ystreet00@gmail.com> * Copyright (C) 2019 Matthew Waters <matthew@centricular.com>
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public * modify it under the terms of the GNU Library General Public
@ -23,13 +23,14 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <vk.h>
#ifndef VK_USE_PLATFORM_IOS_MVK #ifndef VK_USE_PLATFORM_IOS_MVK
#error "VK_USE_PLATFORM_IOS_MVK not defined before including this header" #error "VK_USE_PLATFORM_IOS_MVK not defined before including this header"
#error "Either include vkapi.h or define VK_USE_PLATFORM_IOS_MVK before including this header" #error "Either include vkapi.h or define VK_USE_PLATFORM_IOS_MVK before including this header"
#endif #endif
#include <vulkan/vulkan.h> #include <vulkan/vulkan.h>
#include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
GType gst_vulkan_display_ios_get_type (void); GType gst_vulkan_display_ios_get_type (void);

View file

@ -24,7 +24,9 @@
#include <UIKit/UIKit.h> #include <UIKit/UIKit.h>
#include "vkdisplay_ios.h" #include <gst/vulkan/vulkan.h>
#include "gstvkdisplay_ios.h"
#define GST_CAT_DEFAULT gst_vulkan_display_debug #define GST_CAT_DEFAULT gst_vulkan_display_debug
GST_DEBUG_CATEGORY_STATIC (gst_vulkan_display_debug); GST_DEBUG_CATEGORY_STATIC (gst_vulkan_display_debug);

View file

@ -24,7 +24,7 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <UIKit/UIKit.h> #include <UIKit/UIKit.h>
#include "vkwindow_ios.h" #include "gstvkwindow_ios.h"
G_BEGIN_DECLS G_BEGIN_DECLS

View file

@ -1,6 +1,6 @@
/* /*
* GStreamer * GStreamer
* Copyright (C) 2019 Matthew Waters <ystreet00@gmail.com> * Copyright (C) 2019 Matthew Waters <matthew@centricular.com>
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public * modify it under the terms of the GNU Library General Public
@ -21,7 +21,7 @@
#ifndef __GST_VULKAN_WINDOW_IOS_H__ #ifndef __GST_VULKAN_WINDOW_IOS_H__
#define __GST_VULKAN_WINDOW_IOS_H__ #define __GST_VULKAN_WINDOW_IOS_H__
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS

View file

@ -26,10 +26,12 @@
#include <gst/gst.h> #include <gst/gst.h>
#include "vkwindow_ios.h" #include <gst/vulkan/vulkan.h>
#include "vkdisplay_ios.h"
#include "vkios_utils.h" #include "gstvkwindow_ios.h"
#include "gstvkdisplay_ios.h"
#include "gstvkios_utils.h"
#define GST_VULKAN_WINDOW_IOS_GET_PRIVATE(o) \ #define GST_VULKAN_WINDOW_IOS_GET_PRIVATE(o) \
(G_TYPE_INSTANCE_GET_PRIVATE((o), GST_TYPE_VULKAN_WINDOW_IOS, GstVulkanWindowIosPrivate)) (G_TYPE_INSTANCE_GET_PRIVATE((o), GST_TYPE_VULKAN_WINDOW_IOS, GstVulkanWindowIosPrivate))

View file

@ -0,0 +1,206 @@
if get_option('vulkan').disabled()
gstvulkan_dep = dependency('', required: false)
subdir_done()
endif
vulkan_sources = [
'gstvkbuffermemory.c',
'gstvkbufferpool.c',
'gstvkdevice.c',
'gstvkdisplay.c',
'gstvkerror.c',
'gstvkfence.c',
'gstvkimagememory.c',
'gstvkinstance.c',
'gstvkmemory.c',
'gstvkqueue.c',
'gstvkutils.c',
'gstvkwindow.c',
]
vulkan_headers = [
'gstvkbuffermemory.h',
'gstvkbufferpool.h',
'gstvkdevice.h',
'gstvkdisplay.h',
'gstvkerror.h',
'gstvkfence.h',
'gstvkimagememory.h',
'gstvkinstance.h',
'gstvkmemory.h',
'gstvkqueue.h',
'gstvkutils.h',
'gstvkwindow.h',
'vulkan-prelude.h',
'vulkan.h',
]
vulkan_xcb_headers = []
vulkan_wayland_headers = []
vulkan_windowing = false
vulkan_objc_args = []
vulkan_defines = []
optional_deps = []
vulkan_conf = configuration_data()
vulkan_conf_options = [
'GST_VULKAN_HAVE_WINDOW_XCB',
'GST_VULKAN_HAVE_WINDOW_WAYLAND',
'GST_VULKAN_HAVE_WINDOW_COCOA',
'GST_VULKAN_HAVE_WINDOW_IOS',
]
foreach option : vulkan_conf_options
vulkan_conf.set10(option, false)
endforeach
if host_system == 'ios'
vulkan_dep = cc.find_library('MoltenVK', required : get_option('vulkan'))
else
vulkan_dep = cc.find_library('vulkan', required : get_option('vulkan'))
endif
has_vulkan_header = cc.has_header('vulkan/vulkan.h')
if not has_vulkan_header and get_option('vulkan').enabled()
error('vulkan plugin enabled, but vulkan.h not found')
endif
xcb_dep = dependency('xcb', version : '>=1.10', required : get_option('x11'))
if xcb_dep.found()
vulkan_sources += [
'xcb/gstvkdisplay_xcb.c',
'xcb/gstvkwindow_xcb.c',
'xcb/xcb_event_source.c',
]
vulkan_xcb_headers += [
'xcb/gstvkdisplay_xcb.h'
]
optional_deps += xcb_dep
vulkan_windowing = true
vulkan_conf.set10('GST_VULKAN_HAVE_WINDOW_XCB', 1)
endif
wayland_client_dep = dependency('wayland-client', version : '>=1.4', required : get_option('wayland'))
if wayland_client_dep.found()
vulkan_sources += [
'wayland/gstvkdisplay_wayland.c',
'wayland/gstvkwindow_wayland.c',
'wayland/wayland_event_source.c',
]
vulkan_wayland_headers += [
'wayland/gstvkdisplay_wayland.h'
]
optional_deps += wayland_client_dep
vulkan_windowing = true
vulkan_conf.set10('GST_VULKAN_HAVE_WINDOW_WAYLAND', 1)
endif
if ['darwin', 'ios'].contains(host_system)
objc = meson.get_compiler('objc')
if not objc.has_argument('-fobjc-arc')
error('ARC is required for building')
endif
vulkan_objc_args += ['-fobjc-arc']
foundation_dep = dependency('appleframeworks', modules : ['Foundation'], required : get_option('vulkan'))
quartzcore_dep = dependency('appleframeworks', modules : ['QuartzCore'], required : get_option('vulkan'))
corefoundation_dep = dependency('appleframeworks', modules : ['CoreFoundation'], required : get_option('vulkan'))
if foundation_dep.found() and quartzcore_dep.found() and corefoundation_dep.found()
optional_deps += [foundation_dep, corefoundation_dep, quartzcore_dep]
endif
endif
if host_system == 'darwin'
cocoa_dep = dependency('appleframeworks', modules : ['Cocoa'], required : get_option('vulkan'))
if cocoa_dep.found()
vulkan_sources += [
'cocoa/gstvkdisplay_cocoa.m',
'cocoa/gstvkwindow_cocoa.m',
]
optional_deps += [cocoa_dep]
vulkan_windowing = true
vulkan_conf.set10('GST_VULKAN_HAVE_WINDOW_COCOA', 1)
endif
endif
if host_system == 'ios'
uikit_dep = dependency('appleframeworks', modules : ['UIKit'], required : get_option('vulkan'))
if uikit_dep.found()
vulkan_sources += [
'ios/gstvkdisplay_ios.m',
'ios/gstvkwindow_ios.m',
]
optional_deps += [uikit_dep]
vulkan_windowing = true
vulkan_conf.set10('GST_VULKAN_HAVE_WINDOW_IOS', 1)
endif
endif
if not vulkan_windowing
warning('No Windowing system found. vulkansink will not work')
endif
if vulkan_dep.found() and has_vulkan_header
gen_sources = []
install_headers(vulkan_headers, subdir : 'gstreamer-1.0/gst/vulkan')
install_headers(vulkan_xcb_headers, subdir : 'gstreamer-1.0/gst/vulkan/xcb')
install_headers(vulkan_wayland_headers, subdir : 'gstreamer-1.0/gst/vulkan/wayland')
configure_file(input : 'gstvkconfig.h.meson',
output : 'gstvkconfig.h',
install_dir : join_paths(get_option('includedir'), 'gstreamer-1.0/gst/vulkan'),
configuration : vulkan_conf)
vulkan_enums = gnome.mkenums_simple('vulkan-enumtypes',
sources : vulkan_headers,
body_prefix : '#ifdef HAVE_CONFIG_H\n#include "config.h"\n#endif',
header_prefix : '#include <gst/vulkan/vulkan-prelude.h>',
decorator : 'GST_VULKAN_API',
install_header: true,
install_dir : join_paths(get_option('includedir'), 'gstreamer-1.0/gst/vulkan'))
vulkan_enumtypes_c = vulkan_enums[0]
vulkan_enumtypes_h = vulkan_enums[1]
gen_sources += [vulkan_enumtypes_h]
gstvulkan = library('gstvulkan-' + api_version,
vulkan_sources, vulkan_enumtypes_c, vulkan_enumtypes_h,
c_args : gst_plugins_bad_args + vulkan_defines + ['-DBUILDING_GST_VULKAN'],
objc_args : gst_plugins_bad_args + vulkan_defines + vulkan_objc_args + ['-DBUILDING_GST_VULKAN'],
include_directories : [configinc, libsinc],
version : libversion,
soversion : soversion,
darwin_versions : osxversion,
install : true,
dependencies : [gstbase_dep, gstvideo_dep, vulkan_dep] + optional_deps)
if build_gir
vulkan_gir = gnome.generate_gir(gstvulkan,
sources : vulkan_sources + [vulkan_enumtypes_h, vulkan_enumtypes_c],
namespace : 'GstVulkan',
nsversion : api_version,
identifier_prefix : 'Gst',
symbol_prefix : 'gst',
export_packages : 'gstreamer-vulkan-1.0',
includes : ['Gst-1.0', 'GstBase-1.0', 'GstVideo-1.0'],
install : true,
extra_args : gir_init_section + ['--c-include=gst/vulkan/vulkan.h'],
dependencies : [gstvideo_dep, gst_dep, gstbase_dep] + optional_deps
)
gen_sources += vulkan_gir
endif
gstvulkan_dep = declare_dependency(link_with : gstvulkan,
include_directories : [libsinc],
sources: gen_sources,
dependencies : [gstvideo_dep, gstbase_dep] + optional_deps)
elif get_option('vulkan').enabled()
error('GStreamer Vulkan integration required via options, but needed dependencies not found.')
else
gstvulkan_dep = dependency('', required : false)
endif

View file

@ -1,6 +1,7 @@
/* /* GStreamer Vulkan Library
* GStreamer * Copyright (C) 2019 GStreamer developers
* Copyright (C) 2015 Matthew Waters <matthew@centricular.com> *
* vulkan-prelude.h: prelude include header for gst-vulkan library
* *
* This library is free software; you can redistribute it and/or * This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public * modify it under the terms of the GNU Library General Public
@ -17,14 +18,16 @@
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_UTILS_PRIVATE_H_
#define _VK_UTILS_PRIVATE_H_ #ifndef __GST_VULKAN_PRELUDE_H__
#define __GST_VULKAN_PRELUDE_H__
#include <gst/gst.h> #include <gst/gst.h>
#include "vk.h"
G_BEGIN_DECLS #ifdef BUILDING_GST_VULKAN
#define GST_VULKAN_API GST_API_EXPORT /* from config.h */
#else
#define GST_VULKAN_API GST_API_IMPORT
#endif
G_END_DECLS #endif /* __GST_VULKAN_PRELUDE_H__ */
#endif /*_VK_UTILS_H_ */

View file

@ -18,26 +18,25 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_H_ #ifndef __GST_VULKAN_H__
#define _VK_H_ #define __GST_VULKAN_H__
#include <gst/gst.h> #include <gst/gst.h>
#include "vkapi.h" #include <gst/vulkan/gstvkapi.h>
#include <gst/vulkan/gstvkmacros.h>
#include "vkerror.h" #include <gst/vulkan/gstvkerror.h>
#include "vkinstance.h" #include <gst/vulkan/gstvkinstance.h>
#include "vkdevice.h" #include <gst/vulkan/gstvkdevice.h>
#include "vkqueue.h" #include <gst/vulkan/gstvkqueue.h>
#include "vkfence.h" #include <gst/vulkan/gstvkfence.h>
#include "vktrash.h" #include <gst/vulkan/gstvkdisplay.h>
#include "vkdisplay.h" #include <gst/vulkan/gstvkwindow.h>
#include "vkwindow.h" #include <gst/vulkan/gstvkmemory.h>
#include "vkswapper.h" #include <gst/vulkan/gstvkbuffermemory.h>
#include "vkmemory.h" #include <gst/vulkan/gstvkimagememory.h>
#include "vkbuffermemory.h" #include <gst/vulkan/gstvkbufferpool.h>
#include "vkimagememory.h" #include <gst/vulkan/gstvkutils.h>
#include "vkbufferpool.h"
#include "vkutils.h"
#endif /* _VK_H_ */ #endif /* __GST_VULKAN_H__ */

View file

@ -18,8 +18,8 @@
* Boston, MA 02110-1301, USA. * Boston, MA 02110-1301, USA.
*/ */
#ifndef _VK_FWD_H_ #ifndef __GST_VULKAN_FWD_H__
#define _VK_FWD_H_ #define __GST_VULKAN_FWD_H__
#include <gst/gst.h> #include <gst/gst.h>
@ -46,12 +46,6 @@ typedef struct _GstVulkanWindow GstVulkanWindow;
typedef struct _GstVulkanWindowClass GstVulkanWindowClass; typedef struct _GstVulkanWindowClass GstVulkanWindowClass;
typedef struct _GstVulkanWindowPrivate GstVulkanWindowPrivate; typedef struct _GstVulkanWindowPrivate GstVulkanWindowPrivate;
typedef struct _GstVulkanSwapper GstVulkanSwapper;
typedef struct _GstVulkanSwapperClass GstVulkanSwapperClass;
typedef struct _GstVulkanSwapperPrivate GstVulkanSwapperPrivate;
typedef struct _GstVulkanTrash GstVulkanTrash;
typedef struct _GstVulkanFence GstVulkanFence; typedef struct _GstVulkanFence GstVulkanFence;
typedef struct _GstVulkanMemory GstVulkanMemory; typedef struct _GstVulkanMemory GstVulkanMemory;
@ -72,4 +66,4 @@ typedef struct _GstVulkanBufferPoolPrivate GstVulkanBufferPoolPrivate;
G_END_DECLS G_END_DECLS
#endif /* _VK_FWD_H_ */ #endif /* __GST_VULKAN_FWD_H__ */

View file

@ -22,7 +22,8 @@
#include "config.h" #include "config.h"
#endif #endif
#include "wayland/vkdisplay_wayland.h" #include <gst/vulkan/wayland/gstvkdisplay_wayland.h>
#include "wayland_event_source.h" #include "wayland_event_source.h"
GST_DEBUG_CATEGORY_STATIC (gst_vulkan_display_wayland_debug); GST_DEBUG_CATEGORY_STATIC (gst_vulkan_display_wayland_debug);

View file

@ -25,13 +25,14 @@
#include <wayland-client.h> #include <wayland-client.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
#define GST_TYPE_VULKAN_DISPLAY_WAYLAND (gst_vulkan_display_wayland_get_type())
GST_VULKAN_API
GType gst_vulkan_display_wayland_get_type (void); GType gst_vulkan_display_wayland_get_type (void);
#define GST_TYPE_VULKAN_DISPLAY_WAYLAND (gst_vulkan_display_wayland_get_type())
#define GST_VULKAN_DISPLAY_WAYLAND(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_VULKAN_DISPLAY_WAYLAND,GstVulkanDisplayWayland)) #define GST_VULKAN_DISPLAY_WAYLAND(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_VULKAN_DISPLAY_WAYLAND,GstVulkanDisplayWayland))
#define GST_VULKAN_DISPLAY_WAYLAND_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GST_TYPE_VULKAN_DISPLAY_WAYLAND,GstVulkanDisplayWaylandClass)) #define GST_VULKAN_DISPLAY_WAYLAND_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GST_TYPE_VULKAN_DISPLAY_WAYLAND,GstVulkanDisplayWaylandClass))
#define GST_IS_VULKAN_DISPLAY_WAYLAND(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_VULKAN_DISPLAY_WAYLAND)) #define GST_IS_VULKAN_DISPLAY_WAYLAND(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_VULKAN_DISPLAY_WAYLAND))
@ -68,11 +69,11 @@ struct _GstVulkanDisplayWaylandClass
#define GST_VULKAN_DISPLAY_WAYLAND_DISPLAY(display_) (GST_VULKAN_DISPLAY_WAYLAND (display_)->display) #define GST_VULKAN_DISPLAY_WAYLAND_DISPLAY(display_) (GST_VULKAN_DISPLAY_WAYLAND (display_)->display)
GST_VULKAN_API
GstVulkanDisplayWayland *gst_vulkan_display_wayland_new (const gchar * name); GstVulkanDisplayWayland *gst_vulkan_display_wayland_new (const gchar * name);
GST_VULKAN_API
GstVulkanDisplayWayland *gst_vulkan_display_wayland_new_with_display (struct wl_display *display); GstVulkanDisplayWayland *gst_vulkan_display_wayland_new_with_display (struct wl_display *display);
void gst_vulkan_display_wayland_roundtrip_async (GstVulkanDisplayWayland * display);
G_END_DECLS G_END_DECLS
#endif /* __GST_VULKAN_DISPLAY_WAYLAND_H__ */ #endif /* __GST_VULKAN_DISPLAY_WAYLAND_H__ */

View file

@ -26,10 +26,10 @@
#include <linux/input.h> #include <linux/input.h>
#include "wayland_event_source.h" #include <gst/vulkan/wayland/gstvkdisplay_wayland.h>
#include "gstvkwindow_wayland.h"
#include "vkdisplay_wayland.h" #include "wayland_event_source.h"
#include "vkwindow_wayland.h"
#define GST_CAT_DEFAULT gst_vulkan_window_wayland_debug #define GST_CAT_DEFAULT gst_vulkan_window_wayland_debug
GST_DEBUG_CATEGORY_STATIC (GST_CAT_DEFAULT); GST_DEBUG_CATEGORY_STATIC (GST_CAT_DEFAULT);

View file

@ -24,11 +24,13 @@
#include <wayland-client.h> #include <wayland-client.h>
#include <wayland-cursor.h> #include <wayland-cursor.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
#define GST_TYPE_VULKAN_WINDOW_WAYLAND (gst_vulkan_window_wayland_get_type()) #define GST_TYPE_VULKAN_WINDOW_WAYLAND (gst_vulkan_window_wayland_get_type())
GType gst_vulkan_window_wayland_get_type (void);
#define GST_VULKAN_WINDOW_WAYLAND(o) (G_TYPE_CHECK_INSTANCE_CAST((o), GST_TYPE_VULKAN_WINDOW_WAYLAND, GstVulkanWindowWayland)) #define GST_VULKAN_WINDOW_WAYLAND(o) (G_TYPE_CHECK_INSTANCE_CAST((o), GST_TYPE_VULKAN_WINDOW_WAYLAND, GstVulkanWindowWayland))
#define GST_VULKAN_WINDOW_WAYLAND_CLASS(k) (G_TYPE_CHECK_CLASS((k), GST_TYPE_VULKAN_WINDOW_WAYLAND, GstVulkanWindowWaylandClass)) #define GST_VULKAN_WINDOW_WAYLAND_CLASS(k) (G_TYPE_CHECK_CLASS((k), GST_TYPE_VULKAN_WINDOW_WAYLAND, GstVulkanWindowWaylandClass))
#define GST_IS_VULKAN_WINDOW_WAYLAND(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_WINDOW_WAYLAND)) #define GST_IS_VULKAN_WINDOW_WAYLAND(o) (G_TYPE_CHECK_INSTANCE_TYPE((o), GST_TYPE_VULKAN_WINDOW_WAYLAND))
@ -65,8 +67,6 @@ struct _GstVulkanWindowWaylandClass {
gpointer _reserved[GST_PADDING]; gpointer _reserved[GST_PADDING];
}; };
GType gst_vulkan_window_wayland_get_type (void);
GstVulkanWindowWayland * gst_vulkan_window_wayland_new (GstVulkanDisplay * display); GstVulkanWindowWayland * gst_vulkan_window_wayland_new (GstVulkanDisplay * display);
G_END_DECLS G_END_DECLS

View file

@ -37,6 +37,8 @@
#include <stdlib.h> #include <stdlib.h>
#include <wayland-client.h> #include <wayland-client.h>
#include <gst/vulkan/wayland/gstvkdisplay_wayland.h>
#include "wayland_event_source.h" #include "wayland_event_source.h"
static void static void

View file

@ -28,7 +28,11 @@
GSource * wayland_event_source_new (struct wl_display *display, GSource * wayland_event_source_new (struct wl_display *display,
struct wl_event_queue *queue); struct wl_event_queue *queue);
G_GNUC_INTERNAL gint gst_vulkan_wl_display_roundtrip_queue (struct wl_display *display, G_GNUC_INTERNAL
void gst_vulkan_display_wayland_roundtrip_async (GstVulkanDisplayWayland * display);
G_GNUC_INTERNAL
gint gst_vulkan_wl_display_roundtrip_queue (struct wl_display *display,
struct wl_event_queue *queue); struct wl_event_queue *queue);
#endif /* __WAYLAND_EVENT_SOURCE_H__ */ #endif /* __WAYLAND_EVENT_SOURCE_H__ */

View file

@ -22,7 +22,9 @@
#include "config.h" #include "config.h"
#endif #endif
#include "vkdisplay_xcb.h" #include <gst/vulkan/gstvkapi.h>
#include <gst/vulkan/xcb/gstvkdisplay_xcb.h>
#include "xcb_event_source.h" #include "xcb_event_source.h"
#define GST_CAT_DEFAULT gst_vulkan_display_debug #define GST_CAT_DEFAULT gst_vulkan_display_debug

View file

@ -25,15 +25,17 @@
#include <xcb/xcb.h> #include <xcb/xcb.h>
#include <vk.h>
#ifndef VK_USE_PLATFORM_XCB_KHR #ifndef VK_USE_PLATFORM_XCB_KHR
#error "VK_USE_PLATFORM_XCB_KHR not defined before including this header" #error "VK_USE_PLATFORM_XCB_KHR not defined before including this header"
#error "Either include vkapi.h or define VK_USE_PLATFORM_XCB_KHR before including this header" #error "Either include vkapi.h or define VK_USE_PLATFORM_XCB_KHR before including this header"
#endif #endif
#include <vulkan/vulkan.h> #include <vulkan/vulkan.h>
#include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS
GST_VULKAN_API
GType gst_vulkan_display_xcb_get_type (void); GType gst_vulkan_display_xcb_get_type (void);
#define GST_TYPE_VULKAN_DISPLAY_XCB (gst_vulkan_display_xcb_get_type()) #define GST_TYPE_VULKAN_DISPLAY_XCB (gst_vulkan_display_xcb_get_type())
@ -75,7 +77,9 @@ struct _GstVulkanDisplayXCBClass
GstVulkanDisplayClass object_class; GstVulkanDisplayClass object_class;
}; };
GST_VULKAN_API
GstVulkanDisplayXCB * gst_vulkan_display_xcb_new (const gchar * name); GstVulkanDisplayXCB * gst_vulkan_display_xcb_new (const gchar * name);
GST_VULKAN_API
GstVulkanDisplayXCB * gst_vulkan_display_xcb_new_with_connection (xcb_connection_t * connection, GstVulkanDisplayXCB * gst_vulkan_display_xcb_new_with_connection (xcb_connection_t * connection,
int screen_no); int screen_no);

View file

@ -25,8 +25,8 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <locale.h> #include <locale.h>
#include "vkwindow_xcb.h" #include "gstvkwindow_xcb.h"
#include "vkdisplay_xcb.h" #include "gstvkdisplay_xcb.h"
#define GST_VULKAN_WINDOW_XCB_GET_PRIVATE(o) \ #define GST_VULKAN_WINDOW_XCB_GET_PRIVATE(o) \
(G_TYPE_INSTANCE_GET_PRIVATE((o), GST_TYPE_VULKAN_WINDOW_XCB, GstVulkanWindowXCBPrivate)) (G_TYPE_INSTANCE_GET_PRIVATE((o), GST_TYPE_VULKAN_WINDOW_XCB, GstVulkanWindowXCBPrivate))

View file

@ -23,7 +23,7 @@
#include <xcb/xcb.h> #include <xcb/xcb.h>
#include <vk.h> #include <gst/vulkan/vulkan.h>
G_BEGIN_DECLS G_BEGIN_DECLS

View file

@ -25,9 +25,12 @@
#include <stdint.h> #include <stdint.h>
#include <stdlib.h> #include <stdlib.h>
#include <gst/vulkan/gstvkapi.h>
#include <gst/vulkan/xcb/gstvkdisplay_xcb.h>
#include "gstvkwindow_xcb.h"
#include "xcb_event_source.h" #include "xcb_event_source.h"
#include "vkdisplay_xcb.h"
#include "vkwindow_xcb.h"
static gint static gint
_compare_xcb_window (GstVulkanWindowXCB * window_xcb, xcb_window_t * window_id) _compare_xcb_window (GstVulkanWindowXCB * window_xcb, xcb_window_t * window_id)

View file

@ -22,7 +22,6 @@
#define __VULKAN_XCB_EVENT_SOURCE_H__ #define __VULKAN_XCB_EVENT_SOURCE_H__
#include <glib-object.h> #include <glib-object.h>
#include "vkdisplay_xcb.h"
GSource * GSource *
xcb_event_source_new (GstVulkanDisplayXCB *display_xcb); xcb_event_source_new (GstVulkanDisplayXCB *display_xcb);

View file

@ -0,0 +1,12 @@
prefix=
exec_prefix=
libdir=@vulkanlibdir@
includedir=@abs_top_srcdir@/gst-libs
Name: GStreamer Vulkan, Uninstalled
Description: GStreamer Vulkan support, uninstalled
Requires: gstreamer-@GST_API_VERSION@ gstreamer-base-@GST_API_VERSION@ gstreamer-video-@GST_API_VERSION@
Version: @VERSION@
Libs: -L${libdir} -lgstvulkan-@GST_API_VERSION@
Cflags: -I@abs_top_srcdir@/gst-libs -I@abs_top_builddir@/gst-libs

View file

@ -0,0 +1,12 @@
prefix=@prefix@
exec_prefix=@exec_prefix@
libdir=@libdir@
includedir=@includedir@/gstreamer-@GST_API_VERSION@
Name: GStreamer Vulkan
Description: GStreamer Vulkan support
Requires: gstreamer-@GST_API_VERSION@ gstreamer-base-@GST_API_VERSION@ gstreamer-video-@GST_API_VERSION@
Version: @VERSION@
Libs: -L${libdir} -lgstvulkan-@GST_API_VERSION@
Cflags: -I${includedir}

View file

@ -37,6 +37,11 @@ pkg_libs = [
# pkg_libs += 'wayland' # pkg_libs += 'wayland'
#endif #endif
if gstvulkan_dep.found()
pkgconf.set('vulkanlibdir', join_paths(meson.build_root(), gstvulkan.outdir()))
pkg_libs += 'vulkan'
endif
foreach p : pkg_libs foreach p : pkg_libs
infile = 'gstreamer-@0@.pc.in'.format(p) infile = 'gstreamer-@0@.pc.in'.format(p)
outfile = 'gstreamer-@0@-@1@.pc'.format(p, api_version) outfile = 'gstreamer-@0@-@1@.pc'.format(p, api_version)