diff options
author | Tom Stellard <[email protected]> | 2012-09-17 14:29:49 +0000 |
---|---|---|
committer | Tom Stellard <[email protected]> | 2012-09-25 14:36:50 +0000 |
commit | 71682cf65bd31aca96f0c84434fc57bcfdec89fc (patch) | |
tree | 7e31a7c6a02d52a7cd47202da1e79df17334ed7e /src/gallium | |
parent | 0e3c30cd6f90db72044bb2d3311aa13a245cbcaf (diff) |
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 <[email protected]>
Diffstat (limited to 'src/gallium')
-rw-r--r-- | src/gallium/state_trackers/clover/api/device.cpp | 3 | ||||
-rw-r--r-- | src/gallium/state_trackers/clover/core/device.cpp | 6 | ||||
-rw-r--r-- | 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 1a9127bb3d5..d99aed8f564 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 2ab735d9a2a..d93a1f6ac6c 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 9408083e479..5b92751cbcd 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; |