32#define mysleep(n) Sleep(n)
35#define mysleep(n) usleep((n)*1000)
54#define DEP_ALL_MEM 0x80
76 #pragma omp atomic capture
78 th = omp_get_thread_num();
79 printf(
"task m_%d, th %d, checker %d\n",
ptask->
f_priv, th, lcheck);
82 printf(
"Error m1, checker %d != 1\n", lcheck);
85 #pragma omp atomic read
89 printf(
"Error m2, checker %d != 1\n", lcheck);
98 #pragma omp atomic capture
100 th = omp_get_thread_num();
101 printf(
"task 2_%d, th %d, checker %d\n",
ptask->
f_priv, th, lcheck);
104 printf(
"Error s1, checker %d != 1\n", lcheck);
107 #pragma omp atomic read
111 printf(
"Error s2, checker %d != 1\n", lcheck);
125 dep *dep_lst,
int nd_noalias,
dep *noalias_lst);
127 int ndeps_noalias,
dep *noalias_dep_lst);
128static id loc = {0, 2, 0, 0,
";file;func;0;0;;"};
142 #pragma omp single nowait
147 int t = omp_get_thread_num();
154 int th = omp_get_thread_num();
155 printf(
"signalled independent task 9_%d, th %d started....\n", t, th);
160 #pragma omp atomic read
165 printf(
"signalled independent task 9_%d, th %d finished....\n", t, th);
167 #pragma omp task depend(in: i1, i2)
170 #pragma omp atomic capture
172 th = omp_get_thread_num();
173 printf(
"task 0_%d, th %d, checker %d\n", t, th, lcheck);
174 if (lcheck > 2 || lcheck < 1) {
176 printf(
"Error1, checker %d, not 1 or 2\n", lcheck);
179 #pragma omp atomic read
181 if (lcheck > 2 || lcheck < 1) {
184 printf(
"Error2, checker %d, not 1 or 2\n", lcheck);
189 #pragma omp task depend(in: i1, i2)
192 #pragma omp atomic capture
194 th = omp_get_thread_num();
195 printf(
"task 1_%d, th %d, checker %d\n", t, th, lcheck);
196 if (lcheck > 2 || lcheck < 1) {
198 printf(
"Error3, checker %d, not 1 or 2\n", lcheck);
201 #pragma omp atomic read
203 if (lcheck > 2 || lcheck < 1) {
205 printf(
"Error4, checker %d, not 1 or 2\n", lcheck);
213 sdep[0].
addr = (size_t)&i1;
216 sdep[1].
addr = (size_t)&i2;
224 sdep[0].
addr = (size_t)&i1;
233 #pragma omp task depend(in: i1, i2)
236 #pragma omp atomic capture
238 th = omp_get_thread_num();
239 printf(
"task 4_%d, th %d, checker %d\n", t, th, lcheck);
240 if (lcheck > 2 || lcheck < 1) {
242 printf(
"Error5, checker %d, not 1 or 2\n", lcheck);
245 #pragma omp atomic read
247 if (lcheck > 2 || lcheck < 1) {
249 printf(
"Error6, checker %d, not 1 or 2\n", lcheck);
254 #pragma omp task depend(in: i1, i2)
257 #pragma omp atomic capture
259 th = omp_get_thread_num();
260 printf(
"task 5_%d, th %d, checker %d\n", t, th, lcheck);
261 if (lcheck > 2 || lcheck < 1) {
263 printf(
"Error7, checker %d, not 1 or 2\n", lcheck);
266 #pragma omp atomic read
268 if (lcheck > 2 || lcheck < 1) {
270 printf(
"Error8, checker %d, not 1 or 2\n", lcheck);
278 sdep[0].
addr = (size_t)(-1);
289 sdep[1].
addr = (size_t)&i3;
295 #pragma omp task depend(in: i3)
298 #pragma omp atomic capture
300 th = omp_get_thread_num();
301 printf(
"task 8_%d, th %d, checker %d\n", t, th, lcheck);
304 printf(
"Error9, checker %d, != 1\n", lcheck);
307 #pragma omp atomic read
311 printf(
"Error10, checker %d, != 1\n", lcheck);
318 printf(
"all 10 tasks generated;\n"
319 "taskwait depend(omp_all_memory: out) started, th %d\n", t);
321 #pragma omp atomic write
323 printf(
"taskwait depend(omp_all_memory: out) passed, th %d\n", t);
331 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)
void __kmpc_omp_wait_deps(id *loc, int gtid, int ndeps, dep *dep_lst, int ndeps_noalias, dep *noalias_dep_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 *)