[gtk+/wip/otte/vulkan: 51/59] vulkan: Register debug handler
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/otte/vulkan: 51/59] vulkan: Register debug handler
- Date: Mon, 5 Dec 2016 12:31:46 +0000 (UTC)
commit ec22551278e350288cb2449d1ff7311b8c2db18d
Author: Benjamin Otte <otte redhat com>
Date: Tue Nov 29 16:29:19 2016 +0100
vulkan: Register debug handler
We now hook Vulkan error reporting into glib's error reporting.
I'm not sure on the severity handling yet, but we can fix that as we go
along.
gdk/gdkdisplayprivate.h | 1 +
gdk/gdkvulkancontext.c | 123 ++++++++++++++++++++++++++++++++++++++++-------
2 files changed, 106 insertions(+), 18 deletions(-)
---
diff --git a/gdk/gdkdisplayprivate.h b/gdk/gdkdisplayprivate.h
index 9f28db7..8aba6d1 100644
--- a/gdk/gdkdisplayprivate.h
+++ b/gdk/gdkdisplayprivate.h
@@ -126,6 +126,7 @@ struct _GdkDisplay
#ifdef GDK_WINDOWING_VULKAN
VkInstance vk_instance;
+ VkDebugReportCallbackEXT vk_debug_callback;
VkPhysicalDevice vk_physical_device;
VkDevice vk_device;
VkQueue vk_queue;
diff --git a/gdk/gdkvulkancontext.c b/gdk/gdkvulkancontext.c
index f9405c0..af485b4 100644
--- a/gdk/gdkvulkancontext.c
+++ b/gdk/gdkvulkancontext.c
@@ -452,13 +452,48 @@ gdk_display_create_vulkan_device (GdkDisplay *display,
return FALSE;
}
+static VkBool32
+gdk_vulkan_debug_report (VkDebugReportFlagsEXT flags,
+ VkDebugReportObjectTypeEXT objectType,
+ uint64_t object,
+ size_t location,
+ int32_t messageCode,
+ const char* pLayerPrefix,
+ const char* pMessage,
+ void* pUserData)
+{
+ if (flags & VK_DEBUG_REPORT_ERROR_BIT_EXT)
+ {
+ g_critical ("Vulkan: %s: %s\n", pLayerPrefix, pMessage);
+ }
+ else if (flags & VK_DEBUG_REPORT_WARNING_BIT_EXT)
+ {
+ g_critical ("Vulkan: %s: %s\n", pLayerPrefix, pMessage);
+ }
+ else if (flags & VK_DEBUG_REPORT_PERFORMANCE_WARNING_BIT_EXT)
+ {
+ g_warning ("Vulkan: %s: %s\n", pLayerPrefix, pMessage);
+ }
+ else if (flags & VK_DEBUG_REPORT_DEBUG_BIT_EXT)
+ {
+ g_debug ("Vulkan: %s: %s\n", pLayerPrefix, pMessage);
+ }
+ else
+ {
+ g_message ("Vulkan: %s: %s\n", pLayerPrefix, pMessage);
+ }
+
+ return VK_TRUE;
+}
+
static gboolean
gdk_display_create_vulkan_instance (GdkDisplay *display,
GError **error)
{
uint32_t i;
+ GPtrArray *used_extensions;
GPtrArray *used_layers;
- gboolean validate = FALSE;
+ gboolean validate = FALSE, have_debug_report = FALSE;
VkResult res;
if (GDK_DISPLAY_GET_CLASS (display)->vk_extension_name == NULL)
@@ -473,6 +508,10 @@ gdk_display_create_vulkan_instance (GdkDisplay *display,
VkExtensionProperties extensions[n_extensions];
GDK_VK_CHECK (vkEnumerateInstanceExtensionProperties, NULL, &n_extensions, extensions);
+ used_extensions = g_ptr_array_new ();
+ g_ptr_array_add (used_extensions, (gpointer) VK_KHR_SURFACE_EXTENSION_NAME);
+ g_ptr_array_add (used_extensions, (gpointer) GDK_DISPLAY_GET_CLASS (display)->vk_extension_name);
+
for (i = 0; i < n_extensions; i++)
{
GDK_NOTE (VULKAN, g_print ("Extension available: %s v%u.%u.%u\n",
@@ -480,6 +519,12 @@ gdk_display_create_vulkan_instance (GdkDisplay *display,
VK_VERSION_MAJOR (extensions[i].specVersion),
VK_VERSION_MINOR (extensions[i].specVersion),
VK_VERSION_PATCH (extensions[i].specVersion)));
+
+ if (g_str_equal (extensions[i].extensionName, VK_EXT_DEBUG_REPORT_EXTENSION_NAME))
+ {
+ g_ptr_array_add (used_extensions, (gpointer) VK_EXT_DEBUG_REPORT_EXTENSION_NAME);
+ have_debug_report = TRUE;
+ }
}
uint32_t n_layers;
@@ -511,28 +556,27 @@ gdk_display_create_vulkan_instance (GdkDisplay *display,
}
res = 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 },
- used_layers->len,
- (const char * const *) used_layers->pdata,
- 2,
- (const char *const *) &(const char *[2]) {
- VK_KHR_SURFACE_EXTENSION_NAME,
- GDK_DISPLAY_GET_CLASS (display)->vk_extension_name
+ .sType = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO,
+ .pNext = NULL,
+ .flags = 0,
+ .pApplicationInfo = &(VkApplicationInfo) {
+ .sType = VK_STRUCTURE_TYPE_APPLICATION_INFO,
+ .pNext = NULL,
+ .pApplicationName = g_get_application_name (),
+ .applicationVersion = 0,
+ .pEngineName = "GTK+",
+ .engineVersion = VK_MAKE_VERSION (GDK_MAJOR_VERSION,
GDK_MINOR_VERSION, GDK_MICRO_VERSION),
+ .apiVersion = VK_API_VERSION_1_0
},
+ .enabledLayerCount = used_layers->len,
+ .ppEnabledLayerNames = (const char * const *)
used_layers->pdata,
+ .enabledExtensionCount = used_extensions->len,
+ .ppEnabledExtensionNames = (const char * const *)
used_extensions->pdata
},
NULL,
&display->vk_instance);
g_ptr_array_free (used_layers, TRUE);
+ g_ptr_array_free (used_extensions, TRUE);
if (res != VK_SUCCESS)
{
@@ -541,8 +585,39 @@ gdk_display_create_vulkan_instance (GdkDisplay *display,
return FALSE;
}
+ if (have_debug_report)
+ {
+ PFN_vkCreateDebugReportCallbackEXT vkCreateDebugReportCallbackEXT;
+
+ vkCreateDebugReportCallbackEXT = (PFN_vkCreateDebugReportCallbackEXT) vkGetInstanceProcAddr
(display->vk_instance, "vkCreateDebugReportCallbackEXT" );
+ GDK_VK_CHECK (vkCreateDebugReportCallbackEXT, display->vk_instance,
+ &(VkDebugReportCallbackCreateInfoEXT) {
+ .sType =
VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT,
+ .pNext = NULL,
+ .flags = VK_DEBUG_REPORT_INFORMATION_BIT_EXT
+ | VK_DEBUG_REPORT_WARNING_BIT_EXT
+ | VK_DEBUG_REPORT_PERFORMANCE_WARNING_BIT_EXT
+ | VK_DEBUG_REPORT_ERROR_BIT_EXT
+ | VK_DEBUG_REPORT_DEBUG_BIT_EXT,
+ .pfnCallback = gdk_vulkan_debug_report,
+ .pUserData = NULL
+ },
+ NULL,
+ &display->vk_debug_callback);
+ }
+
if (!gdk_display_create_vulkan_device (display, error))
{
+ if (display->vk_debug_callback != VK_NULL_HANDLE)
+ {
+ PFN_vkDestroyDebugReportCallbackEXT vkDestroyDebugReportCallbackEXT;
+
+ vkDestroyDebugReportCallbackEXT = (PFN_vkDestroyDebugReportCallbackEXT) vkGetInstanceProcAddr
(display->vk_instance, "vkDestroyDebugReportCallbackEXT");
+ vkDestroyDebugReportCallbackEXT (display->vk_instance,
+ display->vk_debug_callback,
+ NULL);
+ display->vk_debug_callback = VK_NULL_HANDLE;
+ }
vkDestroyInstance (display->vk_instance, NULL);
display->vk_instance = VK_NULL_HANDLE;
return FALSE;
@@ -577,7 +652,19 @@ gdk_display_unref_vulkan (GdkDisplay *display)
return;
vkDestroyDevice (display->vk_device, NULL);
+ display->vk_device = VK_NULL_HANDLE;
+ if (display->vk_debug_callback != VK_NULL_HANDLE)
+ {
+ PFN_vkDestroyDebugReportCallbackEXT vkDestroyDebugReportCallbackEXT;
+
+ vkDestroyDebugReportCallbackEXT = (PFN_vkDestroyDebugReportCallbackEXT) vkGetInstanceProcAddr
(display->vk_instance, "vkDestroyDebugReportCallbackEXT");
+ vkDestroyDebugReportCallbackEXT (display->vk_instance,
+ display->vk_debug_callback,
+ NULL);
+ display->vk_debug_callback = VK_NULL_HANDLE;
+ }
vkDestroyInstance (display->vk_instance, NULL);
+ display->vk_instance = VK_NULL_HANDLE;
}
#else /* GDK_WINDOWING_VULKAN */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]