clover: add missing clGetDeviceInfo CL1.2 queries
authorSerge Martin <edb+mesa@sigluy.net>
Sat, 1 Oct 2016 16:51:11 +0000 (18:51 +0200)
committerSerge Martin <edb@sigluy.net>
Sun, 6 Nov 2016 14:56:49 +0000 (15:56 +0100)
Reviewed-by: Francisco Jerez <currojerez@riseup.net>
Reviewed-by: Edward O'Callaghan <funfunctor@folklore1984.net>
Reviewed-by: Vedran Miletić <vedran@miletic.net>
src/gallium/state_trackers/clover/api/device.cpp
src/gallium/state_trackers/clover/core/device.cpp
src/gallium/state_trackers/clover/core/device.hpp

index f7bd61b929b2dd02273bc642648c4c861502dfc3..a80ca46654fe93042823fd4e22624fb5c24f66d6 100644 (file)
@@ -184,6 +184,14 @@ clGetDeviceInfo(cl_device_id d_dev, cl_device_info param,
       buf.as_scalar<size_t>() = 1 << dev.max_image_levels_3d();
       break;
 
+   case CL_DEVICE_IMAGE_MAX_BUFFER_SIZE:
+      buf.as_scalar<size_t>() = dev.max_image_buffer_size();
+      break;
+
+   case CL_DEVICE_IMAGE_MAX_ARRAY_SIZE:
+      buf.as_scalar<size_t>() = dev.max_image_array_number();
+      break;
+
    case CL_DEVICE_IMAGE_SUPPORT:
       buf.as_scalar<cl_bool>() = dev.image_support();
       break;
@@ -273,6 +281,7 @@ clGetDeviceInfo(cl_device_id d_dev, cl_device_info param,
 
    case CL_DEVICE_AVAILABLE:
    case CL_DEVICE_COMPILER_AVAILABLE:
+   case CL_DEVICE_LINKER_AVAILABLE:
       buf.as_scalar<cl_bool>() = CL_TRUE;
       break;
 
@@ -284,6 +293,10 @@ clGetDeviceInfo(cl_device_id d_dev, cl_device_info param,
       buf.as_scalar<cl_command_queue_properties>() = CL_QUEUE_PROFILING_ENABLE;
       break;
 
+   case CL_DEVICE_BUILT_IN_KERNELS:
+      buf.as_string() = "";
+      break;
+
    case CL_DEVICE_NAME:
       buf.as_string() = dev.device_name();
       break;
@@ -358,6 +371,16 @@ clGetDeviceInfo(cl_device_id d_dev, cl_device_info param,
       buf.as_string() = "OpenCL C 1.1 ";
       break;
 
+   case CL_DEVICE_PRINTF_BUFFER_SIZE:
+      // Per the spec, the minimum value for the FULL profile is 1 MB.
+      // However, clover is not ready yet to support it
+      buf.as_scalar<size_t>() = 0 /* 1024 */;
+      break;
+
+   case CL_DEVICE_PREFERRED_INTEROP_USER_SYNC:
+      buf.as_scalar<cl_bool>() = CL_TRUE;
+      break;
+
    case CL_DEVICE_PARENT_DEVICE:
       buf.as_scalar<cl_device_id>() = NULL;
       break;
index 8825f993a75e1d1b6269c4343307bcec13162fb0..8f1c1da51362b468f487659e0f865971ad3592e3 100644 (file)
@@ -98,6 +98,11 @@ device::max_images_write() const {
    return PIPE_MAX_SHADER_IMAGES;
 }
 
+size_t
+device::max_image_buffer_size() const {
+   return pipe->get_param(pipe, PIPE_CAP_MAX_TEXTURE_BUFFER_SIZE);
+}
+
 cl_uint
 device::max_image_levels_2d() const {
    return pipe->get_param(pipe, PIPE_CAP_MAX_TEXTURE_2D_LEVELS);
@@ -108,6 +113,11 @@ device::max_image_levels_3d() const {
    return pipe->get_param(pipe, PIPE_CAP_MAX_TEXTURE_3D_LEVELS);
 }
 
+size_t
+device::max_image_array_number() const {
+   return pipe->get_param(pipe, PIPE_CAP_MAX_TEXTURE_ARRAY_LAYERS);
+}
+
 cl_uint
 device::max_samplers() const {
    return pipe->get_shader_param(pipe, PIPE_SHADER_COMPUTE,
index 6cf6c7fcb24077f2ea37a56716c5a40e5af96848..94a61d10500d7fdab94ec72517012c286c2e56fd 100644 (file)
@@ -51,8 +51,10 @@ namespace clover {
       cl_uint vendor_id() const;
       size_t max_images_read() const;
       size_t max_images_write() const;
+      size_t max_image_buffer_size() const;
       cl_uint max_image_levels_2d() const;
       cl_uint max_image_levels_3d() const;
+      size_t max_image_array_number() const;
       cl_uint max_samplers() const;
       cl_ulong max_mem_global() const;
       cl_ulong max_mem_local() const;