[gtk+/wip/otte/vulkan: 21/62] vulkan: Initial support



commit cca547e5bccda95fd8bf283bec1bfc7b564e88f6
Author: Benjamin Otte <otte redhat com>
Date:   Mon Nov 21 14:18:43 2016 +0100

    vulkan: Initial support
    
    Adds the gdk_display_ref_vulkan() and gdk_display_unref_vulkan()
    functions which setup/tear down VUlkan support for the display.
    
    Nothing is using those functions yet.

 gdk/Makefile.am                |    3 +
 gdk/gdk.c                      |    3 +-
 gdk/gdk.h                      |    1 +
 gdk/gdkdisplayprivate.h        |   13 ++-
 gdk/gdkinternals.h             |    1 +
 gdk/gdktypes.h                 |    1 +
 gdk/gdkvulkancontext.c         |  358 ++++++++++++++++++++++++++++++++++++++++
 gdk/gdkvulkancontext.h         |   52 ++++++
 gdk/gdkvulkancontextprivate.h  |   82 +++++++++
 gdk/x11/Makefile.am            |    2 +
 gdk/x11/gdkvulkancontext-x11.c |   32 ++++
 gdk/x11/gdkvulkancontext-x11.h |   51 ++++++
 12 files changed, 596 insertions(+), 3 deletions(-)
---
diff --git a/gdk/Makefile.am b/gdk/Makefile.am
index 08d40a6..7b69289 100644
--- a/gdk/Makefile.am
+++ b/gdk/Makefile.am
@@ -91,6 +91,7 @@ gdk_public_h_sources =                                \
        gdkthreads.h                            \
        gdktypes.h                              \
        gdkvisual.h                             \
+       gdkvulkancontext.h                      \
        gdkwindow.h
 
 gdk_h_sources =                                        \
@@ -120,6 +121,7 @@ gdk_private_headers =                               \
        gdkintl.h                               \
        gdkkeysprivate.h                        \
        gdkvisualprivate.h                      \
+       gdkvulkancontextprivate.h               \
        gdkx.h
 
 gdk_c_sources =                                \
@@ -157,6 +159,7 @@ gdk_c_sources =                             \
        gdkseatdefault.c                        \
        gdkselection.c                          \
        gdkvisual.c                             \
+       gdkvulkancontext.c                      \
        gdkwindow.c                             \
        gdkwindowimpl.c
 
diff --git a/gdk/gdk.c b/gdk/gdk.c
index 050dfe6..a59a874 100644
--- a/gdk/gdk.c
+++ b/gdk/gdk.c
@@ -165,7 +165,8 @@ static const GDebugKey gdk_debug_keys[] = {
   { "eventloop",     GDK_DEBUG_EVENTLOOP },
   { "frames",        GDK_DEBUG_FRAMES },
   { "settings",      GDK_DEBUG_SETTINGS },
-  { "opengl",        GDK_DEBUG_OPENGL }
+  { "opengl",        GDK_DEBUG_OPENGL },
+  { "vulkan",        GDK_DEBUG_VULKAN }
 };
 
 static gboolean
diff --git a/gdk/gdk.h b/gdk/gdk.h
index 2a93357..4f6c4c4 100644
--- a/gdk/gdk.h
+++ b/gdk/gdk.h
@@ -62,6 +62,7 @@
 #include <gdk/gdkthreads.h>
 #include <gdk/gdktypes.h>
 #include <gdk/gdkvisual.h>
+#include <gdk/gdkvulkancontext.h>
 #include <gdk/gdkwindow.h>
 
 #include <gdk/gdk-autocleanup.h>
diff --git a/gdk/gdkdisplayprivate.h b/gdk/gdkdisplayprivate.h
index 5664776..c90c611 100644
--- a/gdk/gdkdisplayprivate.h
+++ b/gdk/gdkdisplayprivate.h
@@ -24,6 +24,10 @@
 #include "gdkmonitor.h"
 #include "gdkinternals.h"
 
