From 57d24ecdbbaf30026701d222f37c2516215a3e28 Mon Sep 17 00:00:00 2001 From: Jakob Bornecrantz Date: Sun, 6 Jun 2021 01:25:00 +0100 Subject: [PATCH] aux/vk: Make it possible to get a compute only queue --- src/xrt/auxiliary/vk/vk_helpers.c | 61 +++++++++++++++++++++-- src/xrt/auxiliary/vk/vk_helpers.h | 1 + src/xrt/compositor/main/comp_compositor.c | 2 + 3 files changed, 59 insertions(+), 5 deletions(-) diff --git a/src/xrt/auxiliary/vk/vk_helpers.c b/src/xrt/auxiliary/vk/vk_helpers.c index 76c2df86f..3434a048f 100644 --- a/src/xrt/auxiliary/vk/vk_helpers.c +++ b/src/xrt/auxiliary/vk/vk_helpers.c @@ -1080,6 +1080,50 @@ err_free: return VK_ERROR_INITIALIZATION_FAILED; } +static VkResult +vk_find_compute_only_queue(struct vk_bundle *vk, uint32_t *out_compute_queue) +{ + /* Find the first graphics queue */ + uint32_t num_queues = 0; + uint32_t i = 0; + vk->vkGetPhysicalDeviceQueueFamilyProperties(vk->physical_device, &num_queues, NULL); + + VkQueueFamilyProperties *queue_family_props = U_TYPED_ARRAY_CALLOC(VkQueueFamilyProperties, num_queues); + + vk->vkGetPhysicalDeviceQueueFamilyProperties(vk->physical_device, &num_queues, queue_family_props); + + if (num_queues == 0) { + VK_DEBUG(vk, "Failed to get queue properties"); + goto err_free; + } + + for (i = 0; i < num_queues; i++) { + if (queue_family_props[i].queueFlags & VK_QUEUE_GRAPHICS_BIT) { + continue; + } + + if (queue_family_props[i].queueFlags & VK_QUEUE_COMPUTE_BIT) { + break; + } + } + + if (i >= num_queues) { + VK_DEBUG(vk, "No compute only queue found"); + goto err_free; + } + + *out_compute_queue = i; + + free(queue_family_props); + + return VK_SUCCESS; + +err_free: + free(queue_family_props); + + return VK_ERROR_INITIALIZATION_FAILED; +} + static bool vk_check_extension(struct vk_bundle *vk, VkExtensionProperties *props, uint32_t num_props, const char *ext) { @@ -1174,6 +1218,7 @@ vk_build_device_extensions(struct vk_bundle *vk, VkResult vk_create_device(struct vk_bundle *vk, int forced_index, + bool only_compute, VkQueueGlobalPriorityEXT global_priority, const char *const *required_device_extensions, size_t num_required_device_extensions, @@ -1202,19 +1247,25 @@ vk_create_device(struct vk_bundle *vk, .globalPriority = global_priority, }; + if (only_compute) { + ret = vk_find_compute_only_queue(vk, &vk->queue_family_index); + } else { + ret = vk_find_graphics_queue(vk, &vk->queue_family_index); + } + + if (ret != VK_SUCCESS) { + return ret; + } + float queue_priority = 0.0f; VkDeviceQueueCreateInfo queue_create_info = { .sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO, .pNext = vk->has_EXT_global_priority ? &priority_info : NULL, .queueCount = 1, + .queueFamilyIndex = vk->queue_family_index, .pQueuePriorities = &queue_priority, }; - ret = vk_find_graphics_queue(vk, &queue_create_info.queueFamilyIndex); - if (ret != VK_SUCCESS) { - return ret; - } - VkDeviceCreateInfo device_create_info = { .sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO, .queueCreateInfoCount = 1, diff --git a/src/xrt/auxiliary/vk/vk_helpers.h b/src/xrt/auxiliary/vk/vk_helpers.h index 935bcab6c..d8616b690 100644 --- a/src/xrt/auxiliary/vk/vk_helpers.h +++ b/src/xrt/auxiliary/vk/vk_helpers.h @@ -371,6 +371,7 @@ vk_init_cmd_pool(struct vk_bundle *vk); VkResult vk_create_device(struct vk_bundle *vk, int forced_index, + bool only_compute, VkQueueGlobalPriorityEXT global_priorty, const char *const *required_device_extensions, size_t num_required_device_extensions, diff --git a/src/xrt/compositor/main/comp_compositor.c b/src/xrt/compositor/main/comp_compositor.c index 82fa27129..6347f36ac 100644 --- a/src/xrt/compositor/main/comp_compositor.c +++ b/src/xrt/compositor/main/comp_compositor.c @@ -898,6 +898,7 @@ compositor_init_vulkan(struct comp_compositor *c) ret = vk_create_device( // vk, // c->settings.selected_gpu_index, // + false, // compute_only prios[i], // global_priority required_device_extensions, // ARRAY_SIZE(required_device_extensions), // @@ -1113,6 +1114,7 @@ compositor_check_vulkan_caps(struct comp_compositor *c) ret = vk_create_device( // temp_vk, // c->settings.selected_gpu_index, // + false, // compute_only VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT, // global_priority required_device_extensions, // ARRAY_SIZE(required_device_extensions), //