diff options
author | Chad Versace <[email protected]> | 2017-03-05 13:15:06 -0800 |
---|---|---|
committer | Chad Versace <[email protected]> | 2017-03-13 15:08:15 -0700 |
commit | c5a0829e1f56f6bb728ee2d200918ffa0f8842a6 (patch) | |
tree | 50547a6453957923301678c796ac36893ea9a0fb | |
parent | 876f0ecd2f6c49c62d9b346f6c16ec115ae472c9 (diff) |
anv: Use vk_outarray in vkGetPhysicalDeviceQueueFamilyProperties
No intended change in behavior. Just a refactor.
Reviewed-by: Jason Ekstrand <[email protected]>
-rw-r--r-- | src/intel/vulkan/anv_device.c | 73 |
1 files changed, 18 insertions, 55 deletions
diff --git a/src/intel/vulkan/anv_device.c b/src/intel/vulkan/anv_device.c index 1bb835009cc..7761be114e3 100644 --- a/src/intel/vulkan/anv_device.c +++ b/src/intel/vulkan/anv_device.c @@ -660,43 +660,27 @@ void anv_GetPhysicalDeviceProperties2KHR( } } -static void -anv_get_queue_family_properties(struct anv_physical_device *phys_dev, - VkQueueFamilyProperties *props) -{ - *props = (VkQueueFamilyProperties) { - .queueFlags = VK_QUEUE_GRAPHICS_BIT | - VK_QUEUE_COMPUTE_BIT | - VK_QUEUE_TRANSFER_BIT, - .queueCount = 1, - .timestampValidBits = 36, /* XXX: Real value here */ - .minImageTransferGranularity = (VkExtent3D) { 1, 1, 1 }, - }; -} +/* We support exactly one queue family. */ +static const VkQueueFamilyProperties +anv_queue_family_properties = { + .queueFlags = VK_QUEUE_GRAPHICS_BIT | + VK_QUEUE_COMPUTE_BIT | + VK_QUEUE_TRANSFER_BIT, + .queueCount = 1, + .timestampValidBits = 36, /* XXX: Real value here */ + .minImageTransferGranularity = (VkExtent3D) { 1, 1, 1 }, +}; void anv_GetPhysicalDeviceQueueFamilyProperties( VkPhysicalDevice physicalDevice, uint32_t* pCount, VkQueueFamilyProperties* pQueueFamilyProperties) { - ANV_FROM_HANDLE(anv_physical_device, phys_dev, physicalDevice); + VK_OUTARRAY_MAKE(out, pQueueFamilyProperties, pCount); - if (pQueueFamilyProperties == NULL) { - *pCount = 1; - return; + vk_outarray_append(&out, p) { + *p = anv_queue_family_properties; } - - /* The spec implicitly allows the incoming count to be 0. From the Vulkan - * 1.0.38 spec, Section 4.1 Physical Devices: - * - * If the value referenced by pQueueFamilyPropertyCount is not 0 [then - * do stuff]. - */ - if (*pCount == 0) - return; - - *pCount = 1; - anv_get_queue_family_properties(phys_dev, pQueueFamilyProperties); } void anv_GetPhysicalDeviceQueueFamilyProperties2KHR( @@ -705,34 +689,13 @@ void anv_GetPhysicalDeviceQueueFamilyProperties2KHR( VkQueueFamilyProperties2KHR* pQueueFamilyProperties) { - ANV_FROM_HANDLE(anv_physical_device, phys_dev, physicalDevice); - - if (pQueueFamilyProperties == NULL) { - *pQueueFamilyPropertyCount = 1; - return; - } + VK_OUTARRAY_MAKE(out, pQueueFamilyProperties, pQueueFamilyPropertyCount); - /* The spec implicitly allows the incoming count to be 0. From the Vulkan - * 1.0.38 spec, Section 4.1 Physical Devices: - * - * If the value referenced by pQueueFamilyPropertyCount is not 0 [then - * do stuff]. - */ - if (*pQueueFamilyPropertyCount == 0) - return; + vk_outarray_append(&out, p) { + p->queueFamilyProperties = anv_queue_family_properties; - /* We support exactly one queue family. So need to traverse only the first - * array element's pNext chain. - */ - *pQueueFamilyPropertyCount = 1; - anv_get_queue_family_properties(phys_dev, - &pQueueFamilyProperties->queueFamilyProperties); - - vk_foreach_struct(ext, pQueueFamilyProperties->pNext) { - switch (ext->sType) { - default: - anv_debug_ignored_stype(ext->sType); - break; + vk_foreach_struct(s, p->pNext) { + anv_debug_ignored_stype(s->sType); } } } |