summaryrefslogtreecommitdiffstats
path: root/cpukit/score/src/schedulersmpstartidle.c
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2016-11-08 06:39:07 +0100
committerSebastian Huber <sebastian.huber@embedded-brains.de>2016-11-09 15:27:29 +0100
commit68ef65bd5ebd1b2177f9defe5cde994e1466bfab (patch)
tree30ba66814377807be35df5279b2882932b2b4636 /cpukit/score/src/schedulersmpstartidle.c
parentscore: Add scheduler to per-CPU information (diff)
downloadrtems-68ef65bd5ebd1b2177f9defe5cde994e1466bfab.tar.bz2
score: Clarify _Scheduler_SMP_Start_idle()
Diffstat (limited to 'cpukit/score/src/schedulersmpstartidle.c')
-rw-r--r--cpukit/score/src/schedulersmpstartidle.c20
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 );
}