diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2014-04-08 11:14:27 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2014-04-15 08:37:12 +0200 |
commit | 0712d172d0bce40f3a9190af511249256ddac5f1 (patch) | |
tree | edfe262b0e46134e3704641cac50ff9d147e9e2a /cpukit/score/src | |
parent | score: Simplify thread control initialization (diff) | |
download | rtems-0712d172d0bce40f3a9190af511249256ddac5f1.tar.bz2 |
score: Task get/set affinity
Make rtems_task_get_affinity() and rtems_task_set_affinity() available
on non-SMP configurations. Allow larger CPU sets.
Diffstat (limited to 'cpukit/score/src')
-rw-r--r-- | cpukit/score/src/schedulerdefaultgetaffinity.c | 20 | ||||
-rw-r--r-- | cpukit/score/src/schedulerdefaultsetaffinity.c | 11 | ||||
-rw-r--r-- | cpukit/score/src/schedulergetaffinity.c | 55 | ||||
-rw-r--r-- | cpukit/score/src/schedulersetaffinity.c | 55 |
4 files changed, 122 insertions, 19 deletions
diff --git a/cpukit/score/src/schedulerdefaultgetaffinity.c b/cpukit/score/src/schedulerdefaultgetaffinity.c index 367fc25293..56a4ee4fad 100644 --- a/cpukit/score/src/schedulerdefaultgetaffinity.c +++ b/cpukit/score/src/schedulerdefaultgetaffinity.c @@ -20,7 +20,6 @@ #endif #include <rtems/score/schedulerimpl.h> -#include <rtems/score/cpusetimpl.h> bool _Scheduler_default_Get_affinity( const Scheduler_Control *scheduler, @@ -29,17 +28,10 @@ bool _Scheduler_default_Get_affinity( cpu_set_t *cpuset ) { - const CPU_set_Control *ctl; - - (void) scheduler; - (void) thread; - - ctl = _CPU_set_Default(); - if ( cpusetsize != ctl->setsize ) { - return false; - } - - CPU_COPY( cpuset, ctl->set ); - - return true; + return _Scheduler_default_Get_affinity_body( + scheduler, + thread, + cpusetsize, + cpuset + ); } diff --git a/cpukit/score/src/schedulerdefaultsetaffinity.c b/cpukit/score/src/schedulerdefaultsetaffinity.c index 33be12b286..e53f8b8349 100644 --- a/cpukit/score/src/schedulerdefaultsetaffinity.c +++ b/cpukit/score/src/schedulerdefaultsetaffinity.c @@ -20,7 +20,6 @@ #endif #include <rtems/score/schedulerimpl.h> -#include <rtems/score/cpusetimpl.h> bool _Scheduler_default_Set_affinity( const Scheduler_Control *scheduler, @@ -29,8 +28,10 @@ bool _Scheduler_default_Set_affinity( const cpu_set_t *cpuset ) { - (void) scheduler; - (void) thread; - - return _CPU_set_Is_valid( cpuset, cpusetsize ); + return _Scheduler_default_Set_affinity_body( + scheduler, + thread, + cpusetsize, + cpuset + ); } diff --git a/cpukit/score/src/schedulergetaffinity.c b/cpukit/score/src/schedulergetaffinity.c new file mode 100644 index 0000000000..d9e62b5650 --- /dev/null +++ b/cpukit/score/src/schedulergetaffinity.c @@ -0,0 +1,55 @@ +/* + * Copyright (c) 2014 embedded brains GmbH. All rights reserved. + * + * embedded brains GmbH + * Dornierstr. 4 + * 82178 Puchheim + * Germany + * <rtems@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 <rtems/score/schedulerimpl.h> + +#if defined(__RTEMS_HAVE_SYS_CPUSET_H__) + +bool _Scheduler_Get_affinity( + const Scheduler_Control *scheduler, + Thread_Control *the_thread, + size_t cpusetsize, + cpu_set_t *cpuset +) +{ + bool ok; + + if ( _CPU_set_Is_large_enough( cpusetsize ) ) { +#if defined(RTEMS_SMP) + ok = ( *scheduler->Operations.get_affinity )( + scheduler, + the_thread, + cpusetsize, + cpuset + ); +#else + ok = _Scheduler_default_Get_affinity_body( + scheduler, + the_thread, + cpusetsize, + cpuset + ); +#endif + } else { + ok = false; + } + + return ok; +} + +#endif /* defined(__RTEMS_HAVE_SYS_CPUSET_H__) */ diff --git a/cpukit/score/src/schedulersetaffinity.c b/cpukit/score/src/schedulersetaffinity.c new file mode 100644 index 0000000000..2416a195c5 --- /dev/null +++ b/cpukit/score/src/schedulersetaffinity.c @@ -0,0 +1,55 @@ +/* + * Copyright (c) 2014 embedded brains GmbH. All rights reserved. + * + * embedded brains GmbH + * Dornierstr. 4 + * 82178 Puchheim + * Germany + * <rtems@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 <rtems/score/schedulerimpl.h> + +#if defined(__RTEMS_HAVE_SYS_CPUSET_H__) + +bool _Scheduler_Set_affinity( + const Scheduler_Control *scheduler, + Thread_Control *the_thread, + size_t cpusetsize, + const cpu_set_t *cpuset +) +{ + bool ok; + + if ( _CPU_set_Is_large_enough( cpusetsize ) ) { +#if defined(RTEMS_SMP) + ok = ( *scheduler->Operations.set_affinity )( + scheduler, + the_thread, + cpusetsize, + cpuset + ); +#else + ok = _Scheduler_default_Set_affinity_body( + scheduler, + the_thread, + cpusetsize, + cpuset + ); +#endif + } else { + ok = false; + } + + return ok; +} + +#endif /* defined(__RTEMS_HAVE_SYS_CPUSET_H__) */ |