[Mesa-dev] [PATCH 5/5] clover: Query device for CL_DEVICE_MAX_MEM_ALLOC_SIZE

Francisco Jerez currojerez at riseup.net
Mon Sep 24 09:42:18 PDT 2012


Tom Stellard <tom at stellard.net> writes:

> From: Tom Stellard <thomas.stellard at amd.com>
>
> ---
>  src/gallium/state_trackers/clover/api/device.cpp  | 5 ++++-
>  src/gallium/state_trackers/clover/core/device.cpp | 6 ++++++
>  src/gallium/state_trackers/clover/core/device.hpp | 1 +
>  3 files changed, 11 insertions(+), 1 deletion(-)
>
> diff --git a/src/gallium/state_trackers/clover/api/device.cpp b/src/gallium/state_trackers/clover/api/device.cpp
> index 1a9127b..3093652 100644
> --- a/src/gallium/state_trackers/clover/api/device.cpp
> +++ b/src/gallium/state_trackers/clover/api/device.cpp
> @@ -126,7 +126,10 @@ clGetDeviceInfo(cl_device_id dev, cl_device_info param,
>                                        dev->max_images_write());
>  
>     case CL_DEVICE_MAX_MEM_ALLOC_SIZE:
> -      return scalar_property<cl_ulong>(buf, size, size_ret, 0);
> +      return scalar_property<cl_ulong>(buf, size, size_ret,
> +             std::max(std::max(dev->max_mem_alloc_size(),
> +                               dev->max_mem_global() / 4),
> +                      (cl_ulong)(128 * 1024 * 1024)));
>  
I think this is confusing, just return dev->max_mem_alloc_size() here.
Lying from the state tracker isn't going to fix the driver if it's
advertising less than the minimum allocation size required by the
standard...

Other than that, Reviewed-by: Francisco Jerez <currojerez at riseup.net>

>     case CL_DEVICE_IMAGE2D_MAX_WIDTH:
>     case CL_DEVICE_IMAGE2D_MAX_HEIGHT:
> diff --git a/src/gallium/state_trackers/clover/core/device.cpp b/src/gallium/state_trackers/clover/core/device.cpp
> index 2ab735d..d93a1f6 100644
> --- a/src/gallium/state_trackers/clover/core/device.cpp
> +++ b/src/gallium/state_trackers/clover/core/device.cpp
> @@ -144,6 +144,12 @@ _cl_device_id::max_threads_per_block() const {
>        pipe, PIPE_COMPUTE_CAP_MAX_THREADS_PER_BLOCK)[0];
>  }
>  
> +cl_ulong
> +_cl_device_id::max_mem_alloc_size() const {
> +   return get_compute_param<uint64_t>(pipe,
> +                                      PIPE_COMPUTE_CAP_MAX_MEM_ALLOC_SIZE)[0];
> +}
> +
>  std::vector<size_t>
>  _cl_device_id::max_block_size() const {
>     auto v = get_compute_param<uint64_t>(pipe, PIPE_COMPUTE_CAP_MAX_BLOCK_SIZE);
> diff --git a/src/gallium/state_trackers/clover/core/device.hpp b/src/gallium/state_trackers/clover/core/device.hpp
> index 9408083..5b92751 100644
> --- a/src/gallium/state_trackers/clover/core/device.hpp
> +++ b/src/gallium/state_trackers/clover/core/device.hpp
> @@ -56,6 +56,7 @@ public:
>     cl_ulong max_const_buffer_size() const;
>     cl_uint max_const_buffers() const;
>     size_t max_threads_per_block() const;
> +   cl_ulong max_mem_alloc_size() const;
>  
>     std::vector<size_t> max_block_size() const;
>     std::string device_name() const;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 229 bytes
Desc: not available
URL: <http://lists.freedesktop.org/archives/mesa-dev/attachments/20120924/298be6a3/attachment.pgp>


More information about the mesa-dev mailing list