+#ifdef GDK_WINDOWING_VULKAN
+#include <vulkan/vulkan.h>
+#endif
+
 G_BEGIN_DECLS
 
 #define GDK_DISPLAY_CLASS(klass)      (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_DISPLAY, GdkDisplayClass))
@@ -120,9 +124,14 @@ struct _GdkDisplay
   guint double_click_time;  /* Maximum time between clicks in msecs */
   guint double_click_distance;   /* Maximum distance between clicks in pixels */
 
-  guint has_gl_extension_texture_non_power_of_two : 1;
-  guint has_gl_extension_texture_rectangle : 1;
+#ifdef GDK_WINDOWING_VULKAN
+  VkInstance vk_instance;
+  VkPhysicalDevice vk_physical_device;
+  VkDevice vk_device;
+  VkQueue vk_queue;
 
+  guint vulkan_refcount;
+#endif /* GDK_WINDOWING_VULKAN */
   guint rgba : 1;
   guint composited : 1;
 
diff --git a/gdk/gdkinternals.h b/gdk/gdkinternals.h
index 7bce8f9..1ea17e3 100644
--- a/gdk/gdkinternals.h
+++ b/gdk/gdkinternals.h
@@ -69,6 +69,7 @@ typedef enum {
   GDK_DEBUG_FRAMES        = 1 << 11,
   GDK_DEBUG_SETTINGS      = 1 << 12,
   GDK_DEBUG_OPENGL        = 1 << 13,
+  GDK_DEBUG_VULKAN        = 1 << 14
 } GdkDebugFlag;
 
 typedef enum {
diff --git a/gdk/gdktypes.h b/gdk/gdktypes.h
index 8c4dfe5..2172304 100644
--- a/gdk/gdktypes.h
+++ b/gdk/gdktypes.h
@@ -147,6 +147,7 @@ typedef struct _GdkSeat               GdkSeat;
 typedef struct _GdkDrawingContext     GdkDrawingContext;
 typedef struct _GdkDrawContext        GdkDrawContext;
 typedef struct _GdkGLContext          GdkGLContext;
+typedef struct _GdkVulkanContext      GdkVulkanContext;
 
 /**
  * GdkByteOrder:
diff --git a/gdk/gdkvulkancontext.c b/gdk/gdkvulkancontext.c
new file mode 100644
index 0000000..462ca46
--- /dev/null
+++ b/gdk/gdkvulkancontext.c
@@ -0,0 +1,358 @@
+/* GDK - The GIMP Drawing Kit
+ *
+ * gdkvulkancontext-x11.c: X11 specific Vulkan wrappers
+ *
+ * Copyright © 2016  Benjamin Otte
+ *
+ * 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "config.h"
+
+#include "gdkvulkancontextprivate.h"
+
+#include <vulkan/vulkan.h>
+
+#include "gdkdisplayprivate.h"
+#include "gdkinternals.h"
+#include "gdkintl.h"
+
+typedef struct _GdkVulkanContextPrivate GdkVulkanContextPrivate;
+
+struct _GdkVulkanContextPrivate {
+  GdkWindow *window;
+};
+
+enum {
+  PROP_0,
+
+  PROP_DISPLAY,
+  PROP_WINDOW,
+
+  LAST_PROP
+};
+
+static GParamSpec *pspecs[LAST_PROP] = { NULL, };
+
+G_DEFINE_QUARK (gdk-vulkan-error-quark, gdk_vulkan_error)
+
+G_DEFINE_ABSTRACT_TYPE_WITH_PRIVATE (GdkVulkanContext, gdk_vulkan_context, G_TYPE_OBJECT)
+
+static void
+gdk_vulkan_context_dispose (GObject *gobject)
+{
+  GdkVulkanContext *context = GDK_VULKAN_CONTEXT (gobject);
+  GdkVulkanContextPrivate *priv = gdk_vulkan_context_get_instance_private (context);
+
+  g_clear_object (&priv->window);
+
+  G_OBJECT_CLASS (gdk_vulkan_context_parent_class)->dispose (gobject);
+}
+
+static void
+gdk_vulkan_context_set_property (GObject      *gobject,
+                                 guint         prop_id,
+                                 const GValue *value,
+                                 GParamSpec   *pspec)
+{
+  GdkVulkanContext *context = GDK_VULKAN_CONTEXT (gobject);
+  GdkVulkanContextPrivate *priv = gdk_vulkan_context_get_instance_private (context);
+
+  switch (prop_id)
+    {
+    case PROP_WINDOW:
+      priv->window = g_value_dup_object (value);
+      g_assert (priv->window != NULL);
+      break;
+
+    default:
+      G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);
+    }
+}
+
+static void
+gdk_vulkan_context_get_property (GObject    *gobject,
+                                 guint       prop_id,
+                                 GValue     *value,
+                                 GParamSpec *pspec)
+{
+  GdkVulkanContext *context = GDK_VULKAN_CONTEXT (gobject);
+  GdkVulkanContextPrivate *priv = gdk_vulkan_context_get_instance_private (context);
+
+  switch (prop_id)
+    {
+    case PROP_DISPLAY:
+      g_value_set_object (value, gdk_vulkan_context_get_display (context));
+      break;
+
+    case PROP_WINDOW:
+      g_value_set_object (value, priv->window);
+      break;
+
+    default:
+      G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec);
+    }
+}
+
+static void
+gdk_vulkan_context_class_init (GdkVulkanContextClass *klass)
+{
+  GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
+
+  gobject_class->set_property = gdk_vulkan_context_set_property;
+  gobject_class->get_property = gdk_vulkan_context_get_property;
+  gobject_class->dispose = gdk_vulkan_context_dispose;
+
+  /**
+   * GdkVulkanContext:display:
+   *
+   * The #GdkDisplay used to create the #GdkVulkanContext.
+   *
+   * Since: 3.16
+   */
+  pspecs[PROP_DISPLAY] =
+    g_param_spec_object ("display",
+                         P_("Display"),
+                         P_("The GDK display used to create the Vulkan context"),
+                         GDK_TYPE_DISPLAY,
+                         G_PARAM_READABLE |
+                         G_PARAM_STATIC_STRINGS);
+
+  /**
+   * GdkVulkanContext:window:
+   *
+   * The #GdkWindow the gl context is bound to.
+   *
+   * Since: 3.16
+   */
+  pspecs[PROP_WINDOW] =
+    g_param_spec_object ("window",
+                         P_("Window"),
+                         P_("The GDK window bound to the Vulkan context"),
+                         GDK_TYPE_WINDOW,
+                         G_PARAM_READWRITE |
+                         G_PARAM_CONSTRUCT_ONLY |
+                         G_PARAM_STATIC_STRINGS);
+
+  g_object_class_install_properties (gobject_class, LAST_PROP, pspecs);
+}
+
+static void
+gdk_vulkan_context_init (GdkVulkanContext *self)
+{
+}
+
+/**
+ * gdk_vulkan_context_get_display:
+ * @context: a #GdkVulkanContext
+ *
+ * Retrieves the #GdkDisplay the @context is created for
+ *
+ * Returns: (nullable) (transfer none): a #GdkDisplay or %NULL
+ *
+ * Since: 3.90
+ */
+GdkDisplay *
+gdk_vulkan_context_get_display (GdkVulkanContext *context)
+{
+  GdkVulkanContextPrivate *priv = gdk_vulkan_context_get_instance_private (context);
+
+  g_return_val_if_fail (GDK_IS_VULKAN_CONTEXT (context), NULL);
+
+  return priv->window ? gdk_window_get_display (priv->window) : NULL;
+}
+
+/**
+ * gdk_vulkan_context_get_window:
+ * @context: a #GdkVulkanContext
+ *
+ * Retrieves the #GdkWindow used by the @context.
+ *
+ * Returns: (nullable) (transfer none): a #GdkWindow or %NULL
+ *
+ * Since: 3.90
+ */
+GdkWindow *
+gdk_vulkan_context_get_window (GdkVulkanContext *context)
+{
+  GdkVulkanContextPrivate *priv = gdk_vulkan_context_get_instance_private (context);
+
+  g_return_val_if_fail (GDK_IS_VULKAN_CONTEXT (context), NULL);
+
+  return priv->window;
+}
+
+#ifdef GDK_WINDOWING_VULKAN
+
+static gboolean
+gdk_display_create_vulkan_device (GdkDisplay *display)
+{
+  uint32_t i, j;
+
+  uint32_t n_devices;
+  GDK_VK_CHECK(vkEnumeratePhysicalDevices, display->vk_instance, &n_devices, NULL);
+  VkPhysicalDevice devices[n_devices];
+  GDK_VK_CHECK(vkEnumeratePhysicalDevices, display->vk_instance, &n_devices, devices);
+
+  for (i = 0; i < n_devices; i++)
+    {
+      VkPhysicalDeviceProperties props;
+
+      vkGetPhysicalDeviceProperties (devices[i], &props);
+
+      GDK_NOTE (VULKAN, g_print ("Vulkan Device %u:\n", i));
+      GDK_NOTE (VULKAN, g_print ("    %s (%u)\n", props.deviceName, props.deviceType));
+      GDK_NOTE (VULKAN, g_print ("    vendor ID: 0x%Xu\n", props.vendorID));
+      GDK_NOTE (VULKAN, g_print ("    device ID: 0x%Xu\n", props.deviceID));
+      GDK_NOTE (VULKAN, g_print ("    API version %u.%u.%u\n",
+                                 VK_VERSION_MAJOR (props.apiVersion),
+                                 VK_VERSION_MINOR (props.apiVersion),
+                                 VK_VERSION_PATCH (props.apiVersion)));
+      GDK_NOTE (VULKAN, g_print ("    driver version %u.%u.%u\n",
+                                 VK_VERSION_MAJOR (props.driverVersion),
+                                 VK_VERSION_MINOR (props.driverVersion),
+                                 VK_VERSION_PATCH (props.driverVersion)));
+
+      uint32_t n_queue_props;
+      vkGetPhysicalDeviceQueueFamilyProperties (devices[i], &n_queue_props, NULL);
+      VkQueueFamilyProperties queue_props[n_queue_props];
+      vkGetPhysicalDeviceQueueFamilyProperties (devices[i], &n_queue_props, queue_props);
+
+      for (j = 0; j < n_queue_props; j++)
+        {
+          GDK_NOTE (VULKAN, g_print ("    queue %u/%u: %s\n", j, n_queue_props, queue_props[j].queueFlags & 
VK_QUEUE_GRAPHICS_BIT ? "graphics" : "no graphics"));
+          if (queue_props[j].queueFlags & VK_QUEUE_GRAPHICS_BIT)
+            {
+              GDK_NOTE (VULKAN, g_print ("    => trying this queue\n"));
+              if (GDK_VK_CHECK (vkCreateDevice, devices[i],
+                                                &(VkDeviceCreateInfo) {
+                                                    VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO,
+                                                    NULL,
+                                                    0,
+                                                    1,
+                                                    &(VkDeviceQueueCreateInfo) {
+                                                        .sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO,
+                                                        .queueFamilyIndex = j,
+                                                        .queueCount = 1,
+                                                        .pQueuePriorities = (float []) { 1.0f },
+                                                    },
+                                                    0,
+                                                    NULL,
+                                                    1,
+                                                    (const char * const []) {
+                                                       VK_KHR_SWAPCHAIN_EXTENSION_NAME,
+                                                    },
+                                                },
+                                                NULL,
+                                                &display->vk_device) != VK_SUCCESS)
+                continue;
+
+              display->vk_physical_device = devices[i];
+              vkGetDeviceQueue(display->vk_device, j, 0, &display->vk_queue);
+              return TRUE;
+            }
+        }
+    }
+
+  return FALSE;
+}
+
+static gboolean
+gdk_display_create_vulkan_instance (GdkDisplay *display,
+                                    const char *wsi_extension_name)
+{
+  uint32_t i;
+
+  uint32_t n_extensions;
+  GDK_VK_CHECK (vkEnumerateInstanceExtensionProperties, NULL, &n_extensions, NULL);
+  VkExtensionProperties extensions[n_extensions];
+  GDK_VK_CHECK (vkEnumerateInstanceExtensionProperties, NULL, &n_extensions, extensions);
+
+  for (i = 0; i < n_extensions; i++)
+    {
+      GDK_NOTE (VULKAN, g_print ("Extension available: %s v%u.%u.%u\n",
+                                 extensions[i].extensionName,
+                                 VK_VERSION_MAJOR (extensions[i].specVersion),
+                                 VK_VERSION_MINOR (extensions[i].specVersion),
+                                 VK_VERSION_PATCH (extensions[i].specVersion)));
+    }
+
+  uint32_t n_layers;
+  GDK_VK_CHECK (vkEnumerateInstanceLayerProperties, &n_layers, NULL);
+  VkLayerProperties layers[n_layers];
+  GDK_VK_CHECK (vkEnumerateInstanceLayerProperties, &n_layers, layers);
+
+  for (i = 0; i < n_layers; i++)
+    {
+      GDK_NOTE (VULKAN, g_print ("Layer available: %s v%u.%u.%u (%s)\n",
+                                 layers[i].layerName,
+                                 VK_VERSION_MAJOR (layers[i].specVersion),
+                                 VK_VERSION_MINOR (layers[i].specVersion),
+                                 VK_VERSION_PATCH (layers[i].specVersion),
+                                 layers[i].description));
+    }
+
+  if (GDK_VK_CHECK (vkCreateInstance, &(VkInstanceCreateInfo) {
+                                           VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO,
+                                           NULL,
+                                           0,
+                                           &(VkApplicationInfo) {
+                                                VK_STRUCTURE_TYPE_APPLICATION_INFO,
+                                                NULL,
+                                                g_get_application_name (),
+                                                0,
+                                                "GTK+",
+                                                VK_MAKE_VERSION (GDK_MAJOR_VERSION, GDK_MINOR_VERSION, 
GDK_MICRO_VERSION),
+                                                VK_API_VERSION_1_0 },
+                                           0,
+                                           NULL,
+                                           1,
+                                           &wsi_extension_name },
+                                       NULL,
+                                       &display->vk_instance) != VK_SUCCESS)
+    return FALSE;
+
+  return gdk_display_create_vulkan_device (display);
+}
+
+gboolean
+gdk_display_ref_vulkan (GdkDisplay *display,
+                        const char *wsi_extension_name)
+{
+  if (display->vulkan_refcount == 0)
+    {
+      if (!gdk_display_create_vulkan_instance (display, wsi_extension_name))
+        return FALSE;
+    }
+
+  display->vulkan_refcount++;
+    
+  return TRUE;
+}
+
+void
+gdk_display_unref_vulkan (GdkDisplay *display)
+{
+  g_return_if_fail (GDK_IS_DISPLAY (display));
+  g_return_if_fail (display->vulkan_refcount > 0);
+
+  display->vulkan_refcount--;
+  if (display->vulkan_refcount > 0)
+    return;
+  
+  vkDestroyDevice (display->vk_device, NULL);
+  vkDestroyInstance (display->vk_instance, NULL);
+}
+
+#endif /* GDK_WINDOWING_VULKAN */
diff --git a/gdk/gdkvulkancontext.h b/gdk/gdkvulkancontext.h
new file mode 100644
index 0000000..7a042f0
--- /dev/null
+++ b/gdk/gdkvulkancontext.h
@@ -0,0 +1,52 @@
+/* GDK - The GIMP Drawing Kit
+ *
+ * gdkvulkancontext.h:  specific Vulkan wrappers
+ *
+ * Copyright © 2016  Benjamin Otte
+ *
+ * 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __GDK_VULKAN_CONTEXT__
+#define __GDK_VULKAN_CONTEXT__
+
+#if !defined (__GDK_H_INSIDE__) && !defined (GDK_COMPILATION)
+#error "Only <gdk/gdk.h> can be included directly."
+#endif
+
+#include <gdk/gdkversionmacros.h>
+#include <gdk/gdktypes.h>
+
+G_BEGIN_DECLS
+
+#define GDK_TYPE_VULKAN_CONTEXT             (gdk_vulkan_context_get_type ())
+#define GDK_VULKAN_CONTEXT(obj)             (G_TYPE_CHECK_INSTANCE_CAST ((obj), GDK_TYPE_VULKAN_CONTEXT, 
GdkVulkanContext))
+#define GDK_IS_VULKAN_CONTEXT(obj)          (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GDK_TYPE_VULKAN_CONTEXT))
+
+#define GDK_VULKAN_ERROR                    (gdk_vulkan_error_quark ())
+
+GDK_AVAILABLE_IN_3_90
+GQuark gdk_vulkan_error_quark (void);
+
+GDK_AVAILABLE_IN_3_90
+GType gdk_vulkan_context_get_type (void) G_GNUC_CONST;
+
+GDK_AVAILABLE_IN_3_90
+GdkDisplay *            gdk_vulkan_context_get_display              (GdkVulkanContext  *context);
+GDK_AVAILABLE_IN_3_90
+GdkWindow *             gdk_vulkan_context_get_window               (GdkVulkanContext  *context);
+
+G_END_DECLS
+
+#endif /* __GDK_VULKAN_CONTEXT__ */
diff --git a/gdk/gdkvulkancontextprivate.h b/gdk/gdkvulkancontextprivate.h
new file mode 100644
index 0000000..7bed0d9
--- /dev/null
+++ b/gdk/gdkvulkancontextprivate.h
@@ -0,0 +1,82 @@
+/* GDK - The GIMP Drawing Kit
+ *
+ * gdkvulkancontext-x11.h:  specific Vulkan wrappers
+ *
+ * Copyright © 2016  Benjamin Otte
+ *
+ * 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __GDK_VULKAN_CONTEXT_PRIVATE__
+#define __GDK_VULKAN_CONTEXT_PRIVATE__
+
+#include "gdkvulkancontext.h"
+
+#include "gdkinternals.h"
+
+#include <vulkan/vulkan.h>
+
+G_BEGIN_DECLS
+
+#define GDK_VULKAN_CONTEXT_CLASS(klass)        (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_VULKAN_CONTEXT, 
GdkVulkanContextClass))
+#define GDK_IS_VULKAN_CONTEXT_CLASS(klass)     (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_VULKAN_CONTEXT))
+#define GDK_VULKAN_CONTEXT_GET_CLASS(obj)      (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_VULKAN_CONTEXT, 
GdkVulkanContextClass))
+
+typedef struct _GdkVulkanContextClass GdkVulkanContextClass;
+
+struct _GdkVulkanContext
+{
+  GObject parent_instance;
+};
+
+struct _GdkVulkanContextClass
+{
+  GObjectClass parent_class;
+};
+
+#ifdef GDK_WINDOWING_VULKAN
+
+static inline VkResult
+gdk_vulkan_handle_result (VkResult    res,
+                          const char *called_function)
+{
+  if (res != VK_SUCCESS)
+    {
+      GDK_NOTE (VULKAN,g_printerr ("%s(): %d\n", called_function, res));
+    }
+  return res;
+}
+
+#define GDK_VK_CHECK(func, ...) gdk_vulkan_handle_result (func (__VA_ARGS__), G_STRINGIFY (func))
+
+gboolean        gdk_display_ref_vulkan                          (GdkDisplay      *display,
+                                                                 const char      *wsi_extension_name);
+void            gdk_display_unref_vulkan                        (GdkDisplay      *display);
+
+#else /* !GDK_WINDOWING_VULKAN */
+
+static inline gboolean
+gdk_display_init_vulkan (GdkDisplay *display,
+                         const char *wsi_extension_name)
+{
+  GDK_NOTE (VULKAN, g_print ("Support for Vulkan disabled at compile-time"));
+
+  return FALSE;
+}
+
+#endif /* !GDK_WINDOWING_VULKAN */
+
+G_END_DECLS
+
+#endif /* __GDK__VULKAN_CONTEXT_PRIVATE__ */
diff --git a/gdk/x11/Makefile.am b/gdk/x11/Makefile.am
index c233520..d1f6df8 100644
--- a/gdk/x11/Makefile.am
+++ b/gdk/x11/Makefile.am
@@ -52,6 +52,8 @@ libgdk_x11_la_SOURCES =       \
        gdkselection-x11.c      \
        gdktestutils-x11.c      \
        gdkvisual-x11.c         \
