[rtems commit] psxtmtests: copy psxtmthread05 to psxtmthread06, fix psxtmthread05

Gedare Bloom gedare at rtems.org
Thu Nov 28 01:44:35 UTC 2013


Module:    rtems
Branch:    master
Commit:    e9a1c991fed671cb7b22f059d6ca72693558ef44
Changeset: http://git.rtems.org/rtems/commit/?id=e9a1c991fed671cb7b22f059d6ca72693558ef44

Author:    Daniel Ramirez <javamonn at gmail.com>
Date:      Wed Nov 27 17:56:53 2013 -0600

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.

---

 testsuites/psxtmtests/Makefile.am                  |    1 +
 testsuites/psxtmtests/configure.ac                 |    1 +
 testsuites/psxtmtests/psxtmtests_plan.csv          |    2 +-
 testsuites/psxtmtests/psxtmthread05/.cvsignore     |    2 +
 testsuites/psxtmtests/psxtmthread05/init.c         |   10 +-
 .../psxtmtests/psxtmthread05/psxtmthread05.doc     |    6 +-
 testsuites/psxtmtests/psxtmthread06/Makefile.am    |   27 ++++++
 testsuites/psxtmtests/psxtmthread06/init.c         |   98 ++++++++++++++++++++
 .../psxtmtests/psxtmthread06/psxtmthread06.doc     |   26 +++++
 9 files changed, 162 insertions(+), 11 deletions(-)

diff --git a/testsuites/psxtmtests/Makefile.am b/testsuites/psxtmtests/Makefile.am
index 812c3ad..86e2536 100644
--- a/testsuites/psxtmtests/Makefile.am
+++ b/testsuites/psxtmtests/Makefile.am
@@ -43,6 +43,7 @@ SUBDIRS += psxtmthread01
 SUBDIRS += psxtmthread02
 SUBDIRS += psxtmthread03
 SUBDIRS += psxtmthread05
+SUBDIRS += psxtmthread06
 endif
 
 DIST_SUBDIRS = $(SUBDIRS)
diff --git a/testsuites/psxtmtests/configure.ac b/testsuites/psxtmtests/configure.ac
index 0e70274..03aeb35 100644
--- a/testsuites/psxtmtests/configure.ac
+++ b/testsuites/psxtmtests/configure.ac
@@ -117,5 +117,6 @@ psxtmthread01/Makefile
 psxtmthread02/Makefile
 psxtmthread03/Makefile
 psxtmthread05/Makefile
+psxtmthread06/Makefile
 ])
 AC_OUTPUT
diff --git a/testsuites/psxtmtests/psxtmtests_plan.csv b/testsuites/psxtmtests/psxtmtests_plan.csv
index 1fce3cd..5bbadbb 100644
--- a/testsuites/psxtmtests/psxtmtests_plan.csv
+++ b/testsuites/psxtmtests/psxtmtests_plan.csv
@@ -36,7 +36,7 @@
 "pthread_getschedparam","psxtmthread04","psxtmtest_single w/multiple timings","No"
 "pthread_setschedparam - no thread switch","psxtmthread04","psxtmtest_single w/multiple timings","No"
 "pthread_setschedparam - lower own priority, preempt","psxtmthread05","psxtmtest_single","Yes"
-"pthread_setschedparam - raise other priority, preempt","psxtmthread06","psxtmtest_single","No"
+"pthread_setschedparam - raise other priority, preempt","psxtmthread06","psxtmtest_single","Yes"
 ,,,
 "pthread_once",,,
 ,,,
diff --git a/testsuites/psxtmtests/psxtmthread05/.cvsignore b/testsuites/psxtmtests/psxtmthread05/.cvsignore
new file mode 100644
index 0000000..282522d
--- /dev/null
+++ b/testsuites/psxtmtests/psxtmthread05/.cvsignore
@@ -0,0 +1,2 @@
+Makefile
+Makefile.in
diff --git a/testsuites/psxtmtests/psxtmthread05/init.c b/testsuites/psxtmtests/psxtmthread05/init.c
index 78f0465..11c84c5 100644
--- a/testsuites/psxtmtests/psxtmthread05/init.c
+++ b/testsuites/psxtmtests/psxtmthread05/init.c
@@ -2,7 +2,6 @@
  *  COPYRIGHT (c) 1989-2012.
  *  On-Line Applications Research Corporation (OAR).
  *  COPYRIGHT (c) 2013.
- *  Chirayu Desai (chirayudesai1 at gmail.com).
  *
  *  The license and distribution terms for this file may be
  *  found in the file LICENSE in this distribution or at
@@ -37,14 +36,16 @@ void benchmark_pthread_setschedparam(void)
 
   /* 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;
+  param.sched_priority = sched_get_priority_min(policy);
 
   benchmark_timer_initialize();
-  pthread_setschedparam(thread_ID, policy, &param);
+  //lower own priority to minimun, scheduler forces an involuntary context switch
+  pthread_setschedparam(pthread_self(), policy, &param);
 }
 
 void *test_thread(
@@ -52,12 +53,9 @@ void *test_thread(
 )
 {
   long end_time;
-
-  /* switch to POSIX_Init */
   sched_yield();
 
   end_time = benchmark_timer_read();
-
   put_time(
     "pthread_setschedparam - lower own priority, preempt",
     end_time,
diff --git a/testsuites/psxtmtests/psxtmthread05/psxtmthread05.doc b/testsuites/psxtmtests/psxtmthread05/psxtmthread05.doc
index 95724d0..dbbd7b4 100644
--- a/testsuites/psxtmtests/psxtmthread05/psxtmthread05.doc
+++ b/testsuites/psxtmtests/psxtmthread05/psxtmthread05.doc
@@ -1,7 +1,5 @@
 #  COPYRIGHT (c) 1989-2011.
 #  On-Line Applications Research Corporation (OAR).
-#  COPYRIGHT (c) 2013.
-#  Chirayu Desai (chirayudesai1 at gmail.com).
 #
 #  The license and distribution terms for this file may be
 #  found in the file LICENSE in this distribution or at
@@ -22,5 +20,5 @@ directives:
 + pthread_setschedparam
 
 concepts:
-
-+ Benchmark the call pthread_setschedparam while lowering the priority.
++ Benchmark the call pthread_setschedparam for lowering own priority and the
+  resulting involuntary context switch.
diff --git a/testsuites/psxtmtests/psxtmthread06/Makefile.am b/testsuites/psxtmtests/psxtmthread06/Makefile.am
new file mode 100644
index 0000000..b5d3f73
--- /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 at .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 0000000..d224b29
--- /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 at 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 0000000..2693856
--- /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 at 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.




More information about the vc mailing list