[Mesa-dev] [PATCH v2 06/22] clover: Move device extensions definitions to core/device.cpp
Francisco Jerez
currojerez at riseup.net
Tue Jan 23 22:05:10 UTC 2018
Pierre Moreau <pierre.morrow at free.fr> writes:
> Signed-off-by: Pierre Moreau <pierre.morrow at free.fr>
Reviewed-by: Francisco Jerez <currojerez at riseup.net>
> ---
> src/gallium/state_trackers/clover/api/device.cpp | 11 +----------
> src/gallium/state_trackers/clover/core/device.cpp | 14 ++++++++++++++
> src/gallium/state_trackers/clover/core/device.hpp | 1 +
> 3 files changed, 16 insertions(+), 10 deletions(-)
>
> diff --git a/src/gallium/state_trackers/clover/api/device.cpp b/src/gallium/state_trackers/clover/api/device.cpp
> index 576555a9af..4e274c5005 100644
> --- a/src/gallium/state_trackers/clover/api/device.cpp
> +++ b/src/gallium/state_trackers/clover/api/device.cpp
> @@ -330,16 +330,7 @@ clGetDeviceInfo(cl_device_id d_dev, cl_device_info param,
> break;
>
> case CL_DEVICE_EXTENSIONS:
> - buf.as_string() =
> - "cl_khr_byte_addressable_store"
> - " cl_khr_global_int32_base_atomics"
> - " cl_khr_global_int32_extended_atomics"
> - " cl_khr_local_int32_base_atomics"
> - " cl_khr_local_int32_extended_atomics"
> - + std::string(dev.has_int64_atomics() ? " cl_khr_int64_base_atomics" : "")
> - + std::string(dev.has_int64_atomics() ? " cl_khr_int64_extended_atomics" : "")
> - + std::string(dev.has_doubles() ? " cl_khr_fp64" : "")
> - + std::string(dev.has_halves() ? " cl_khr_fp16" : "");
> + buf.as_string() = dev.supported_extensions();
> break;
>
> case CL_DEVICE_PLATFORM:
> diff --git a/src/gallium/state_trackers/clover/core/device.cpp b/src/gallium/state_trackers/clover/core/device.cpp
> index 7eaa0ca2cb..9fb233aa72 100644
> --- a/src/gallium/state_trackers/clover/core/device.cpp
> +++ b/src/gallium/state_trackers/clover/core/device.cpp
> @@ -279,3 +279,17 @@ bool
> device::supports_ir(cl_uint ir) const {
> return supported_irs() & (1 << ir);
> }
> +
> +std::string
> +device::supported_extensions() const {
> + return
> + "cl_khr_byte_addressable_store"
> + " cl_khr_global_int32_base_atomics"
> + " cl_khr_global_int32_extended_atomics"
> + " cl_khr_local_int32_base_atomics"
> + " cl_khr_local_int32_extended_atomics"
> + + std::string(has_int64_atomics() ? " cl_khr_int64_base_atomics" : "")
> + + std::string(has_int64_atomics() ? " cl_khr_int64_extended_atomics" : "")
> + + std::string(has_doubles() ? " cl_khr_fp64" : "")
> + + std::string(has_halves() ? " cl_khr_fp16" : "");
> +}
> diff --git a/src/gallium/state_trackers/clover/core/device.hpp b/src/gallium/state_trackers/clover/core/device.hpp
> index eed644e919..98b9637ace 100644
> --- a/src/gallium/state_trackers/clover/core/device.hpp
> +++ b/src/gallium/state_trackers/clover/core/device.hpp
> @@ -83,6 +83,7 @@ namespace clover {
> cl_uint supported_irs() const;
> std::string ir_target() const;
> enum pipe_endian endianness() const;
> + std::string supported_extensions() const;
>
> bool supports_ir(cl_uint ir) const;
>
> --
> 2.16.0
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 227 bytes
Desc: not available
URL: <https://lists.freedesktop.org/archives/mesa-dev/attachments/20180123/9d0f2964/attachment.sig>
More information about the mesa-dev
mailing list