+       gdkvulkancontext-x11.c  \
+       gdkvulkancontext-x11.h  \
        gdkwindow-x11.c         \
        gdkwindow-x11.h         \
        gdkxftdefaults.c        \
diff --git a/gdk/x11/gdkvulkancontext-x11.c b/gdk/x11/gdkvulkancontext-x11.c
new file mode 100644
index 0000000..cb0bda2
--- /dev/null
+++ b/gdk/x11/gdkvulkancontext-x11.c
@@ -0,0 +1,32 @@
+/* GDK - The GIMP Drawing Kit
+ *
+ * gdkvulkancontext-x11.c: X11 specific Vulkan wrappers
+ *
+ * Copyright © 2016  Benjamin Otte
+ *
+ * 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifdef GDK_WINDOWING_VULKAN
+
+#include "config.h"
+
+#include "gdkvulkancontext-x11.h"
+
+#include <vulkan/vulkan.h>
+
+#include "gdkinternals.h"
+
+#endif /* GDK_WINDOWING_VULKAN */
+
diff --git a/gdk/x11/gdkvulkancontext-x11.h b/gdk/x11/gdkvulkancontext-x11.h
new file mode 100644
index 0000000..d4268df
--- /dev/null
+++ b/gdk/x11/gdkvulkancontext-x11.h
@@ -0,0 +1,51 @@
+/* GDK - The GIMP Drawing Kit
+ *
+ * gdkvulkancontext-x11.h: X11 specific Vulkan wrappers
+ *
+ * Copyright © 2016  Benjamin Otte
+ *
+ * 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, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __GDK_X11_VULKAN_CONTEXT__
+#define __GDK_X11_VULKAN_CONTEXT__
+
+#ifdef GDK_WINDOWING_VULKAN
+
+#include "gdkvulkancontextprivate.h"
+
+G_BEGIN_DECLS
+
+#define GDK_TYPE_X11_VULKAN_CONTEXT            (gdk_x11_vulkan_context_get_type ())
+#define GDK_X11_VULKAN_CONTEXT(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), 
GDK_TYPE_X11_VULKAN_CONTEXT, GdkX11VulkanContext))
+#define GDK_IS_X11_VULKAN_CONTEXT(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), 
GDK_TYPE_X11_VULKAN_CONTEXT))
+#define GDK_X11_VULKAN_CONTEXT_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), 
GDK_TYPE_X11_VULKAN_CONTEXT, GdkX11VulkanContextClass))
+#define GDK_IS_X11_VULKAN_CONTEXT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), 
GDK_TYPE_X11_VULKAN_CONTEXT))
+#define GDK_X11_VULKAN_CONTEXT_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), 
GDK_TYPE_X11_VULKAN_CONTEXT, GdkX11VulkanContextClass))
+
+struct _GdkX11VulkanContext
+{
+  GdkVulkanContext parent_instance;
+};
+
+struct _GdkX11VulkanContextClass
+{
+  GdkVulkanContextClass parent_class;
+};
+
+G_END_DECLS
+
+#endif /* !GDK_WINDOWING_VULKAN */
+
+#endif /* __GDK_X11_VULKAN_CONTEXT__ */


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]