From edae517758338c5d6103cde6ca1ad85d1bf551fd Mon Sep 17 00:00:00 2001 From: Himanshu40 Date: Tue, 20 Nov 2018 06:41:58 +0530 Subject: psxtmutexattr01: Added new POSIX timing suite (GCI 2018) --- testsuites/psxtmtests/Makefile.am | 11 + testsuites/psxtmtests/configure.ac | 1 + testsuites/psxtmtests/psxtmmutexattr01/init.c | 277 +++++++++++++++++++++ .../psxtmmutexattr01/psxtmmutexattr01.doc | 27 ++ testsuites/psxtmtests/psxtmtests_plan.csv | 11 + 5 files changed, 327 insertions(+) create mode 100644 testsuites/psxtmtests/psxtmmutexattr01/init.c create mode 100644 testsuites/psxtmtests/psxtmmutexattr01/psxtmmutexattr01.doc diff --git a/testsuites/psxtmtests/Makefile.am b/testsuites/psxtmtests/Makefile.am index 1101a5b447..920ff6e081 100644 --- a/testsuites/psxtmtests/Makefile.am +++ b/testsuites/psxtmtests/Makefile.am @@ -326,6 +326,17 @@ psxtmmutex07_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_FLAGS_psxtmmutex07) \ -DOPERATION_COUNT=$(OPERATION_COUNT) endif +if TEST_psxtmmutexattr01 +psxtm_tests += psxtmmutexattr01 +psxtm_docs += psxtmmutexattr01/psxtmmutexattr01.doc +psxtmmutexattr01_SOURCES = psxtmmutexattr01/init.c \ + ../tmtests/include/timesys.h ../support/src/tmtests_empty_function.c \ + ../support/src/tmtests_support.c +psxtmmutexattr01_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_FLAGS_psxtmmutexattr01) \ + $(support_includes) -I$(top_srcdir)/../tmtests/include \ + -DOPERATION_COUNT=$(OPERATION_COUNT) +endif + if TEST_psxtmnanosleep01 psxtm_tests += psxtmnanosleep01 psxtm_docs += psxtmnanosleep01/psxtmnanosleep01.doc diff --git a/testsuites/psxtmtests/configure.ac b/testsuites/psxtmtests/configure.ac index eff7067959..a8312fc951 100644 --- a/testsuites/psxtmtests/configure.ac +++ b/testsuites/psxtmtests/configure.ac @@ -58,6 +58,7 @@ RTEMS_TEST_CHECK([psxtmmutex04]) RTEMS_TEST_CHECK([psxtmmutex05]) RTEMS_TEST_CHECK([psxtmmutex06]) RTEMS_TEST_CHECK([psxtmmutex07]) +RTEMS_TEST_CHECK([psxtmmutexattr01]) RTEMS_TEST_CHECK([psxtmnanosleep01]) RTEMS_TEST_CHECK([psxtmnanosleep02]) RTEMS_TEST_CHECK([psxtmonce01]) diff --git a/testsuites/psxtmtests/psxtmmutexattr01/init.c b/testsuites/psxtmtests/psxtmmutexattr01/init.c new file mode 100644 index 0000000000..6998c16d59 --- /dev/null +++ b/testsuites/psxtmtests/psxtmmutexattr01/init.c @@ -0,0 +1,277 @@ +/* + * COPYRIGHT (c) 2018. + * Himanshu Sekhar Nayak( GCI 2018 ) + * + * Permission to use, copy, modify, and/or distribute this software + * for any purpose with or without fee is hereby granted. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL + * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR + * BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES + * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, + * WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, + * ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include +#include +#include +#include +#include +#include "test_support.h" + +const char rtems_test_name[] = "PSXTMMUTEXATTR01"; + +/* forward declarations to avoid warnings */ +static void *POSIX_Init(void *argument); + +static pthread_mutexattr_t attr; + +static void benchmark_create_pthread_mutexattr(void) +{ + long end_time; + int status; + + benchmark_timer_initialize(); + status = pthread_mutexattr_init( &attr ); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + + put_time( + "pthread_mutexattr_init: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_pthread_mutexattr_setprioceiling(void) +{ + long end_time; + int status; + + benchmark_timer_initialize(); + status = pthread_mutexattr_setprioceiling( &attr, SCHED_FIFO); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + + put_time( + "pthread_mutexattr_setprioceiling: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_pthread_mutexattr_getprioceiling(void) +{ + long end_time; + int status; + int prioceiling; + + benchmark_timer_initialize(); + status = pthread_mutexattr_getprioceiling( &attr, &prioceiling); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + rtems_test_assert( prioceiling == SCHED_FIFO); + + put_time( + "pthread_mutexattr_getprioceiling: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_pthread_mutexattr_setprotocol(void) +{ + long end_time; + int status; + + benchmark_timer_initialize(); + status = pthread_mutexattr_setprotocol( &attr, PTHREAD_PRIO_INHERIT ); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + + put_time( + "pthread_mutexattr_setprotocol: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_pthread_mutexattr_getprotocol(void) +{ + long end_time; + int status; + int protocol; + + benchmark_timer_initialize(); + status = pthread_mutexattr_getprotocol( &attr, &protocol ); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + rtems_test_assert( protocol == PTHREAD_PRIO_INHERIT ); + + put_time( + "pthread_mutexattr_getprotocol: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_pthread_mutexattr_setpshared(void) +{ + long end_time; + int status; + + benchmark_timer_initialize(); + status = pthread_mutexattr_setpshared( &attr, PTHREAD_PROCESS_PRIVATE ); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + + put_time( + "pthread_mutexattr_setpshared: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_pthread_mutexattr_getpshared(void) +{ + long end_time; + int status; + int pshared; + + benchmark_timer_initialize(); + status = pthread_mutexattr_getpshared( &attr, &pshared ); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + rtems_test_assert( pshared == PTHREAD_PROCESS_PRIVATE ); + + put_time( + "pthread_mutexattr_getpshared: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_pthread_mutexattr_settype(void) +{ + long end_time; + int status; + + benchmark_timer_initialize(); + status = pthread_mutexattr_settype( &attr, PTHREAD_MUTEX_DEFAULT ); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + + put_time( + "pthread_mutexattr_settype: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_pthread_mutexattr_gettype(void) +{ + long end_time; + int status; + int type; + + benchmark_timer_initialize(); + status = pthread_mutexattr_gettype( &attr, &type ); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + rtems_test_assert( type == PTHREAD_MUTEX_DEFAULT ); + + put_time( + "pthread_mutexattr_gettype: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +static void benchmark_destroy_pthread_mutexattr(void) +{ + long end_time; + int status; + + benchmark_timer_initialize(); + status = pthread_mutexattr_destroy( &attr ); + end_time = benchmark_timer_read(); + rtems_test_assert( status == 0 ); + + put_time( + "pthread_mutexattr_destroy: only case", + end_time, + 1, /* Only executed once */ + 0, + 0 + ); + +} + +void *POSIX_Init( + void *argument +) +{ + + TEST_BEGIN(); + + benchmark_create_pthread_mutexattr(); + benchmark_pthread_mutexattr_setprioceiling(); + benchmark_pthread_mutexattr_getprioceiling(); + benchmark_pthread_mutexattr_setprotocol(); + benchmark_pthread_mutexattr_getprotocol(); + benchmark_pthread_mutexattr_setpshared(); + benchmark_pthread_mutexattr_getpshared(); + benchmark_pthread_mutexattr_settype(); + benchmark_pthread_mutexattr_gettype(); + benchmark_destroy_pthread_mutexattr(); + + TEST_END(); + rtems_test_exit(0); +} + +/* configuration information */ + +#define CONFIGURE_APPLICATION_NEEDS_SIMPLE_CONSOLE_DRIVER +#define CONFIGURE_APPLICATION_NEEDS_TIMER_DRIVER + + +#define CONFIGURE_MAXIMUM_POSIX_THREADS 1 +#define CONFIGURE_POSIX_INIT_THREAD_TABLE + +#define CONFIGURE_INIT + +#include +/* end of file */ diff --git a/testsuites/psxtmtests/psxtmmutexattr01/psxtmmutexattr01.doc b/testsuites/psxtmtests/psxtmmutexattr01/psxtmmutexattr01.doc new file mode 100644 index 0000000000..9bde3369e7 --- /dev/null +++ b/testsuites/psxtmtests/psxtmmutexattr01/psxtmmutexattr01.doc @@ -0,0 +1,27 @@ +# COPYRIGHT (c) 2018. +# Himanshu Sekhar Nayak( GCI 2018 ) +# +# Permission to use, copy, modify, and/or distribute this software +# for any purpose with or without fee is hereby granted. +# +# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL +# WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED +# WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR +# BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES +# OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, +# WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, +# ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. +# + +This test benchmarks the following operations: + ++ pthread_mutexattr_init: only case ++ pthread_mutexattr_setprioceiling: only case ++ pthread_mutexattr_getprioceiling: only case ++ pthread_mutexattr_setprotocol: only case ++ pthread_mutexattr_getprotocol: only case ++ pthread_mutexattr_setpshared: only case ++ pthread_mutexattr_getpshared: only case ++ pthread_mutexattr_settype: only case ++ pthread_mutexattr_gettype: only case ++ pthread_mutexattr_destroy: only case diff --git a/testsuites/psxtmtests/psxtmtests_plan.csv b/testsuites/psxtmtests/psxtmtests_plan.csv index 6a1f4900e9..e4425f9894 100644 --- a/testsuites/psxtmtests/psxtmtests_plan.csv +++ b/testsuites/psxtmtests/psxtmtests_plan.csv @@ -13,6 +13,17 @@ "pthread_mutex_setprioceiling","psxtmmutex07","psxtmtest_single","Yes" "pthread_mutex_getprioceiling","psxtmmutex07","psxtmtest_single","Yes" +"pthread_mutexattr_init: only case","psxtmmutexattr01","psxtmtest_init_destroy","Yes" +"pthread_mutexattr_destroy: only case","psxtmmutexattr01","psxtmtest_init_destroy","Yes" +"pthread_mutexattr_getprioceiling: only case","psxtmmutexattr01","psxtmtest_single","Yes" +"pthread_mutexattr_getprotocol: only case","psxtmmutexattr01","psxtmtest_single","Yes" +"pthread_mutexattr_getpshared: only case","psxtmmutexattr01","psxtmtest_single","Yes" +"pthread_mutexattr_gettype: only case","psxtmmutexattr01","psxtmtest_single","Yes" +"pthread_mutexattr_setprioceiling: only case","psxtmmutexattr01","psxtmtest_single","Yes" +"pthread_mutexattr_setprotocol: only case","psxtmmutexattr01","psxtmtest_single","Yes" +"pthread_mutexattr_setpshared: only case","psxtmmutexattr01","psxtmtest_single","Yes" +"pthread_mutexattr_settype: only case","psxtmmutexattr01","psxtmtest_single","Yes" + "pthread_cond_init: only case","psxtmcond01","psxtmtest_init_destroy","Yes" "pthread_cond_destroy: only case","psxtmcond01","psxtmtest_init_destroy","Yes" "pthread_cond_signal: no threads waiting","psxtmcond02","psxtmtest_single","Yes" -- cgit v1.2.3