summaryrefslogtreecommitdiff
path: root/utests/compiler_pipe_builtin.cpp
blob: 99270d190ba9b3d634e0ec94f6dd7046b1873a7b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#include <string.h>
#include "utest_helper.hpp"
typedef struct{
  int a;
  uint b;
}mystruct;

#define PIPE_BUILTIN(TYPE,GROUP) \
static void compiler_pipe_##GROUP##_##TYPE(void) \
{ \
  if(!cl_check_ocl20(false))\
    return;\
  const size_t w = 16;  \
  uint32_t ans_host = 0;  \
  uint32_t ans_device = 0;  \
  /* pipe write kernel*/  \
  OCL_CALL(cl_kernel_init, "compiler_pipe_builtin.cl", "compiler_pipe_"#GROUP"_write_"#TYPE, SOURCE, "-cl-std=CL2.0");\
  OCL_CALL2(clCreatePipe, buf[0], ctx, 0, sizeof(TYPE), w, NULL);\
  OCL_CREATE_BUFFER(buf[1], CL_MEM_READ_WRITE, w * sizeof(TYPE), NULL);\
  OCL_MAP_BUFFER(1);\
  for (uint32_t i = 0; i < w; i++)\
      ((uint32_t*)buf_data[1])[i] = i;\
  OCL_UNMAP_BUFFER(1);\
  OCL_SET_ARG(0, sizeof(cl_mem), &buf[0]);\
  OCL_SET_ARG(1, sizeof(cl_mem), &buf[1]);\
  globals[0] = w;\
  locals[0] = 16;\
  OCL_NDRANGE(1);\
  OCL_CALL(clReleaseKernel, kernel);\
  /* pipe read kernel */\
  OCL_CALL(cl_kernel_init, "compiler_pipe_builtin.cl", "compiler_pipe_"#GROUP"_read_"#TYPE, SOURCE, "-cl-std=CL2.0");\
  OCL_CREATE_BUFFER(buf[2], CL_MEM_READ_WRITE, w * sizeof(TYPE), NULL);\
  OCL_SET_ARG(0, sizeof(cl_mem), &buf[0]);\
  OCL_SET_ARG(1, sizeof(cl_mem), &buf[2]);\
  OCL_NDRANGE(1);\
  /* Check result */\
  OCL_MAP_BUFFER(2);\
  for (uint32_t i = 0; i < w; i++) {\
      ans_device += ((uint32_t*)buf_data[2])[i];\
      ans_host += i;\
  }\
  OCL_UNMAP_BUFFER(2);\
  OCL_ASSERT(ans_host == ans_device);\
}\
MAKE_UTEST_FROM_FUNCTION(compiler_pipe_##GROUP##_##TYPE);

PIPE_BUILTIN(int, convenience)
PIPE_BUILTIN(mystruct, convenience)
PIPE_BUILTIN(int, reserve)
PIPE_BUILTIN(mystruct, reserve)
PIPE_BUILTIN(int, workgroup)
PIPE_BUILTIN(mystruct, workgroup)

static void compiler_pipe_query(void) {
  const size_t w = 32;
  const size_t sz = 16;
  if(!cl_check_ocl20(false)){return;}
  /* pipe write kernel */
  OCL_CALL(cl_kernel_init, "compiler_pipe_builtin.cl", "compiler_pipe_query", SOURCE, "-cl-std=CL2.0");
  OCL_CALL2(clCreatePipe, buf[0], ctx, 0, sizeof(uint32_t), w, NULL);
  OCL_CREATE_BUFFER(buf[1], CL_MEM_READ_WRITE, sz * sizeof(uint32_t), NULL);
  OCL_SET_ARG(0, sizeof(cl_mem), &buf[0]);
  OCL_SET_ARG(1, sizeof(cl_mem), &buf[1]);
  globals[0] = sz;
  locals[0] = 16;
  OCL_NDRANGE(1);
  /*Check result */
  OCL_MAP_BUFFER(1);
  OCL_ASSERT(sz == ((uint32_t *)buf_data[1])[0] && w == ((uint32_t *)buf_data[1])[1]);
  OCL_UNMAP_BUFFER(2);
}
MAKE_UTEST_FROM_FUNCTION(compiler_pipe_query);