[Beignet] [PATCH] utest: add test case for built-in function get_global_id.
Zhigang Gong
zhigang.gong at linux.intel.com
Mon Jul 22 00:43:43 PDT 2013
One comment as below:
On Thu, Jul 18, 2013 at 02:15:37PM +0800, Yi Sun wrote:
> Signed-off-by: Yi Sun <yi.sun at intel.com>
>
> diff --git a/kernels/builtin_global_id.cl b/kernels/builtin_global_id.cl
> new file mode 100644
> index 0000000..6a2957d
> --- /dev/null
> +++ b/kernels/builtin_global_id.cl
> @@ -0,0 +1,4 @@
> +kernel void builtin_global_id( __global int *ret, __global int *i_dim ) {
i_dim is defined as kernel argument, but haven't been used. Is it what you intend to do?
> + int id = get_global_id(0) + get_global_id(1)*3 + get_global_id(2)*3*4;
> + ret[id] = id;
> +}
> diff --git a/utests/CMakeLists.txt b/utests/CMakeLists.txt
> index 1cdbd24..97d1506 100644
> --- a/utests/CMakeLists.txt
> +++ b/utests/CMakeLists.txt
> @@ -104,6 +104,7 @@ set (utests_sources
> builtin_mad_sat.cpp
> buildin_work_dim.cpp
> builtin_global_size.cpp
> + builtin_global_id.cpp
> runtime_createcontext.cpp
> runtime_null_kernel_arg.cpp
> compiler_double.cpp
> diff --git a/utests/builtin_global_id.cpp b/utests/builtin_global_id.cpp
> new file mode 100644
> index 0000000..27cb7af
> --- /dev/null
> +++ b/utests/builtin_global_id.cpp
> @@ -0,0 +1,88 @@
> +/*
> +According to the OpenCL v1.1 & v1.2 chapter 6.11.
> +Now define global size as following:
> + globals[0] = 3;
> + globals[1] = 4;
> + globals[2] = 5;
> +
> +Kernel:
> +id = get_global_id(0) + get_global_id(1)*3 + get_global_id(2)*3*4
> +
> +dimension:1
> + 0 1 2
> +dimension:2
> + 0 1 2
> + 3 4 5
> + 6 7 8
> + 9 10 11
> +dimension:3
> + 0 1 2 12 13 14 24 25 26 36 37 38 48 49 50
> + 3 4 5 15 16 17 27 28 29 39 40 41 51 52 53
> + 6 7 8 18 19 20 30 31 32 42 43 44 54 55 56
> + 9 10 11 21 22 23 33 34 35 45 46 47 57 58 59
> +*/
> +
> +#define udebug 0
> +#include "utest_helper.hpp"
> +static void builtin_global_id(void)
> +{
> +
> + // Setup kernel and buffers
> + int dim, dim_arg_global=0, global_id[80], err, i, buf_len=1;
> + OCL_CREATE_KERNEL("builtin_global_id");
> +
> + OCL_CREATE_BUFFER(buf[0], CL_MEM_READ_WRITE, sizeof(int)*80, NULL);
> + OCL_CREATE_BUFFER(buf[1], CL_MEM_READ_WRITE, sizeof(int), NULL);
> + OCL_SET_ARG(0, sizeof(cl_mem), &buf[0]);
> + OCL_SET_ARG(1, sizeof(cl_mem), &buf[1]);
> +
> + for( dim=1; dim <= 3; dim++ )
> + {
> + buf_len = 1;
> + for(i=1; i <= dim; i++)
> + {
> + globals[i - 1] = 2 + i;
> + locals[i - 1] = 2 + i;
> + buf_len *= 2 + i;
> + }
> + for(i=dim+1; i <= 3; i++)
> + {
> + globals[i - 1] = 0;
> + locals[i - 1] = 0;
> + }
> +
> + dim_arg_global = dim - 1;
> +
> + err = clEnqueueWriteBuffer( queue, buf[1], CL_TRUE, 0, sizeof(int), &dim_arg_global, 0, NULL, NULL);
> + if (err != CL_SUCCESS)
> + {
> + printf("Error: Failed to write to source array!\n");
> + exit(1);
> + }
> +
> + // Run the kernel
> + OCL_NDRANGE( dim );
> + clFinish(queue);
> +
> + err = clEnqueueReadBuffer( queue, buf[0], CL_TRUE, 0, sizeof(int) * buf_len, &global_id, 0, NULL, NULL);
> +
> + if (err != CL_SUCCESS)
> + {
> + printf("Error: Failed to read output array! %d\n", err);
> + exit(1);
> + }
> +
> +#if udebug
> + for(i = 0; i < buf_len; i++)
> + {
> + printf("%2d ", global_id[i]);
> + if ((i + 1) % 3 == 0) printf("\n");
> + }
> +#endif
> +
> + for( i = 0; i < buf_len; i++)
> + OCL_ASSERT( global_id[i] == i);
> + }
> +}
> +
> +MAKE_UTEST_FROM_FUNCTION(builtin_global_id);
> --
> 1.7.6.4
>
> _______________________________________________
> Beignet mailing list
> Beignet at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/beignet
More information about the Beignet
mailing list