/* { dg-do run { target *-*-linux* *-*-gnu* *-*-freebsd* } } */ #ifndef _GNU_SOURCE #define _GNU_SOURCE 1 #endif #include #include #include #include pthread_barrier_t bar; omp_nest_lock_t lock; void *tf (void *p) { int l; if (p) { if (omp_test_nest_lock (&lock) != 1) abort (); if (omp_test_nest_lock (&lock) != 2) abort (); } pthread_barrier_wait (&bar); if (!p && omp_test_nest_lock (&lock) != 0) abort (); pthread_barrier_wait (&bar); if (p) { if (omp_test_nest_lock (&lock) != 3) abort (); omp_unset_nest_lock (&lock); omp_unset_nest_lock (&lock); omp_unset_nest_lock (&lock); } pthread_barrier_wait (&bar); if (!p) { if (omp_test_nest_lock (&lock) != 1) abort (); if (omp_test_nest_lock (&lock) != 2) abort (); omp_unset_nest_lock (&lock); omp_unset_nest_lock (&lock); } return NULL; } int main (void) { pthread_t th; omp_init_nest_lock (&lock); pthread_barrier_init (&bar, NULL, 2); pthread_create (&th, NULL, tf, NULL); tf (""); pthread_join (th, NULL); omp_destroy_nest_lock (&lock); return 0; }