=?UTF-8?Q?J=C3=B3zef=20Kucia=20?=: winex11: Return Wine Vulkan driver functions from vkGetInstanceProcAddr().

Alexandre Julliard julliard at winehq.org
Mon Mar 26 16:01:20 CDT 2018


Module: wine
Branch: master
Commit: e952a1879f3927b5b40c9d8b8f3934f0dd177a48
URL:    https://source.winehq.org/git/wine.git/?a=commit;h=e952a1879f3927b5b40c9d8b8f3934f0dd177a48

Author: Józef Kucia <jkucia at codeweavers.com>
Date:   Sat Mar 24 14:28:03 2018 +0100

winex11: Return Wine Vulkan driver functions from vkGetInstanceProcAddr().

Signed-off-by: Józef Kucia <jkucia at codeweavers.com>
Signed-off-by: Roderick Colenbrander <thunderbird2k at gmail.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/winex11.drv/vulkan.c | 56 ++++++++++++++++++++++++++++++++++++++++++++---
 1 file changed, 53 insertions(+), 3 deletions(-)

diff --git a/dlls/winex11.drv/vulkan.c b/dlls/winex11.drv/vulkan.c
index 8db61f1..d40afb3 100644
--- a/dlls/winex11.drv/vulkan.c
+++ b/dlls/winex11.drv/vulkan.c
@@ -77,6 +77,8 @@ static VkBool32 (*pvkGetPhysicalDeviceXlibPresentationSupportKHR)(VkPhysicalDevi
 static VkResult (*pvkGetSwapchainImagesKHR)(VkDevice, VkSwapchainKHR, uint32_t *, VkImage *);
 static VkResult (*pvkQueuePresentKHR)(VkQueue, const VkPresentInfoKHR *);
 
+static void *X11DRV_get_vk_instance_proc_addr(VkInstance instance, const char *name);
+
 static struct VkExtensionProperties *winex11_vk_instance_extensions = NULL;
 static unsigned int winex11_vk_instance_extensions_count = 0;
 
@@ -401,9 +403,15 @@ static void * X11DRV_vkGetDeviceProcAddr(VkDevice device, const char *name)
     return pvkGetDeviceProcAddr(device, name);
 }
 
-static void * X11DRV_vkGetInstanceProcAddr(VkInstance instance, const char *name)
+static void *X11DRV_vkGetInstanceProcAddr(VkInstance instance, const char *name)
 {
+    void *proc_addr;
+
     TRACE("%p, %s\n", instance, debugstr_a(name));
+
+    if ((proc_addr = X11DRV_get_vk_instance_proc_addr(instance, name)))
+        return proc_addr;
+
     return pvkGetInstanceProcAddr(instance, name);
 }
 
@@ -473,7 +481,6 @@ static VkResult X11DRV_vkQueuePresentKHR(VkQueue queue, const VkPresentInfoKHR *
     return pvkQueuePresentKHR(queue, present_info);
 }
 
-
 static const struct vulkan_funcs vulkan_funcs =
 {
     X11DRV_vkAcquireNextImageKHR,
@@ -492,9 +499,52 @@ static const struct vulkan_funcs vulkan_funcs =
     X11DRV_vkGetPhysicalDeviceSurfaceSupportKHR,
     X11DRV_vkGetPhysicalDeviceWin32PresentationSupportKHR,
     X11DRV_vkGetSwapchainImagesKHR,
-    X11DRV_vkQueuePresentKHR
+    X11DRV_vkQueuePresentKHR,
 };
 
+static void *get_vulkan_driver_instance_proc_addr(const struct vulkan_funcs *vulkan_funcs,
+        VkInstance instance, const char *name)
+{
+    if (!name || name[0] != 'v' || name[1] != 'k')
+        return NULL;
+
+    name += 2;
+
+    if (!strcmp(name, "CreateInstance"))
+        return vulkan_funcs->p_vkCreateInstance;
+    if (!strcmp(name, "EnumerateInstanceExtensionProperties"))
+        return vulkan_funcs->p_vkEnumerateInstanceExtensionProperties;
+
+    if (!instance)
+        return NULL;
+
+    if (!strcmp(name, "CreateWin32SurfaceKHR"))
+        return vulkan_funcs->p_vkCreateWin32SurfaceKHR;
+    if (!strcmp(name, "DestroyInstance"))
+        return vulkan_funcs->p_vkDestroyInstance;
+    if (!strcmp(name, "DestroySurfaceKHR"))
+        return vulkan_funcs->p_vkDestroySurfaceKHR;
+    if (!strcmp(name, "GetInstanceProcAddr"))
+        return vulkan_funcs->p_vkGetInstanceProcAddr;
+    if (!strcmp(name, "GetPhysicalDeviceSurfaceCapabilitiesKHR"))
+        return vulkan_funcs->p_vkGetPhysicalDeviceSurfaceCapabilitiesKHR;
+    if (!strcmp(name, "GetPhysicalDeviceSurfaceFormatsKHR"))
+        return vulkan_funcs->p_vkGetPhysicalDeviceSurfaceFormatsKHR;
+    if (!strcmp(name, "GetPhysicalDeviceSurfacePresentModesKHR"))
+        return vulkan_funcs->p_vkGetPhysicalDeviceSurfacePresentModesKHR;
+    if (!strcmp(name, "GetPhysicalDeviceSurfaceSupportKHR"))
+        return vulkan_funcs->p_vkGetPhysicalDeviceSurfaceSupportKHR;
+    if (!strcmp(name, "GetPhysicalDeviceWin32PresentationSupportKHR"))
+        return vulkan_funcs->p_vkGetPhysicalDeviceWin32PresentationSupportKHR;
+
+    return NULL;
+}
+
+static void *X11DRV_get_vk_instance_proc_addr(VkInstance instance, const char *name)
+{
+    return get_vulkan_driver_instance_proc_addr(&vulkan_funcs, instance, name);
+}
+
 const struct vulkan_funcs *get_vulkan_driver(UINT version)
 {
     if (version != WINE_VULKAN_DRIVER_VERSION)




More information about the wine-cvs mailing list