[Mesa-dev] [PATCH 3/3] radv: add VK_KHR_shader_atomic_int64 but disable it for now

Bas Nieuwenhuizen bas at basnieuwenhuizen.nl
Wed Apr 17 18:52:23 UTC 2019


On Tue, Apr 16, 2019 at 10:35 AM Samuel Pitoiset
<samuel.pitoiset at gmail.com> wrote:
>
> No support for 64-bit compare&swap atomic operations.
>
> Signed-off-by: Samuel Pitoiset <samuel.pitoiset at gmail.com>
> ---
>  src/amd/vulkan/radv_device.c      | 10 ++++++++++
>  src/amd/vulkan/radv_extensions.py |  1 +
>  src/amd/vulkan/radv_shader.c      |  1 +
>  3 files changed, 12 insertions(+)
>
> diff --git a/src/amd/vulkan/radv_device.c b/src/amd/vulkan/radv_device.c
> index 1f77dcadb17..13021a9f2da 100644
> --- a/src/amd/vulkan/radv_device.c
> +++ b/src/amd/vulkan/radv_device.c
> @@ -906,6 +906,16 @@ void radv_GetPhysicalDeviceFeatures2(
>                         features->shaderInt8 = true;
>                         break;
>                 }
> +               case VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_ATOMIC_INT64_FEATURES_KHR: {
> +                       VkPhysicalDeviceShaderAtomicInt64FeaturesKHR *features =
> +                               (VkPhysicalDeviceShaderAtomicInt64FeaturesKHR *)ext;
> +                       /* TODO: Enable this once the driver supports 64-bit
> +                        * compare&swap atomic operations.
> +                        */
> +                       features->shaderBufferInt64Atomics = false;
> +                       features->shaderSharedInt64Atomics = false;
> +                       break;
> +               }
>                 default:
>                         break;
>                 }
> diff --git a/src/amd/vulkan/radv_extensions.py b/src/amd/vulkan/radv_extensions.py
> index 13fe391e623..2d2d3f0c447 100644
> --- a/src/amd/vulkan/radv_extensions.py
> +++ b/src/amd/vulkan/radv_extensions.py
> @@ -81,6 +81,7 @@ EXTENSIONS = [
>      Extension('VK_KHR_push_descriptor',                   1, True),
>      Extension('VK_KHR_relaxed_block_layout',              1, True),
>      Extension('VK_KHR_sampler_mirror_clamp_to_edge',      1, True),
> +    Extension('VK_KHR_shader_atomic_int64',               1, 'HAVE_LLVM >= 0x900'),

I'd prefer we make this constant False as long we never enable any of
the features.

Otherwise r-b for the series.

>      Extension('VK_KHR_shader_draw_parameters',            1, True),
>      Extension('VK_KHR_shader_float16_int8',               1, True),
>      Extension('VK_KHR_storage_buffer_storage_class',      1, True),
> diff --git a/src/amd/vulkan/radv_shader.c b/src/amd/vulkan/radv_shader.c
> index a9677094772..c802abb0e08 100644
> --- a/src/amd/vulkan/radv_shader.c
> +++ b/src/amd/vulkan/radv_shader.c
> @@ -235,6 +235,7 @@ radv_shader_compile_to_nir(struct radv_device *device,
>                                 .int8 = true,
>                                 .int16 = true,
>                                 .int64 = true,
> +                               .int64_atomics = true,
>                                 .multiview = true,
>                                 .physical_storage_buffer_address = true,
>                                 .runtime_descriptor_array = true,
> --
> 2.21.0
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev


More information about the mesa-dev mailing list