Mesa (master): clover: Query device for CL_DEVICE_MAX_MEM_ALLOC_SIZE v2

Tom Stellard tstellar at kemper.freedesktop.org
Tue Sep 25 14:40:53 UTC 2012


Module: Mesa
Branch: master
Commit: 71682cf65bd31aca96f0c84434fc57bcfdec89fc
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=71682cf65bd31aca96f0c84434fc57bcfdec89fc

Author: Tom Stellard <thomas.stellard at amd.com>
Date:   Mon Sep 17 14:29:49 2012 +0000

clover: Query device for CL_DEVICE_MAX_MEM_ALLOC_SIZE v2

v2:
  - Use driver reported values and don't correct them to the OpenCL
    required minimum.

Reviewed-by: Francisco Jerez <currojerez at riseup.net>

---

 src/gallium/state_trackers/clover/api/device.cpp  |    3 ++-
 src/gallium/state_trackers/clover/core/device.cpp |    6 ++++++
 src/gallium/state_trackers/clover/core/device.hpp |    1 +
 3 files changed, 9 insertions(+), 1 deletions(-)

diff --git a/src/gallium/state_trackers/clover/api/device.cpp b/src/gallium/state_trackers/clover/api/device.cpp
index 1a9127b..d99aed8 100644
--- a/src/gallium/state_trackers/clover/api/device.cpp
+++ b/src/gallium/state_trackers/clover/api/device.cpp
@@ -126,7 +126,8 @@ 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,
+                                       dev->max_mem_alloc_size());
 
    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;




More information about the mesa-commit mailing list