Mesa (main): radv: do not disable DCC for storage images if atomics aren't enabled
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Thu Sep 2 10:23:32 UTC 2021
Module: Mesa
Branch: main
Commit: e62d3db64b640743d6cb334ae546ac4ca7099c30
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=e62d3db64b640743d6cb334ae546ac4ca7099c30
Author: Samuel Pitoiset <samuel.pitoiset at gmail.com>
Date: Tue Aug 17 12:08:42 2021 +0200
radv: do not disable DCC for storage images if atomics aren't enabled
VK_FORMAT_R32_SFLOAT seems pretty common and it seems we can be a
little smarter when shader image 32-bit float atomics aren't enabled.
Signed-off-by: Samuel Pitoiset <samuel.pitoiset at gmail.com>
Reviewed-by: Bas Nieuwenhuizen <bas at basnieuwenhuizen.nl>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/12406>
---
src/amd/vulkan/radv_image.c | 18 ++++++++++++++----
1 file changed, 14 insertions(+), 4 deletions(-)
diff --git a/src/amd/vulkan/radv_image.c b/src/amd/vulkan/radv_image.c
index dce0458eaff..7a1b9b3f314 100644
--- a/src/amd/vulkan/radv_image.c
+++ b/src/amd/vulkan/radv_image.c
@@ -186,9 +186,19 @@ radv_are_formats_dcc_compatible(const struct radv_physical_device *pdev, const v
}
static bool
-radv_formats_is_atomic_allowed(const void *pNext, VkFormat format, VkImageCreateFlags flags)
+radv_format_is_atomic_allowed(struct radv_device *device, VkFormat format)
{
- if (radv_is_atomic_format_supported(format))
+ if (format == VK_FORMAT_R32_SFLOAT && !device->image_float32_atomics)
+ return false;
+
+ return radv_is_atomic_format_supported(format);
+}
+
+static bool
+radv_formats_is_atomic_allowed(struct radv_device *device, const void *pNext, VkFormat format,
+ VkImageCreateFlags flags)
+{
+ if (radv_format_is_atomic_allowed(device, format))
return true;
if (flags & VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT) {
@@ -199,7 +209,7 @@ radv_formats_is_atomic_allowed(const void *pNext, VkFormat format, VkImageCreate
/* We have to ignore the existence of the list if viewFormatCount = 0 */
if (format_list && format_list->viewFormatCount) {
for (unsigned i = 0; i < format_list->viewFormatCount; ++i) {
- if (radv_is_atomic_format_supported(format_list->pViewFormats[i]))
+ if (radv_format_is_atomic_allowed(device, format_list->pViewFormats[i]))
return true;
}
}
@@ -232,7 +242,7 @@ radv_use_dcc_for_image(struct radv_device *device, struct radv_image *image,
*/
if ((pCreateInfo->usage & VK_IMAGE_USAGE_STORAGE_BIT) &&
(device->physical_device->rad_info.chip_class < GFX10 ||
- radv_formats_is_atomic_allowed(pCreateInfo->pNext, format, pCreateInfo->flags)))
+ radv_formats_is_atomic_allowed(device, pCreateInfo->pNext, format, pCreateInfo->flags)))
return false;
/* Do not enable DCC for fragment shading rate attachments. */
More information about the mesa-commit
mailing list