blob: f63e2913c749e7b8ab9ff1ab5afbfaa04265826e [file] [log] [blame]
Anastasia Stulovab42f3c02017-04-21 15:13:24 +00001// RUN: %clang_cc1 %s -cl-std=CL2.0 -triple "spir-unknown-unknown" -verify -pedantic -fsyntax-only -DB32 -DQUALS=
2// RUN: %clang_cc1 %s -cl-std=CL2.0 -triple "spir-unknown-unknown" -verify -pedantic -fsyntax-only -DB32 -DQUALS="const volatile"
3// RUN: %clang_cc1 %s -cl-std=CL2.0 -triple "spir64-unknown-unknown" -verify -pedantic -fsyntax-only -Wconversion -DWCONV -DQUALS=
4// RUN: %clang_cc1 %s -cl-std=CL2.0 -triple "spir64-unknown-unknown" -verify -pedantic -fsyntax-only -Wconversion -DWCONV -DQUALS="const volatile"
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +00005
Anastasia Stulova58984e72017-02-16 12:27:47 +00006typedef struct {int a;} ndrange_t;
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +00007// Diagnostic tests for different overloads of enqueue_kernel from Table 6.13.17.1 of OpenCL 2.0 Spec.
8kernel void enqueue_kernel_tests() {
9 queue_t default_queue;
10 unsigned flags = 0;
Anastasia Stulovab42f3c02017-04-21 15:13:24 +000011 QUALS ndrange_t ndrange;
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000012 clk_event_t evt;
13 clk_event_t event_wait_list;
14 clk_event_t event_wait_list2[] = {evt, evt};
15 void *vptr;
16
17 // Testing the first overload type
18 enqueue_kernel(default_queue, flags, ndrange, ^(void) {
19 return 0;
20 });
21
Joey Gouly6b03d952017-07-04 11:50:23 +000022 enqueue_kernel(vptr, flags, ndrange, ^(void) { // expected-error{{illegal call to 'enqueue_kernel', expected 'queue_t' argument type}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000023 return 0;
24 });
25
Joey Gouly6b03d952017-07-04 11:50:23 +000026 enqueue_kernel(default_queue, vptr, ndrange, ^(void) { // expected-error{{illegal call to 'enqueue_kernel', expected 'kernel_enqueue_flags_t' (i.e. uint) argument type}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000027 return 0;
28 });
29
Joey Gouly6b03d952017-07-04 11:50:23 +000030 enqueue_kernel(default_queue, flags, vptr, ^(void) { // expected-error{{illegal call to 'enqueue_kernel', expected 'ndrange_t' argument type}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000031 return 0;
32 });
33
Joey Gouly6b03d952017-07-04 11:50:23 +000034 enqueue_kernel(default_queue, flags, ndrange, vptr); // expected-error{{illegal call to 'enqueue_kernel', expected block argument}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000035
Anastasia Stulova8ac3d0c2017-01-23 17:12:36 +000036 enqueue_kernel(default_queue, flags, ndrange, ^(int i) { // expected-error{{blocks with parameters are not accepted in this prototype of enqueue_kernel call}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000037 return 0;
38 });
39
40 // Testing the second overload type
41 enqueue_kernel(default_queue, flags, ndrange, 1, &event_wait_list, &evt, ^(void) {
Anastasia Stulova2b461202016-11-14 15:34:01 +000042 return 0;
43 });
44
45 enqueue_kernel(default_queue, flags, ndrange, 1, 0, 0, ^(void) {
46 return 0;
47 });
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000048
Joey Gouly6b03d952017-07-04 11:50:23 +000049 enqueue_kernel(default_queue, flags, ndrange, vptr, &event_wait_list, &evt, ^(void) { // expected-error{{illegal call to 'enqueue_kernel', expected integer argument type}}
Anastasia Stulova0df4ac32016-11-14 17:39:58 +000050 return 0;
51 });
52
Joey Gouly6b03d952017-07-04 11:50:23 +000053 enqueue_kernel(default_queue, flags, ndrange, 1, vptr, &evt, ^(void) // expected-error{{illegal call to 'enqueue_kernel', expected 'clk_event_t *' argument type}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000054 {
55 return 0;
56 });
57
Joey Gouly6b03d952017-07-04 11:50:23 +000058 enqueue_kernel(default_queue, flags, ndrange, 1, &event_wait_list, vptr, ^(void) // expected-error{{illegal call to 'enqueue_kernel', expected 'clk_event_t *' argument type}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000059 {
60 return 0;
61 });
62
Joey Gouly6b03d952017-07-04 11:50:23 +000063 enqueue_kernel(default_queue, flags, ndrange, 1, &event_wait_list, &evt, vptr); // expected-error{{illegal call to 'enqueue_kernel', expected block argument}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000064
65 // Testing the third overload type
66 enqueue_kernel(default_queue, flags, ndrange,
67 ^(local void *a, local void *b) {
68 return 0;
69 },
70 1024, 1024);
71
72 enqueue_kernel(default_queue, flags, ndrange,
73 ^(local void *a, local void *b) {
74 return 0;
75 },
Anastasia Stulova0df4ac32016-11-14 17:39:58 +000076 1024L, 1024);
77
78 enqueue_kernel(default_queue, flags, ndrange,
79 ^(local void *a, local void *b) {
80 return 0;
81 },
82 1024, 4294967296L);
83#ifdef B32
84// expected-warning@-2{{implicit conversion from 'long' to 'unsigned int' changes value from 4294967296 to 0}}
85#endif
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000086
87 char c;
88 enqueue_kernel(default_queue, flags, ndrange,
89 ^(local void *a, local void *b) {
90 return 0;
91 },
Anastasia Stulova0df4ac32016-11-14 17:39:58 +000092 c, 1024L);
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +000093#ifdef WCONV
Anastasia Stulova869d17d2019-12-27 13:38:48 +000094// expected-warning-re@-2{{implicit conversion changes signedness: '__private char' to 'unsigned {{int|long}}'}}
Anastasia Stulova0df4ac32016-11-14 17:39:58 +000095#endif
96#define UINT_MAX 4294967295
97
98 enqueue_kernel(default_queue, flags, ndrange,
99 ^(local void *a, local void *b) {
100 return 0;
101 },
102 sizeof(int), sizeof(int) * UINT_MAX);
103#ifdef B32
104// expected-warning@-2{{implicit conversion from 'long' to 'unsigned int' changes value from 17179869180 to 4294967292}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000105#endif
106
107 typedef void (^bl_A_t)(local void *);
108
109 const bl_A_t block_A = (bl_A_t) ^ (local void *a) {};
110
111 enqueue_kernel(default_queue, flags, ndrange, block_A, 1024);
112
113 typedef void (^bl_B_t)(local void *, local int *);
114
115 const bl_B_t block_B = (bl_B_t) ^ (local void *a, local int *b) {};
116
Anastasia Stulova8ac3d0c2017-01-23 17:12:36 +0000117 enqueue_kernel(default_queue, flags, ndrange, block_B, 1024, 1024); // expected-error{{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000118
119 enqueue_kernel(default_queue, flags, ndrange, // expected-error{{mismatch in number of block parameters and local size arguments passed}}
120 ^(local void *a, local void *b) {
121 return 0;
122 },
123 1024);
124
125 float illegal_mem_size = (float)0.5f;
126 enqueue_kernel(default_queue, flags, ndrange,
127 ^(local void *a, local void *b) {
128 return 0;
129 },
Anastasia Stulova0df4ac32016-11-14 17:39:58 +0000130 illegal_mem_size, illegal_mem_size); // expected-error{{illegal call to enqueue_kernel, parameter needs to be specified as integer type}} expected-error{{illegal call to enqueue_kernel, parameter needs to be specified as integer type}}
131
132 enqueue_kernel(default_queue, flags, ndrange,
133 ^(local void *a, local void *b) {
134 return 0;
135 },
136 illegal_mem_size, 1024); // expected-error{{illegal call to enqueue_kernel, parameter needs to be specified as integer type}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000137
138 // Testing the forth overload type
139 enqueue_kernel(default_queue, flags, ndrange, 1, event_wait_list2, &evt,
140 ^(local void *a, local void *b) {
141 return 0;
142 },
143 1024, 1024);
144
Anastasia Stulova2b461202016-11-14 15:34:01 +0000145 enqueue_kernel(default_queue, flags, ndrange, 1, 0, 0,
146 ^(local void *a, local void *b) {
147 return 0;
148 },
149 1024, 1024);
150
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000151 enqueue_kernel(default_queue, flags, ndrange, 1, &event_wait_list, &evt, // expected-error{{mismatch in number of block parameters and local size arguments passed}}
152 ^(local void *a, local void *b) {
153 return 0;
154 },
155 1024, 1024, 1024);
156
157 // More random misc cases that can't be deduced
158 enqueue_kernel(default_queue, flags, ndrange, 1, &event_wait_list, &evt); // expected-error{{illegal call to enqueue_kernel, incorrect argument types}}
159
160 enqueue_kernel(default_queue, flags, ndrange, 1, 1); // expected-error{{illegal call to enqueue_kernel, incorrect argument types}}
Sven van Haastregta280b632019-08-29 10:21:06 +0000161
162 enqueue_kernel(default_queue, ndrange, ^{}); // expected-error{{too few arguments to function call, expected at least 4, have 3}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000163}
164
165// Diagnostic tests for get_kernel_work_group_size and allowed block parameter types in dynamic parallelism.
166kernel void work_group_size_tests() {
167 void (^const block_A)(void) = ^{
168 return;
169 };
170 void (^const block_B)(int) = ^(int a) {
171 return;
172 };
173 void (^const block_C)(local void *) = ^(local void *a) {
174 return;
175 };
176 void (^const block_D)(local int *) = ^(local int *a) {
177 return;
178 };
179
180 unsigned size = get_kernel_work_group_size(block_A);
181 size = get_kernel_work_group_size(block_C);
182 size = get_kernel_work_group_size(^(local void *a) {
183 return;
184 });
Anastasia Stulova8ac3d0c2017-01-23 17:12:36 +0000185 size = get_kernel_work_group_size(^(local int *a) { // expected-error {{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000186 return;
187 });
Anastasia Stulova8ac3d0c2017-01-23 17:12:36 +0000188 size = get_kernel_work_group_size(block_B); // expected-error {{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
189 size = get_kernel_work_group_size(block_D); // expected-error {{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
190 size = get_kernel_work_group_size(^(int a) { // expected-error {{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000191 return;
192 });
193 size = get_kernel_work_group_size(); // expected-error {{too few arguments to function call, expected 1, have 0}}
194 size = get_kernel_work_group_size(1); // expected-error{{expected block argument}}
195 size = get_kernel_work_group_size(block_A, 1); // expected-error{{too many arguments to function call, expected 1, have 2}}
196
197 size = get_kernel_preferred_work_group_size_multiple(block_A);
198 size = get_kernel_preferred_work_group_size_multiple(block_C);
199 size = get_kernel_preferred_work_group_size_multiple(^(local void *a) {
200 return;
201 });
Anastasia Stulova8ac3d0c2017-01-23 17:12:36 +0000202 size = get_kernel_preferred_work_group_size_multiple(^(local int *a) { // expected-error {{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000203 return;
204 });
Anastasia Stulova8ac3d0c2017-01-23 17:12:36 +0000205 size = get_kernel_preferred_work_group_size_multiple(^(int a) { // expected-error {{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000206 return;
207 });
Anastasia Stulova8ac3d0c2017-01-23 17:12:36 +0000208 size = get_kernel_preferred_work_group_size_multiple(block_B); // expected-error {{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
209 size = get_kernel_preferred_work_group_size_multiple(block_D); // expected-error {{blocks used in enqueue_kernel call are expected to have parameters of type 'local void*'}}
Anastasia Stulovadb7a31c2016-07-05 11:31:24 +0000210 size = get_kernel_preferred_work_group_size_multiple(); // expected-error {{too few arguments to function call, expected 1, have 0}}
211 size = get_kernel_preferred_work_group_size_multiple(1); // expected-error{{expected block argument}}
212 size = get_kernel_preferred_work_group_size_multiple(block_A, 1); // expected-error{{too many arguments to function call, expected 1, have 2}}
213}
Joey Goulyfa76b492017-08-01 13:27:09 +0000214
215#pragma OPENCL EXTENSION cl_khr_subgroups : enable
216
Marco Antogninic0d541d2018-10-19 09:01:37 +0000217kernel void foo(global unsigned int *buf)
Joey Goulyfa76b492017-08-01 13:27:09 +0000218{
219 ndrange_t n;
220 buf[0] = get_kernel_max_sub_group_size_for_ndrange(n, ^(){});
221 buf[0] = get_kernel_max_sub_group_size_for_ndrange(0, ^(){}); // expected-error{{illegal call to 'get_kernel_max_sub_group_size_for_ndrange', expected 'ndrange_t' argument type}}
222 buf[0] = get_kernel_max_sub_group_size_for_ndrange(n, 1); // expected-error{{illegal call to 'get_kernel_max_sub_group_size_for_ndrange', expected block argument type}}
223}
224
Marco Antogninic0d541d2018-10-19 09:01:37 +0000225kernel void bar(global unsigned int *buf)
Joey Goulyfa76b492017-08-01 13:27:09 +0000226{
Yaxun Liub7318e02017-10-13 03:37:48 +0000227 __private ndrange_t n;
Joey Goulyfa76b492017-08-01 13:27:09 +0000228 buf[0] = get_kernel_sub_group_count_for_ndrange(n, ^(){});
229 buf[0] = get_kernel_sub_group_count_for_ndrange(0, ^(){}); // expected-error{{illegal call to 'get_kernel_sub_group_count_for_ndrange', expected 'ndrange_t' argument type}}
230 buf[0] = get_kernel_sub_group_count_for_ndrange(n, 1); // expected-error{{illegal call to 'get_kernel_sub_group_count_for_ndrange', expected block argument type}}
231}
232
233#pragma OPENCL EXTENSION cl_khr_subgroups : disable
234
Marco Antogninic0d541d2018-10-19 09:01:37 +0000235kernel void foo1(global unsigned int *buf)
Joey Goulyfa76b492017-08-01 13:27:09 +0000236{
237 ndrange_t n;
238 buf[0] = get_kernel_max_sub_group_size_for_ndrange(n, ^(){}); // expected-error {{use of declaration 'get_kernel_max_sub_group_size_for_ndrange' requires cl_khr_subgroups extension to be enabled}}
239}
240
Marco Antogninic0d541d2018-10-19 09:01:37 +0000241kernel void bar1(global unsigned int *buf)
Joey Goulyfa76b492017-08-01 13:27:09 +0000242{
243 ndrange_t n;
244 buf[0] = get_kernel_sub_group_count_for_ndrange(n, ^(){}); // expected-error {{use of declaration 'get_kernel_sub_group_count_for_ndrange' requires cl_khr_subgroups extension to be enabled}}
245}