From 183b0ae48832b416ca81a22603cfb0a6d9b796ed Mon Sep 17 00:00:00 2001 From: Himanshu40 Date: Sun, 25 Nov 2018 09:49:30 -0600 Subject: psxtmtests: add psxtmmqrcvblock02 (GCI 2018) --- testsuites/psxtmtests/Makefile.am | 11 ++ testsuites/psxtmtests/configure.ac | 1 + testsuites/psxtmtests/psxtmmqrcvblock02/init.c | 134 +++++++++++++++++++++ .../psxtmmqrcvblock02/psxtmmqrcvblock02.doc | 18 +++ testsuites/psxtmtests/psxtmtests_plan.csv | 2 +- 5 files changed, 165 insertions(+), 1 deletion(-) create mode 100644 testsuites/psxtmtests/psxtmmqrcvblock02/init.c create mode 100644 testsuites/psxtmtests/psxtmmqrcvblock02/psxtmmqrcvblock02.doc diff --git a/testsuites/psxtmtests/Makefile.am b/testsuites/psxtmtests/Makefile.am index d87921d133..2702e0b035 100644 --- a/testsuites/psxtmtests/Makefile.am +++ b/testsuites/psxtmtests/Makefile.am @@ -471,6 +471,17 @@ psxtmmqrcvblock01_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_FLAGS_psxtmmqrcvblock01) \ -DOPERATION_COUNT=$(OPERATION_COUNT) endif +if TEST_psxtmmqrcvblock02 +psxtm_tests += psxtmmqrcvblock02 +psxtm_docs += psxtmmqrcvblock02/psxtmmqrcvblock02.doc +psxtmmqrcvblock02_SOURCES = psxtmmqrcvblock02/init.c \ + ../tmtests/include/timesys.h ../support/src/tmtests_empty_function.c \ + ../support/src/tmtests_support.c +psxtmmqrcvblock02_CPPFLAGS = $(AM_CPPFLAGS) $(TEST_FLAGS_psxtmmqrcvblock02) \ + $(support_includes) -I$(top_srcdir)/../tmtests/include \ + -DOPERATION_COUNT=$(OPERATION_COUNT) +endif + if TEST_psxtmsem01 psxtm_tests += psxtmsem01 psxtm_docs += psxtmsem01/psxtmsem01.doc diff --git a/testsuites/psxtmtests/configure.ac b/testsuites/psxtmtests/configure.ac index 5cfad14894..857a8bac3c 100644 --- a/testsuites/psxtmtests/configure.ac +++ b/testsuites/psxtmtests/configure.ac @@ -71,6 +71,7 @@ RTEMS_TEST_CHECK([psxtmrwlock05]) RTEMS_TEST_CHECK([psxtmrwlock06]) RTEMS_TEST_CHECK([psxtmrwlock07]) RTEMS_TEST_CHECK([psxtmmqrcvblock01]) +RTEMS_TEST_CHECK([psxtmmqrcvblock02]) RTEMS_TEST_CHECK([psxtmsem01]) RTEMS_TEST_CHECK([psxtmsem02]) RTEMS_TEST_CHECK([psxtmsem03]) diff --git a/testsuites/psxtmtests/psxtmmqrcvblock02/init.c b/testsuites/psxtmtests/psxtmmqrcvblock02/init.c new file mode 100644 index 0000000000..c718c38015 --- /dev/null +++ b/testsuites/psxtmtests/psxtmmqrcvblock02/init.c @@ -0,0 +1,134 @@ +/* + * COPYRIGHT (c) 2018. + * Himanshu Sekhar Nayak + * + * 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 "test_support.h" +#include +#include +#include +#include + +const char rtems_test_name[] = "PSXTMMQRCVBLOCK 02"; + +/* forward declarations to avoid warnings */ +void *POSIX_Init(void *argument); +void *Middle(void *argument); +void *Low(void *argument); + +#define MQ_MAXMSG 1 +#define MQ_MSGSIZE sizeof(int) + +static mqd_t queue; +int message[MQ_MAXMSG]; +const char *q_name; +unsigned int priority; +struct timespec timeout; + +void *POSIX_Init( + void *argument +) +{ + int i; + int status; + int oflag = O_CREAT |O_RDWR; + pthread_t threadId; + struct mq_attr attr; + + priority = 0; + timeout.tv_sec = 0; + timeout.tv_nsec = 0; + attr.mq_maxmsg = MQ_MAXMSG; + attr.mq_msgsize = MQ_MSGSIZE; + + TEST_BEGIN(); + + for ( i=0 ; i < OPERATION_COUNT - 1 ; i++ ) { + status = pthread_create( &threadId, NULL, Middle, NULL ); + rtems_test_assert( !status ); + } + + status = pthread_create( &threadId, NULL, Low, NULL ); + rtems_test_assert( !status ); + + queue = mq_open( "queue", oflag, 0x777, &attr ); + + /* let other threads run */ + sched_yield(); + + /* now run the benchmark */ + benchmark_timer_initialize(); + status = mq_timedreceive( + queue, (char *)message, MQ_MSGSIZE, &priority, &timeout); + return NULL; +} + +void *Middle( + void *argument +) +{ + sched_yield(); + + /* let other threads run */ + + (void) mq_timedreceive( + queue, (char *)message, MQ_MSGSIZE, &priority, &timeout); + + return NULL; +} + +void *Low( + void *argument +) +{ + benchmark_timer_t end_time; + + sched_yield(); + + end_time = benchmark_timer_read(); + + put_time( + "mq_timedreceive: not available: block", + end_time, + OPERATION_COUNT, + 0, + 0 + ); + + TEST_END(); + + rtems_test_exit( 0 ); + return NULL; +} + +/* configuration information */ + +#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER +#define CONFIGURE_APPLICATION_NEEDS_TIMER_DRIVER + +#define CONFIGURE_MAXIMUM_POSIX_THREADS OPERATION_COUNT + 2 +#define CONFIGURE_POSIX_INIT_THREAD_TABLE + +#define CONFIGURE_INIT + +#include + /* end of file */ diff --git a/testsuites/psxtmtests/psxtmmqrcvblock02/psxtmmqrcvblock02.doc b/testsuites/psxtmtests/psxtmmqrcvblock02/psxtmmqrcvblock02.doc new file mode 100644 index 0000000000..e4ee9d0499 --- /dev/null +++ b/testsuites/psxtmtests/psxtmmqrcvblock02/psxtmmqrcvblock02.doc @@ -0,0 +1,18 @@ +# COPYRIGHT (c) 2018. +# Himanshu Sekhar Nayak +# +# 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: + ++ mq_timedreceive: not available: blocks diff --git a/testsuites/psxtmtests/psxtmtests_plan.csv b/testsuites/psxtmtests/psxtmtests_plan.csv index 7fd1f113d4..06c6bbaa8e 100644 --- a/testsuites/psxtmtests/psxtmtests_plan.csv +++ b/testsuites/psxtmtests/psxtmtests_plan.csv @@ -128,7 +128,7 @@ "mq_unlink: only case","psxtmmq01","psxtmtest_init_destroy","Yes" "mq_receive: available",,"psxtmtest_single","Yes" "mq_receive: not available: block",,"psxtmtest_blocking","Yes" -"mq_timedreceive: available",,"psxtmtest_single","Yes" +"mq_timedreceive: not available: blocks","psxtmmqrcvblock02,"psxtmtest_blocking","Yes" "mq_timedreceive: not available: blocks",,"psxtmtest_single","No" "mq_send: no threads waiting",,"psxtmtest_single","Yes" "mq_send: thread waiting: no preempt",,"psxtmtest_unblocking_nopreempt","No" -- cgit v1.2.3