diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2014-05-13 16:03:05 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2014-05-14 14:46:19 +0200 |
commit | beab7329fca655c93743fbb590d00bb4ea5a6d78 (patch) | |
tree | fbeb6b27f887b46a41f84acc64aecfce18686540 /cpukit/score/src/schedulercbs.c | |
parent | score: Scheduler documentation (diff) | |
download | rtems-beab7329fca655c93743fbb590d00bb4ea5a6d78.tar.bz2 |
score: Introduce scheduler nodes
Rename scheduler per-thread information into scheduler nodes using
Scheduler_Node as the base type. Use inheritance for specialized
schedulers.
Move the scheduler specific states from the thread control block into
the scheduler node structure.
Validate the SMP scheduler node state transitions in case RTEMS_DEBUG is
defined.
Diffstat (limited to 'cpukit/score/src/schedulercbs.c')
-rw-r--r-- | cpukit/score/src/schedulercbs.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/cpukit/score/src/schedulercbs.c b/cpukit/score/src/schedulercbs.c index 54312b2ca6..e2f34d4c82 100644 --- a/cpukit/score/src/schedulercbs.c +++ b/cpukit/score/src/schedulercbs.c @@ -18,7 +18,7 @@ #include "config.h" #endif -#include <rtems/score/schedulercbs.h> +#include <rtems/score/schedulercbsimpl.h> #include <rtems/score/threadimpl.h> #include <rtems/score/wkspace.h> @@ -27,7 +27,7 @@ void _Scheduler_CBS_Budget_callout( ) { Priority_Control new_priority; - Scheduler_CBS_Per_thread *sched_info; + Scheduler_CBS_Node *node; Scheduler_CBS_Server_id server_id; /* Put violating task to background until the end of period. */ @@ -38,13 +38,13 @@ void _Scheduler_CBS_Budget_callout( _Thread_Change_priority(the_thread, new_priority, true); /* Invoke callback function if any. */ - sched_info = (Scheduler_CBS_Per_thread *) the_thread->scheduler_info; - if ( sched_info->cbs_server->cbs_budget_overrun ) { + node = _Scheduler_CBS_Node_get( the_thread ); + if ( node->cbs_server->cbs_budget_overrun ) { _Scheduler_CBS_Get_server_id( - sched_info->cbs_server->task_id, + node->cbs_server->task_id, &server_id ); - sched_info->cbs_server->cbs_budget_overrun( server_id ); + node->cbs_server->cbs_budget_overrun( server_id ); } } |