mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
aux/vk: Make it possible to get a compute only queue
This commit is contained in:
parent
c42d681db0
commit
57d24ecdbb
|
@ -1080,6 +1080,50 @@ err_free:
|
||||||
return VK_ERROR_INITIALIZATION_FAILED;
|
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
|
static bool
|
||||||
vk_check_extension(struct vk_bundle *vk, VkExtensionProperties *props, uint32_t num_props, const char *ext)
|
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
|
VkResult
|
||||||
vk_create_device(struct vk_bundle *vk,
|
vk_create_device(struct vk_bundle *vk,
|
||||||
int forced_index,
|
int forced_index,
|
||||||
|
bool only_compute,
|
||||||
VkQueueGlobalPriorityEXT global_priority,
|
VkQueueGlobalPriorityEXT global_priority,
|
||||||
const char *const *required_device_extensions,
|
const char *const *required_device_extensions,
|
||||||
size_t num_required_device_extensions,
|
size_t num_required_device_extensions,
|
||||||
|
@ -1202,19 +1247,25 @@ vk_create_device(struct vk_bundle *vk,
|
||||||
.globalPriority = global_priority,
|
.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;
|
float queue_priority = 0.0f;
|
||||||
VkDeviceQueueCreateInfo queue_create_info = {
|
VkDeviceQueueCreateInfo queue_create_info = {
|
||||||
.sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO,
|
.sType = VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO,
|
||||||
.pNext = vk->has_EXT_global_priority ? &priority_info : NULL,
|
.pNext = vk->has_EXT_global_priority ? &priority_info : NULL,
|
||||||
.queueCount = 1,
|
.queueCount = 1,
|
||||||
|
.queueFamilyIndex = vk->queue_family_index,
|
||||||
.pQueuePriorities = &queue_priority,
|
.pQueuePriorities = &queue_priority,
|
||||||
};
|
};
|
||||||
|
|
||||||
ret = vk_find_graphics_queue(vk, &queue_create_info.queueFamilyIndex);
|
|
||||||
if (ret != VK_SUCCESS) {
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
VkDeviceCreateInfo device_create_info = {
|
VkDeviceCreateInfo device_create_info = {
|
||||||
.sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO,
|
.sType = VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO,
|
||||||
.queueCreateInfoCount = 1,
|
.queueCreateInfoCount = 1,
|
||||||
|
|
|
@ -371,6 +371,7 @@ vk_init_cmd_pool(struct vk_bundle *vk);
|
||||||
VkResult
|
VkResult
|
||||||
vk_create_device(struct vk_bundle *vk,
|
vk_create_device(struct vk_bundle *vk,
|
||||||
int forced_index,
|
int forced_index,
|
||||||
|
bool only_compute,
|
||||||
VkQueueGlobalPriorityEXT global_priorty,
|
VkQueueGlobalPriorityEXT global_priorty,
|
||||||
const char *const *required_device_extensions,
|
const char *const *required_device_extensions,
|
||||||
size_t num_required_device_extensions,
|
size_t num_required_device_extensions,
|
||||||
|
|
|
@ -898,6 +898,7 @@ compositor_init_vulkan(struct comp_compositor *c)
|
||||||
ret = vk_create_device( //
|
ret = vk_create_device( //
|
||||||
vk, //
|
vk, //
|
||||||
c->settings.selected_gpu_index, //
|
c->settings.selected_gpu_index, //
|
||||||
|
false, // compute_only
|
||||||
prios[i], // global_priority
|
prios[i], // global_priority
|
||||||
required_device_extensions, //
|
required_device_extensions, //
|
||||||
ARRAY_SIZE(required_device_extensions), //
|
ARRAY_SIZE(required_device_extensions), //
|
||||||
|
@ -1113,6 +1114,7 @@ compositor_check_vulkan_caps(struct comp_compositor *c)
|
||||||
ret = vk_create_device( //
|
ret = vk_create_device( //
|
||||||
temp_vk, //
|
temp_vk, //
|
||||||
c->settings.selected_gpu_index, //
|
c->settings.selected_gpu_index, //
|
||||||
|
false, // compute_only
|
||||||
VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT, // global_priority
|
VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT, // global_priority
|
||||||
required_device_extensions, //
|
required_device_extensions, //
|
||||||
ARRAY_SIZE(required_device_extensions), //
|
ARRAY_SIZE(required_device_extensions), //
|
||||||
|
|
Loading…
Reference in a new issue