| // RUN: %libomp-compile-and-run |
| // The test checks the teams construct pseudocode executed on host |
| // Internal library staff to emulate compiler's code generation: |
| static ident_t dummy_loc = {0, 2, 0, 0, ";dummyFile;dummyFunc;0;0;;"}; |
| int __kmpc_global_thread_num(void*); |
| void __kmpc_push_num_teams(ident_t const*, int, int, int); |
| void __kmpc_fork_teams(ident_t const*, int argc, void *microtask, ...); |
| void foo(int *gtid, int *tid, int *nt) |
| { // start "serial" execution by master threads of each team |
| printf(" team %d, param %d\n", omp_get_team_num(), *nt); |
| printf("ERROR: teams before parallel: gtid, tid: %d %d, bad pointer: %p\n", *gtid, *tid, nt); |
| int th = __kmpc_global_thread_num(NULL); // registers initial thread |
| __kmpc_push_num_teams(&dummy_loc, th, N_TEAMS, N_THR); |
| __kmpc_fork_teams(&dummy_loc, 1, &foo, &nt); // pass 1 shared parameter "nt" |
| printf("failed with %d errors\n",err); |