[Beignet] [PATCH] support clGetImageInfo
He Junyan
junyan.he at inbox.com
Wed Jul 10 01:00:50 PDT 2013
I think it is better to add a case in get_cl_info.cpp as
all other getXXXinfo-like APIs.
On 07/10/2013 02:20 PM, Homer Hsing wrote:
> clGetImageInfo() is an OpenCL API. It returns information of an image.
>
> This patch makes Piglit test case "clGetImageInfo" pass.
>
> Signed-off-by: Homer Hsing <homer.xing at intel.com>
> ---
> src/cl_api.c | 7 +++++--
> src/cl_mem.c | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++
> src/cl_mem.h | 3 +++
> 3 files changed, 59 insertions(+), 2 deletions(-)
>
> diff --git a/src/cl_api.c b/src/cl_api.c
> index dc52f0a..277f7a9 100644
> --- a/src/cl_api.c
> +++ b/src/cl_api.c
> @@ -573,8 +573,11 @@ clGetImageInfo(cl_mem image,
> void * param_value,
> size_t * param_value_size_ret)
> {
> - NOT_IMPLEMENTED;
> - return 0;
> + return cl_get_image_info(image,
> + param_name,
> + param_value_size,
> + param_value,
> + param_value_size_ret);
> }
>
> cl_int
> diff --git a/src/cl_mem.c b/src/cl_mem.c
> index 5465aa9..064ecb3 100644
> --- a/src/cl_mem.c
> +++ b/src/cl_mem.c
> @@ -90,6 +90,57 @@ cl_get_mem_object_info(cl_mem mem,
> return CL_SUCCESS;
> }
>
> +LOCAL cl_int
> +cl_get_image_info(cl_mem mem,
> + cl_image_info param_name,
> + size_t param_value_size,
> + void *param_value,
> + size_t *param_value_size_ret)
> +{
> + if(!mem || !mem->is_image)
> + return CL_INVALID_MEM_OBJECT;
> +
> + switch(param_name)
> + {
> + FIELD_SIZE(IMAGE_FORMAT, cl_image_format);
> + FIELD_SIZE(IMAGE_ELEMENT_SIZE, size_t);
> + FIELD_SIZE(IMAGE_ROW_PITCH, size_t);
> + FIELD_SIZE(IMAGE_SLICE_PITCH, size_t);
> + FIELD_SIZE(IMAGE_WIDTH, size_t);
> + FIELD_SIZE(IMAGE_HEIGHT, size_t);
> + FIELD_SIZE(IMAGE_DEPTH, size_t);
> + default:
> + return CL_INVALID_VALUE;
> + }
> +
> + switch(param_name)
> + {
> + case CL_IMAGE_FORMAT:
> + *(cl_image_format *)param_value = mem->fmt;
> + break;
> + case CL_IMAGE_ELEMENT_SIZE:
> + *(size_t *)param_value = mem->bpp;
> + break;
> + case CL_IMAGE_ROW_PITCH:
> + *(size_t *)param_value = mem->row_pitch;
> + break;
> + case CL_IMAGE_SLICE_PITCH:
> + *(size_t *)param_value = mem->slice_pitch;
> + break;
> + case CL_IMAGE_WIDTH:
> + *(size_t *)param_value = mem->w;
> + break;
> + case CL_IMAGE_HEIGHT:
> + *(size_t *)param_value = mem->h;
> + break;
> + case CL_IMAGE_DEPTH:
> + *(size_t *)param_value = mem->depth;
> + break;
> + }
> +
> + return CL_SUCCESS;
> +}
> +
> #undef FIELD_SIZE
>
> static cl_mem
> diff --git a/src/cl_mem.h b/src/cl_mem.h
> index c204992..c63bf6c 100644
> --- a/src/cl_mem.h
> +++ b/src/cl_mem.h
> @@ -73,6 +73,9 @@ struct _cl_mem {
> /* Query information about a memory object */
> extern cl_int cl_get_mem_object_info(cl_mem, cl_mem_info, size_t, void *, size_t *);
>
> +/* Query information about an image */
> +extern cl_int cl_get_image_info(cl_mem, cl_image_info, size_t, void *, size_t *);
> +
> /* Create a new memory object and initialize it with possible user data */
> extern cl_mem cl_mem_new(cl_context, cl_mem_flags, size_t, void*, cl_int*);
>
More information about the Beignet
mailing list