diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2017-09-15 13:24:51 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2017-09-15 13:57:53 +0200 |
commit | 8230a329d34b2298d80817e900c3bde2cdcbdea0 (patch) | |
tree | 217c457b44cab7f331b5bdf315ea1957d4109859 /testsuites/psxtests | |
parent | 3b47ce73fa67efaeb1c92dc0129efa92f22d747c (diff) |
posix: Allow PTHREAD_PROCESS_SHARED for barriers
Close #3126.
Diffstat (limited to 'testsuites/psxtests')
-rw-r--r-- | testsuites/psxtests/psxbarrier01/psxbarrier01.scn | 8 | ||||
-rw-r--r-- | testsuites/psxtests/psxbarrier01/test.c | 17 |
2 files changed, 23 insertions, 2 deletions
diff --git a/testsuites/psxtests/psxbarrier01/psxbarrier01.scn b/testsuites/psxtests/psxbarrier01/psxbarrier01.scn index 6b714115ae..d568d8d03e 100644 --- a/testsuites/psxtests/psxbarrier01/psxbarrier01.scn +++ b/testsuites/psxtests/psxbarrier01/psxbarrier01.scn @@ -1,4 +1,4 @@ -*** POSIX BARRIER TEST 01 *** +*** BEGIN OF TEST PSXBARRIER 1 *** pthread_barrierattr_init( NULL ) -- EINVAL pthread_barrierattr_setpshared( NULL, private ) -- EINVAL pthread_barrierattr_setpshared( NULL, shared ) -- EINVAL @@ -19,6 +19,10 @@ pthread_barrier_init( NULL, NULL, 2 ) -- EINVAL pthread_barrier_init( &barrier, &attr, 2 ) -- EINVAL pthread_barrierattr_init( &attr ) -- OK pthread_barrier_init( &barrier, &attr, 0 ) -- EINVAL +pthread_barrier_init( &barrier, &attr, 1 ) -- EINVAL +pthread_barrierattr_setpshared( &attr, shared ) -- OK +pthread_barrier_init( &barrier, &attr, 1 ) -- OK +pthread_barrier_destroy( &barrier ) -- OK pthread_barrier_init( &barrier, NULL, 1 ) -- OK pthread_barrier_init( &barrier, NULL, 1 ) -- EAGAIN pthread_barrier_destroy( &barrier ) -- OK @@ -38,4 +42,4 @@ Init: pthread_create - thread 2 OK pthread_barrier_wait( &Barrier ) for thread 0x0b010002 pthread_barrier_wait - 0x0b010002 released pthread_barrier_wait - 0x0b010001 released -*** END OF POSIX BARRIER TEST 01 *** +*** END OF TEST PSXBARRIER 1 *** diff --git a/testsuites/psxtests/psxbarrier01/test.c b/testsuites/psxtests/psxbarrier01/test.c index bcbb87a467..16e8665b94 100644 --- a/testsuites/psxtests/psxbarrier01/test.c +++ b/testsuites/psxtests/psxbarrier01/test.c @@ -161,6 +161,23 @@ int main( status = pthread_barrier_init( &barrier, &attr, 0 ); rtems_test_assert( status == EINVAL ); + puts( "pthread_barrier_init( &barrier, &attr, 1 ) -- EINVAL" ); + attr.process_shared = -1; + status = pthread_barrier_init( &barrier, &attr, 1 ); + rtems_test_assert( status == EINVAL ); + + puts( "pthread_barrierattr_setpshared( &attr, shared ) -- OK" ); + status = pthread_barrierattr_setpshared( &attr, PTHREAD_PROCESS_SHARED ); + rtems_test_assert( status == 0 ); + + puts( "pthread_barrier_init( &barrier, &attr, 1 ) -- OK" ); + status = pthread_barrier_init( &barrier, &attr, 1 ); + rtems_test_assert( status == 0 ); + + puts( "pthread_barrier_destroy( &barrier ) -- OK" ); + status = pthread_barrier_destroy( &barrier ); + rtems_test_assert( status == 0 ); + /* allocating too many */ puts( "pthread_barrier_init( &barrier, NULL, 1 ) -- OK" ); status = pthread_barrier_init( &barrier, NULL, 1 ); |