[PATCH 8/8] score: Add scheduler <sys/lock.h> support
Sebastian Huber
sebastian.huber at embedded-brains.de
Thu Jul 23 12:54:48 UTC 2015
---
cpukit/score/Makefile.am | 1 +
cpukit/score/src/sched.c | 70 ++++++++++++++++++++++++++
testsuites/sptests/spsyslock01/init.c | 17 +++++++
testsuites/sptests/spsyslock01/spsyslock01.doc | 5 ++
4 files changed, 93 insertions(+)
create mode 100644 cpukit/score/src/sched.c
diff --git a/cpukit/score/Makefile.am b/cpukit/score/Makefile.am
index 6f0c4db..5c35611 100644
--- a/cpukit/score/Makefile.am
+++ b/cpukit/score/Makefile.am
@@ -349,6 +349,7 @@ libscore_a_SOURCES += src/profilingisrentryexit.c
libscore_a_SOURCES += src/mutex.c
libscore_a_SOURCES += src/once.c
libscore_a_SOURCES += src/resourceiterate.c
+libscore_a_SOURCES += src/sched.c
libscore_a_SOURCES += src/semaphore.c
libscore_a_SOURCES += src/smpbarrierwait.c
libscore_a_SOURCES += src/kern_tc.c
diff --git a/cpukit/score/src/sched.c b/cpukit/score/src/sched.c
new file mode 100644
index 0000000..e694564
--- /dev/null
+++ b/cpukit/score/src/sched.c
@@ -0,0 +1,70 @@
+/*
+ * Copyright (c) 2015 embedded brains GmbH. All rights reserved.
+ *
+ * embedded brains GmbH
+ * Dornierstr. 4
+ * 82178 Puchheim
+ * Germany
+ * <rtems at embedded-brains.de>
+ *
+ * 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.
+ */
+
+#if HAVE_CONFIG_H
+ #include "config.h"
+#endif
+
+#include <sys/lock.h>
+
+#include <rtems/score/schedulerimpl.h>
+
+#if HAVE_STRUCT__THREAD_QUEUE_QUEUE
+
+int _Sched_Count( void )
+{
+ return (int) _Scheduler_Count;
+}
+
+int _Sched_Index( void )
+{
+ Thread_Control *executing = _Thread_Get_executing();
+
+ return (int) _Scheduler_Get_index( _Scheduler_Get( executing ) );
+}
+
+int _Sched_Name_to_index( const char *name, size_t len )
+{
+ uint32_t name_32 = 0;
+ size_t i = 0;
+
+ while ( i < 4 && i < len ) {
+ name_32 |= ( (uint32_t) ( (uint8_t) *name ) ) << ( ( 3 - i ) * 8 );
+ ++name;
+ ++i;
+ }
+
+ for ( i = 0 ; i < _Scheduler_Count ; ++i ) {
+ const Scheduler_Control *scheduler = &_Scheduler_Table[ i ];
+
+ if ( scheduler->name == name_32 ) {
+ return (int) i;
+ }
+ }
+
+ return -1;
+}
+
+int _Sched_Processor_count( int index )
+{
+ size_t i = (size_t) index;
+
+ if ( i < _Scheduler_Count ) {
+ return _Scheduler_Get_processor_count( &_Scheduler_Table[ i ] );
+ } else {
+ return 0;
+ }
+}
+
+#endif /* HAVE_STRUCT__THREAD_QUEUE_QUEUE */
diff --git a/testsuites/sptests/spsyslock01/init.c b/testsuites/sptests/spsyslock01/init.c
index 57f6d35..1309847 100644
--- a/testsuites/sptests/spsyslock01/init.c
+++ b/testsuites/sptests/spsyslock01/init.c
@@ -209,6 +209,20 @@ static void test_futex(test_context *ctx)
rtems_test_assert(ctx->eno == 0);
}
+static void test_sched(void)
+{
+ rtems_test_assert(_Sched_Index() == 0);
+ rtems_test_assert(_Sched_Name_to_index("", 0) == -1);
+ rtems_test_assert(_Sched_Name_to_index("b", 1) == -1);
+ rtems_test_assert(_Sched_Name_to_index("bl", 2) == -1);
+ rtems_test_assert(_Sched_Name_to_index("blu", 3) == -1);
+ rtems_test_assert(_Sched_Name_to_index("blue", 4) == 0);
+ rtems_test_assert(_Sched_Name_to_index("blueX", 5) == 0);
+ rtems_test_assert(_Sched_Processor_count(-1) == 0);
+ rtems_test_assert(_Sched_Processor_count(0) == 1);
+ rtems_test_assert(_Sched_Processor_count(1) == 0);
+}
+
static void mid_task(rtems_task_argument arg)
{
rtems_test_assert(0);
@@ -332,6 +346,7 @@ static void test(void)
test_prio_inv_recursive(ctx);
test_sem(ctx);
test_futex(ctx);
+ test_sched();
send_events(ctx, EVENT_MTX_DEADLOCK);
@@ -363,6 +378,8 @@ static void Init(rtems_task_argument arg)
#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
+#define CONFIGURE_SCHEDULER_NAME rtems_build_name('b', 'l', 'u', 'e')
+
#define CONFIGURE_INIT
#include <rtems/confdefs.h>
diff --git a/testsuites/sptests/spsyslock01/spsyslock01.doc b/testsuites/sptests/spsyslock01/spsyslock01.doc
index bf59ceb..c8ab182 100644
--- a/testsuites/sptests/spsyslock01/spsyslock01.doc
+++ b/testsuites/sptests/spsyslock01/spsyslock01.doc
@@ -22,9 +22,14 @@ directives:
- _Futex_Wait()
- _Futex_Wake()
- _Futex_Destroy()
+ - _Sched_Count()
+ - _Sched_Index()
+ - _Sched_Name_to_index()
+ - _Sched_Processor_count()
concepts:
- Ensure that self-contained mutexes and recursive mutexes work.
- Ensure that self-contained semaphores work.
- Ensure that self-contained futexes work.
+ - Ensure that <sys/lock.h> scheduler support works.
--
1.8.4.5
More information about the devel
mailing list