diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2017-09-21 14:13:16 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2017-10-05 14:29:01 +0200 |
commit | e67929c4c0025ef46053523be4c8736dd178cbec (patch) | |
tree | 09fca2c6ff8369031b9e76d97872da12236e155a /testsuites/psxtests/psxbarrier01 | |
parent | posix: Implement self-contained POSIX semaphores (diff) | |
download | rtems-e67929c4c0025ef46053523be4c8736dd178cbec.tar.bz2 |
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.
Diffstat (limited to 'testsuites/psxtests/psxbarrier01')
-rw-r--r-- | testsuites/psxtests/psxbarrier01/main.c | 2 | ||||
-rw-r--r-- | testsuites/psxtests/psxbarrier01/psxbarrier01.scn | 7 | ||||
-rw-r--r-- | testsuites/psxtests/psxbarrier01/test.c | 82 |
3 files changed, 63 insertions, 28 deletions
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 <stdio.h> #include <errno.h> #include <stdlib.h> +#include <string.h> /* #define __USE_XOPEN2K XXX already defined on GNU/Linux */ #include <pthread.h> @@ -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<NUMBER_THREADS ; i++ ) { @@ -253,6 +289,10 @@ int main( sleep(1); } + test_barrier_null(); + test_barrier_not_initialized(); + test_barrier_invalid_copy(); + /*************** END OF TEST *****************/ TEST_END(); exit(0); |