77#define mysleep(n) Sleep(n)
80#define mysleep(n) usleep((n)*1000)
97#define DEP_ALL_MEM 0x80
119#pragma omp atomic capture
121 th = omp_get_thread_num();
122 printf(
"task m_%d, th %d, checker %d\n",
ptask->
f_priv, th, lcheck);
125 printf(
"Error m1, checker %d != 1\n", lcheck);
128#pragma omp atomic read
132 printf(
"Error m2, checker %d != 1\n", lcheck);
141#pragma omp atomic capture
143 th = omp_get_thread_num();
144 printf(
"task 2_%d, th %d, checker %d\n",
ptask->
f_priv, th, lcheck);
147 printf(
"Error s1, checker %d != 1\n", lcheck);
150#pragma omp atomic read
154 printf(
"Error s2, checker %d != 1\n", lcheck);
168 dep *dep_lst,
int nd_noalias,
dep *noalias_lst);
169static id loc = {0, 2, 0, 0,
";file;func;0;0;;"};
177 char *ompx_all_memory = (
void *)0xffffffffffffffff;
183#pragma omp single nowait
188 int t = omp_get_thread_num();
189#pragma omp task depend(in : i1, i2)
192#pragma omp atomic capture
194 th = omp_get_thread_num();
195 printf(
"task 0_%d, th %d, checker %d\n", t, th, lcheck);
196 if (lcheck > 2 || lcheck < 1) {
198 printf(
"Error1, checker %d, not 1 or 2\n", lcheck);
201#pragma omp atomic read
203 if (lcheck > 2 || lcheck < 1) {
206 printf(
"Error2, checker %d, not 1 or 2\n", lcheck);
211#pragma omp task depend(in : i1, i2)
214#pragma omp atomic capture
216 th = omp_get_thread_num();
217 printf(
"task 1_%d, th %d, checker %d\n", t, th, lcheck);
218 if (lcheck > 2 || lcheck < 1) {
220 printf(
"Error3, checker %d, not 1 or 2\n", lcheck);
223#pragma omp atomic read
225 if (lcheck > 2 || lcheck < 1) {
227 printf(
"Error4, checker %d, not 1 or 2\n", lcheck);
235 sdep[0].
addr = (size_t)&i1;
238 sdep[1].
addr = (size_t)&i2;
245#pragma omp task depend(in : i1) depend(inout : ompx_all_memory[0])
248#pragma omp atomic capture
250 th = omp_get_thread_num();
251 printf(
"task m_%d, th %d, checker %d\n", t, th, lcheck);
254 printf(
"Error m1, checker %d != 1\n", lcheck);
257#pragma omp atomic read
261 printf(
"Error m2, checker %d != 1\n", lcheck);
267#pragma omp task depend(in : i1, i2)
270#pragma omp atomic capture
272 th = omp_get_thread_num();
273 printf(
"task 4_%d, th %d, checker %d\n", t, th, lcheck);
274 if (lcheck > 2 || lcheck < 1) {
276 printf(
"Error5, checker %d, not 1 or 2\n", lcheck);
279#pragma omp atomic read
281 if (lcheck > 2 || lcheck < 1) {
283 printf(
"Error6, checker %d, not 1 or 2\n", lcheck);
288#pragma omp task depend(in : i1, i2)
291#pragma omp atomic capture
293 th = omp_get_thread_num();
294 printf(
"task 5_%d, th %d, checker %d\n", t, th, lcheck);
295 if (lcheck > 2 || lcheck < 1) {
297 printf(
"Error7, checker %d, not 1 or 2\n", lcheck);
300#pragma omp atomic read
302 if (lcheck > 2 || lcheck < 1) {
304 printf(
"Error8, checker %d, not 1 or 2\n", lcheck);
310#pragma omp task depend(inout : ompx_all_memory[0])
313#pragma omp atomic capture
315 th = omp_get_thread_num();
316 printf(
"task m_%d, th %d, checker %d\n", t, th, lcheck);
319 printf(
"Error m1, checker %d != 1\n", lcheck);
322#pragma omp atomic read
326 printf(
"Error m2, checker %d != 1\n", lcheck);
332#pragma omp task depend(inout : ompx_all_memory[0]) depend(mutexinoutset : i3)
335#pragma omp atomic capture
337 th = omp_get_thread_num();
338 printf(
"task m_%d, th %d, checker %d\n", t, th, lcheck);
341 printf(
"Error m1, checker %d != 1\n", lcheck);
344#pragma omp atomic read
348 printf(
"Error m2, checker %d != 1\n", lcheck);
353#pragma omp task depend(in : i3)
356#pragma omp atomic capture
358 th = omp_get_thread_num();
359 printf(
"task 8_%d, th %d, checker %d\n", t, th, lcheck);
362 printf(
"Error9, checker %d, != 1\n", lcheck);
365#pragma omp atomic read
369 printf(
"Error10, checker %d, != 1\n", lcheck);
380 printf(
"failed, err = %d, checker = %d\n",
err,
checker);
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp __itt_timestamp ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain ITT_FORMAT p const __itt_domain __itt_string_handle unsigned long long ITT_FORMAT lu const __itt_domain __itt_string_handle unsigned long long ITT_FORMAT lu const __itt_domain __itt_id __itt_string_handle __itt_metadata_type size_t void ITT_FORMAT p const __itt_domain __itt_id __itt_string_handle const wchar_t size_t ITT_FORMAT lu const __itt_domain __itt_id __itt_relation __itt_id ITT_FORMAT p const wchar_t int ITT_FORMAT __itt_group_mark d int
#define omp_set_num_threads
int thunk_s(int gtid, task_t *ptask)
int(* entry_t)(int, task_t *)
int thunk_m(int gtid, task_t *ptask)
int __kmpc_omp_task_with_deps(id *loc, int gtid, task_t *task, int ndeps, dep *dep_lst, int nd_noalias, dep *noalias_lst)
task_t * __kmpc_omp_task_alloc(id *loc, int gtid, int flags, size_t sz, size_t shar, entry_t rtn)
int __kmpc_global_thread_num(id *)