diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2016-11-08 06:39:07 +0100 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2016-11-09 15:27:29 +0100 |
commit | 68ef65bd5ebd1b2177f9defe5cde994e1466bfab (patch) | |
tree | 30ba66814377807be35df5279b2882932b2b4636 /cpukit/score/src/schedulersmpstartidle.c | |
parent | score: Add scheduler to per-CPU information (diff) | |
download | rtems-68ef65bd5ebd1b2177f9defe5cde994e1466bfab.tar.bz2 |
score: Clarify _Scheduler_SMP_Start_idle()
Diffstat (limited to 'cpukit/score/src/schedulersmpstartidle.c')
-rw-r--r-- | cpukit/score/src/schedulersmpstartidle.c | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/cpukit/score/src/schedulersmpstartidle.c b/cpukit/score/src/schedulersmpstartidle.c index 0ffb628550..c28a4c3f98 100644 --- a/cpukit/score/src/schedulersmpstartidle.c +++ b/cpukit/score/src/schedulersmpstartidle.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013-2014 embedded brains GmbH + * Copyright (c) 2013, 2016 embedded brains GmbH. * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at @@ -14,18 +14,22 @@ void _Scheduler_SMP_Start_idle( const Scheduler_Control *scheduler, - Thread_Control *thread, - Per_CPU_Control *cpu + Thread_Control *idle, + Per_CPU_Control *cpu ) { - Scheduler_Context *context = _Scheduler_Get_context( scheduler ); - Scheduler_SMP_Context *self = _Scheduler_SMP_Get_self( context ); - Scheduler_SMP_Node *node = _Scheduler_SMP_Thread_get_node( thread ); + Scheduler_Context *context; + Scheduler_SMP_Context *self; + Scheduler_SMP_Node *node; + + context = _Scheduler_Get_context( scheduler ); + self = _Scheduler_SMP_Get_self( context ); + node = _Scheduler_SMP_Thread_get_node( idle ); _Scheduler_Thread_change_state( thread, THREAD_SCHEDULER_SCHEDULED ); node->state = SCHEDULER_SMP_NODE_SCHEDULED; - _Thread_Set_CPU( thread, cpu ); + _Thread_Set_CPU( idle, cpu ); _Chain_Append_unprotected( &self->Scheduled, &node->Base.Node ); - _Chain_Prepend_unprotected( &self->Idle_threads, &thread->Object.Node ); + _Scheduler_SMP_Release_idle_thread( &self->Base, idle ); } |