From e67929c4c0025ef46053523be4c8736dd178cbec Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Thu, 21 Sep 2017 14:13:16 +0200 Subject: posix: Implement self-contained POSIX barriers POSIX barriers are now available in all configurations and no longer depend on --enable-posix. Update #2514. Update #3114. --- testsuites/psxtests/psxbarrier01/main.c | 2 - testsuites/psxtests/psxbarrier01/psxbarrier01.scn | 7 +- testsuites/psxtests/psxbarrier01/test.c | 82 +++++++++++++++++------ testsuites/psxtests/psxconfig01/init.c | 13 ---- testsuites/psxtmtests/psxtmbarrier01/init.c | 1 - testsuites/psxtmtests/psxtmbarrier02/init.c | 1 - testsuites/psxtmtests/psxtmbarrier03/init.c | 1 - testsuites/psxtmtests/psxtmbarrier04/init.c | 1 - testsuites/sptests/spsysinit01/init.c | 16 ----- 9 files changed, 63 insertions(+), 61 deletions(-) (limited to 'testsuites') diff --git a/testsuites/psxtests/psxbarrier01/main.c b/testsuites/psxtests/psxbarrier01/main.c index 6475016730..f031c05b3c 100644 --- a/testsuites/psxtests/psxbarrier01/main.c +++ b/testsuites/psxtests/psxbarrier01/main.c @@ -40,8 +40,6 @@ rtems_task Init( #define CONFIGURE_MAXIMUM_POSIX_THREADS 10 -#define CONFIGURE_MAXIMUM_POSIX_BARRIERS 1 - #define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION #define CONFIGURE_RTEMS_INIT_TASKS_TABLE diff --git a/testsuites/psxtests/psxbarrier01/psxbarrier01.scn b/testsuites/psxtests/psxbarrier01/psxbarrier01.scn index d568d8d03e..c7ef3fd245 100644 --- a/testsuites/psxtests/psxbarrier01/psxbarrier01.scn +++ b/testsuites/psxtests/psxbarrier01/psxbarrier01.scn @@ -23,14 +23,11 @@ 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 pthread_barrierattr_destroy( &attr ) -- OK pthread_barrier_destroy( NULL ) -- EINVAL -pthread_barrier_destroy( &bad_barrier ) -- EINVAL +pthread_barrier_destroy( bad_barrier ) -- EINVAL pthread_barrier_wait( NULL ) -- EINVAL -pthread_barrier_wait( &bad_barrier ) -- EINVAL +pthread_barrier_wait( bad_barrier ) -- EINVAL pthread_barrierattr_init( &attr ) -- OK pthread_barrier_init( &barrier, &attr, 2 ) -- OK pthread_barrier_destroy( &barrier ) -- OK diff --git a/testsuites/psxtests/psxbarrier01/test.c b/testsuites/psxtests/psxbarrier01/test.c index 16e8665b94..4253b21057 100644 --- a/testsuites/psxtests/psxbarrier01/test.c +++ b/testsuites/psxtests/psxbarrier01/test.c @@ -4,6 +4,8 @@ * COPYRIGHT (c) 1989-2009. * On-Line Applications Research Corporation (OAR). * + * Copyright (c) 2017 embedded brains GmbH + * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at * http://www.rtems.org/license/LICENSE. @@ -16,6 +18,7 @@ #include #include #include +#include /* #define __USE_XOPEN2K XXX already defined on GNU/Linux */ #include @@ -24,6 +27,55 @@ const char rtems_test_name[] = "PSXBARRIER 1"; +static void test_barrier_null( void ) +{ + int eno; + + eno = pthread_barrier_init( NULL, NULL, 1 ); + rtems_test_assert( eno == EINVAL ); + + eno = pthread_barrier_wait( NULL ); + rtems_test_assert( eno == EINVAL ); + + eno = pthread_barrier_destroy( NULL ); + rtems_test_assert( eno == EINVAL ); +} + +static void test_barrier_not_initialized( void ) +{ + pthread_barrier_t bar; + int eno; + + memset( &bar, 0xff, sizeof( bar ) ); + + eno = pthread_barrier_wait(& bar) ; + rtems_test_assert( eno == EINVAL ); + + eno = pthread_barrier_destroy( &bar ); + rtems_test_assert( eno == EINVAL ); +} + +static void test_barrier_invalid_copy( void ) +{ + pthread_barrier_t bar; + pthread_barrier_t bar2; + int eno; + + eno = pthread_barrier_init( &bar, NULL, 1 ); + rtems_test_assert( eno == 0 ); + + memcpy( &bar2, &bar, sizeof( bar2 ) ); + + eno = pthread_barrier_wait( &bar2 ); + rtems_test_assert( eno == EINVAL ); + + eno = pthread_barrier_destroy( &bar2 ); + rtems_test_assert( eno == EINVAL ); + + eno = pthread_barrier_destroy( &bar ); + rtems_test_assert( eno == 0 ); +} + #define NUMBER_THREADS 2 pthread_t ThreadIds[NUMBER_THREADS]; pthread_barrier_t Barrier; @@ -57,7 +109,7 @@ int main( ) #endif { - pthread_barrier_t bad_barrier = 100; + pthread_barrier_t *bad_barrier = NULL; pthread_barrier_t barrier; pthread_barrierattr_t attr; int status; @@ -178,20 +230,6 @@ int main( 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 ); - rtems_test_assert( status == 0 ); - - puts( "pthread_barrier_init( &barrier, NULL, 1 ) -- EAGAIN" ); - status = pthread_barrier_init( &barrier, NULL, 1 ); - rtems_test_assert( status == EAGAIN ); - - /* clean up */ - puts( "pthread_barrier_destroy( &barrier ) -- OK" ); - status = pthread_barrier_destroy( &barrier ); - rtems_test_assert( status == 0 ); - puts( "pthread_barrierattr_destroy( &attr ) -- OK" ); status = pthread_barrierattr_destroy( &attr ); rtems_test_assert( status == 0 ); @@ -202,8 +240,8 @@ int main( status = pthread_barrier_destroy( NULL ); rtems_test_assert( status == EINVAL ); - puts( "pthread_barrier_destroy( &bad_barrier ) -- EINVAL" ); - status = pthread_barrier_destroy( &bad_barrier ); + puts( "pthread_barrier_destroy( bad_barrier ) -- EINVAL" ); + status = pthread_barrier_destroy( bad_barrier ); rtems_test_assert( status == EINVAL ); /*************** pthread_barrier_wait ERROR CHECKs *********/ @@ -212,8 +250,8 @@ int main( status = pthread_barrier_wait( NULL ); rtems_test_assert( status == EINVAL ); - puts( "pthread_barrier_wait( &bad_barrier ) -- EINVAL" ); - status = pthread_barrier_wait( &bad_barrier ); + puts( "pthread_barrier_wait( bad_barrier ) -- EINVAL" ); + status = pthread_barrier_wait( bad_barrier ); rtems_test_assert( status == EINVAL ); /*************** ACTUALLY CREATE ONE CHECK *****************/ @@ -224,7 +262,6 @@ int main( puts( "pthread_barrier_init( &barrier, &attr, 2 ) -- OK" ); status = pthread_barrier_init( &barrier, &attr, 2 ); rtems_test_assert( status == 0 ); - rtems_test_assert( barrier != 0 ); puts( "pthread_barrier_destroy( &barrier ) -- OK" ); status = pthread_barrier_destroy( &barrier ); @@ -234,7 +271,6 @@ int main( puts( "pthread_barrier_init( &Barrier, &attr, NUMBER_THREADS ) -- OK" ); status = pthread_barrier_init( &Barrier, &attr, NUMBER_THREADS ); rtems_test_assert( status == 0 ); - rtems_test_assert( barrier != 0 ); for (i=0 ; i