summaryrefslogtreecommitdiffstats
path: root/testsuites/psxtmtests/psxtmthread06
diff options
context:
space:
mode:
authorDaniel Ramirez <javamonn@gmail.com>2013-11-27 17:56:53 -0600
committerGedare Bloom <gedare@rtems.org>2013-11-27 20:50:10 -0500
commite9a1c991fed671cb7b22f059d6ca72693558ef44 (patch)
treeb17bab1710568af9e7acecd23e3e59c32e275dab /testsuites/psxtmtests/psxtmthread06
parentadd --enable-paravirt to the configure options (diff)
downloadrtems-e9a1c991fed671cb7b22f059d6ca72693558ef44.tar.bz2
psxtmtests: copy psxtmthread05 to psxtmthread06, fix psxtmthread05
The psxtmthread05 test was testing the functionality meant for psxtmthread06. This patch copies the psxtmthread05 to psxtmthread06 and modifies psxtmthread05 to test the intended functionality.
Diffstat (limited to 'testsuites/psxtmtests/psxtmthread06')
-rw-r--r--testsuites/psxtmtests/psxtmthread06/Makefile.am27
-rw-r--r--testsuites/psxtmtests/psxtmthread06/init.c98
-rw-r--r--testsuites/psxtmtests/psxtmthread06/psxtmthread06.doc26
3 files changed, 151 insertions, 0 deletions
diff --git a/testsuites/psxtmtests/psxtmthread06/Makefile.am b/testsuites/psxtmtests/psxtmthread06/Makefile.am
new file mode 100644
index 0000000000..b5d3f73288
--- /dev/null
+++ b/testsuites/psxtmtests/psxtmthread06/Makefile.am
@@ -0,0 +1,27 @@
+MANAGERS = all
+
+rtems_tests_PROGRAMS = psxtmthread06
+psxtmthread06_SOURCES = init.c
+psxtmthread06_SOURCES += ../../tmtests/include/timesys.h
+psxtmthread06_SOURCES += ../../support/src/tmtests_empty_function.c
+psxtmthread06_SOURCES += ../../support/src/tmtests_support.c
+
+dist_rtems_tests_DATA = psxtmthread06.doc
+
+include $(RTEMS_ROOT)/make/custom/@RTEMS_BSP@.cfg
+include $(top_srcdir)/../automake/compile.am
+include $(top_srcdir)/../automake/leaf.am
+
+OPERATION_COUNT = @OPERATION_COUNT@
+AM_CPPFLAGS += -I$(top_srcdir)/../tmtests/include
+AM_CPPFLAGS += -DOPERATION_COUNT=$(OPERATION_COUNT)
+AM_CPPFLAGS += -I$(top_srcdir)/../support/include
+
+LINK_OBJS = $(psxtmthread06_OBJECTS) $(psxtmthread06_LDADD)
+LINK_LIBS = $(psxtmthread06_LDLIBS)
+
+psxtmthread06$(EXEEXT): $(psxtmthread06_OBJECTS) $(psxtmthread06_DEPENDENCIES)
+ @rm -f psxtmthread06$(EXEEXT)
+ $(make-exe)
+
+include $(top_srcdir)/../automake/local.am
diff --git a/testsuites/psxtmtests/psxtmthread06/init.c b/testsuites/psxtmtests/psxtmthread06/init.c
new file mode 100644
index 0000000000..d224b29840
--- /dev/null
+++ b/testsuites/psxtmtests/psxtmthread06/init.c
@@ -0,0 +1,98 @@
+/*
+ * COPYRIGHT (c) 1989-2012.
+ * On-Line Applications Research Corporation (OAR).
+ * COPYRIGHT (c) 2013.
+ * Chirayu Desai (chirayudesai1@gmail.com).
+ *
+ * The license and distribution terms for this file may be
+ * found in the file LICENSE in this distribution or at
+ * http://www.rtems.com/license/LICENSE.
+ */
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include <timesys.h>
+#include <pthread.h>
+#include <sched.h>
+#include <rtems/timerdrv.h>
+#include "test_support.h"
+
+/* forward declarations to avoid warnings */
+void *POSIX_Init(void *argument);
+void benchmark_pthread_create(void);
+void benchmark_pthread_setschedparam(void);
+void *test_thread(void *argument);
+
+void benchmark_pthread_setschedparam(void)
+{
+ int status;
+ int policy;
+ struct sched_param param;
+ pthread_t thread_ID;
+
+ status = pthread_create(&thread_ID, NULL, test_thread, NULL);
+ rtems_test_assert( status == 0 );
+
+ /* make test_thread equal to POSIX_Init() */
+ pthread_getschedparam(pthread_self(), &policy, &param);
+ pthread_setschedparam(thread_ID, policy, &param);
+ /* At this point, we've switched to test_thread */
+
+ /* Back from test_thread, switch to test_thread again */
+ param.sched_priority = sched_get_priority_max(policy) - 1;
+
+ benchmark_timer_initialize();
+ pthread_setschedparam(thread_ID, policy, &param);
+}
+
+void *test_thread(
+ void *argument
+)
+{
+ long end_time;
+
+ /* switch to POSIX_Init */
+ sched_yield();
+
+ end_time = benchmark_timer_read();
+
+ put_time(
+ "pthread_setschedparam - raise other priority, preempt",
+ end_time,
+ 1, /* Only executed once */
+ 0,
+ 0
+ );
+
+ puts( "*** END OF POSIX TIME TEST PSXTMTHREAD06 ***" );
+ rtems_test_exit(0);
+ //Empty thread used in pthread_create().
+ return NULL;
+}
+
+void *POSIX_Init(
+ void *argument
+)
+{
+
+ puts( "\n\n*** POSIX TIME TEST PSXTMTHREAD06 ***" );
+ benchmark_pthread_setschedparam();
+
+ rtems_test_assert( 1 );
+ return NULL;
+}
+
+/* configuration information */
+
+#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
+#define CONFIGURE_APPLICATION_NEEDS_TIMER_DRIVER
+
+#define CONFIGURE_MAXIMUM_POSIX_THREADS 2
+#define CONFIGURE_POSIX_INIT_THREAD_TABLE
+
+#define CONFIGURE_INIT
+
+#include <rtems/confdefs.h>
+/* end of file */
diff --git a/testsuites/psxtmtests/psxtmthread06/psxtmthread06.doc b/testsuites/psxtmtests/psxtmthread06/psxtmthread06.doc
new file mode 100644
index 0000000000..269385601a
--- /dev/null
+++ b/testsuites/psxtmtests/psxtmthread06/psxtmthread06.doc
@@ -0,0 +1,26 @@
+# COPYRIGHT (c) 1989-2011.
+# On-Line Applications Research Corporation (OAR).
+# COPYRIGHT (c) 2013.
+# Chirayu Desai (chirayudesai1@gmail.com).
+#
+# The license and distribution terms for this file may be
+# found in the file LICENSE in this distribution or at
+# http://www.rtems.com/license/LICENSE.
+#
+
+This test benchmarks the following operations:
+
++ pthread_setschedparam - raise other priority, preempt
+
+This file describes the directives and concepts tested by this test set.
+
+test set name: psxtmthread
+
+directives:
++ pthread_create
++ pthread_getschedparam
++ pthread_setschedparam
+
+concepts:
++ Benchmark the call pthread_setschedparam for raising another thread's
+ priority and the resulting context switch.