Mesa (main): radv: Implement VK_EXT_global_priority_query.
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Wed Jun 9 08:53:18 UTC 2021
Module: Mesa
Branch: main
Commit: 3149eccc1c838bb5bc50998721e6a73089bbc729
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=3149eccc1c838bb5bc50998721e6a73089bbc729
Author: Georg Lehmann <dadschoorse at gmail.com>
Date: Mon Jun 7 13:27:52 2021 +0200
radv: Implement VK_EXT_global_priority_query.
Signed-off-by: Georg Lehmann <dadschoorse at gmail.com>
Reviewed-by: Bas Nieuwenhuizen <bas at basnieuwenhuizen.nl>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/11215>
---
docs/relnotes/new_features.txt | 1 +
src/amd/vulkan/radv_device.c | 32 ++++++++++++++++++++++++++++++++
2 files changed, 33 insertions(+)
diff --git a/docs/relnotes/new_features.txt b/docs/relnotes/new_features.txt
index 851cf9a689b..00c0e47cbc6 100644
--- a/docs/relnotes/new_features.txt
+++ b/docs/relnotes/new_features.txt
@@ -1,5 +1,6 @@
zink supports GL_ARB_texture_filter_minmax, GL_ARB_shader_clock
VK_EXT_provoking_vertex on RADV.
VK_EXT_extended_dynamic_state2 on RADV.
+VK_EXT_global_priority_query on RADV.
32-bit x86 builds now default disable x87 math and use sse2.
GL ES 3.1 on GT21x hardware.
diff --git a/src/amd/vulkan/radv_device.c b/src/amd/vulkan/radv_device.c
index 055bbced9a2..5efca6f061c 100644
--- a/src/amd/vulkan/radv_device.c
+++ b/src/amd/vulkan/radv_device.c
@@ -456,6 +456,7 @@ radv_physical_device_get_supported_extensions(const struct radv_physical_device
.EXT_external_memory_dma_buf = true,
.EXT_external_memory_host = device->rad_info.has_userptr,
.EXT_global_priority = true,
+ .EXT_global_priority_query = true,
.EXT_host_query_reset = true,
.EXT_image_drm_format_modifier = device->rad_info.chip_class >= GFX9,
.EXT_image_robustness = true,
@@ -1588,6 +1589,12 @@ radv_GetPhysicalDeviceFeatures2(VkPhysicalDevice physicalDevice,
features->extendedDynamicState2PatchControlPoints = false;
break;
}
+ case VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_GLOBAL_PRIORITY_QUERY_FEATURES_EXT: {
+ VkPhysicalDeviceGlobalPriorityQueryFeaturesEXT *features =
+ (VkPhysicalDeviceGlobalPriorityQueryFeaturesEXT *)ext;
+ features->globalPriorityQuery = true;
+ break;
+ }
default:
break;
}
@@ -2331,6 +2338,13 @@ radv_GetPhysicalDeviceQueueFamilyProperties(VkPhysicalDevice physicalDevice, uin
assert(*pCount <= 3);
}
+static const VkQueueGlobalPriorityEXT radv_global_queue_priorities[] = {
+ VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT,
+ VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT,
+ VK_QUEUE_GLOBAL_PRIORITY_HIGH_EXT,
+ VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT,
+};
+
void
radv_GetPhysicalDeviceQueueFamilyProperties2(VkPhysicalDevice physicalDevice, uint32_t *pCount,
VkQueueFamilyProperties2 *pQueueFamilyProperties)
@@ -2347,6 +2361,24 @@ radv_GetPhysicalDeviceQueueFamilyProperties2(VkPhysicalDevice physicalDevice, ui
};
radv_get_physical_device_queue_family_properties(pdevice, pCount, properties);
assert(*pCount <= 3);
+
+ for (uint32_t i = 0; i < *pCount; i++) {
+ vk_foreach_struct(ext, pQueueFamilyProperties[i].pNext)
+ {
+ switch (ext->sType) {
+ case VK_STRUCTURE_TYPE_QUEUE_FAMILY_GLOBAL_PRIORITY_PROPERTIES_EXT: {
+ VkQueueFamilyGlobalPriorityPropertiesEXT *prop =
+ (VkQueueFamilyGlobalPriorityPropertiesEXT *)ext;
+ STATIC_ASSERT(ARRAY_SIZE(radv_global_queue_priorities) <= VK_MAX_GLOBAL_PRIORITY_SIZE_EXT);
+ prop->priorityCount = ARRAY_SIZE(radv_global_queue_priorities);
+ memcpy(&prop->priorities, radv_global_queue_priorities, sizeof(radv_global_queue_priorities));
+ break;
+ }
+ default:
+ break;
+ }
+ }
+ }
}
void
More information about the mesa-commit
mailing list