[PATCH 7/7] winex11: Implement vkEnumerateInstanceExtensionProperties.

Józef Kucia joseph.kucia at gmail.com
Mon Feb 26 12:42:17 CST 2018


From: Roderick Colenbrander <thunderbird2k at gmail.com>

Signed-off-by: Roderick Colenbrander <thunderbird2k at gmail.com>
Signed-off-by: Józef Kucia <jkucia at codeweavers.com>
---
 dlls/winex11.drv/vulkan.c | 28 ++++++++++++++++++++++++++--
 1 file changed, 26 insertions(+), 2 deletions(-)

diff --git a/dlls/winex11.drv/vulkan.c b/dlls/winex11.drv/vulkan.c
index b73f37984621..92f8a0e4526b 100644
--- a/dlls/winex11.drv/vulkan.c
+++ b/dlls/winex11.drv/vulkan.c
@@ -41,8 +41,32 @@ static void X11DRV_vkDestroyInstance(VkInstance instance, const VkAllocationCall
 static VkResult X11DRV_vkEnumerateInstanceExtensionProperties(const char *layer_name,
         uint32_t *count, VkExtensionProperties* properties)
 {
-    FIXME("stub: %s %p %p\n", debugstr_a(layer_name), count, properties);
-    return VK_ERROR_OUT_OF_HOST_MEMORY;
+    TRACE("layer_name %s, count %p, properties %p\n", debugstr_a(layer_name), count, properties);
+
+    /* This shouldn't get called with layer_name set, the ICD loader prevents it. */
+    if (layer_name)
+    {
+        ERR("Layer enumeration not supported from ICD.\n");
+        return VK_ERROR_LAYER_NOT_PRESENT;
+    }
+
+    if (!properties)
+    {
+        /* When properties is NULL, we need to return the number of extensions
+         * supported. For now report 0 until we add some e.g.
+         * VK_KHR_win32_surface. Long-term this needs to be an intersection
+         * between what the native library supports and what thunks we have.
+         */
+        *count = 0;
+        return VK_SUCCESS;
+    }
+
+    /* When properties is not NULL, we copy the extensions over and set count
+     * to the number of copied extensions. For now we don't have much to do as
+     * we don't support any extensions yet.
+     */
+    *count = 0;
+    return VK_SUCCESS;
 }
 
 static void * X11DRV_vkGetInstanceProcAddr(VkInstance instance, const char *name)
-- 
2.16.1




More information about the wine-devel mailing list