summaryrefslogtreecommitdiffstats
path: root/cpukit/score/include/rtems/score/schedulersimpleimpl.h
diff options
context:
space:
mode:
Diffstat (limited to 'cpukit/score/include/rtems/score/schedulersimpleimpl.h')
-rw-r--r--cpukit/score/include/rtems/score/schedulersimpleimpl.h52
1 files changed, 9 insertions, 43 deletions
diff --git a/cpukit/score/include/rtems/score/schedulersimpleimpl.h b/cpukit/score/include/rtems/score/schedulersimpleimpl.h
index ec74cdc586..3891839281 100644
--- a/cpukit/score/include/rtems/score/schedulersimpleimpl.h
+++ b/cpukit/score/include/rtems/score/schedulersimpleimpl.h
@@ -38,65 +38,31 @@ RTEMS_INLINE_ROUTINE Scheduler_simple_Context *
return (Scheduler_simple_Context *) _Scheduler_Get_context( scheduler );
}
-RTEMS_INLINE_ROUTINE bool _Scheduler_simple_Insert_priority_lifo_order(
+RTEMS_INLINE_ROUTINE bool _Scheduler_simple_Priority_less_equal(
const void *to_insert,
const Chain_Node *next
)
{
- const Priority_Control *priority_to_insert;
- const Thread_Control *thread_next;
+ const unsigned int *priority_to_insert;
+ const Thread_Control *thread_next;
- priority_to_insert = (const Priority_Control *) to_insert;
+ priority_to_insert = (const unsigned int *) to_insert;
thread_next = (const Thread_Control *) next;
return *priority_to_insert <= _Thread_Get_priority( thread_next );
}
-RTEMS_INLINE_ROUTINE bool _Scheduler_simple_Insert_priority_fifo_order(
- const void *to_insert,
- const Chain_Node *next
-)
-{
- const Priority_Control *priority_to_insert;
- const Thread_Control *thread_next;
-
- priority_to_insert = (const Priority_Control *) to_insert;
- thread_next = (const Thread_Control *) next;
-
- return *priority_to_insert < _Thread_Get_priority( thread_next );
-}
-
-RTEMS_INLINE_ROUTINE void _Scheduler_simple_Insert_priority_lifo(
- Chain_Control *chain,
- Thread_Control *to_insert
-)
-{
- Priority_Control priority_to_insert;
-
- priority_to_insert = _Thread_Get_priority( to_insert );
-
- _Chain_Insert_ordered_unprotected(
- chain,
- &to_insert->Object.Node,
- &priority_to_insert,
- _Scheduler_simple_Insert_priority_lifo_order
- );
-}
-
-RTEMS_INLINE_ROUTINE void _Scheduler_simple_Insert_priority_fifo(
+RTEMS_INLINE_ROUTINE void _Scheduler_simple_Insert(
Chain_Control *chain,
- Thread_Control *to_insert
+ Thread_Control *to_insert,
+ unsigned int insert_priority
)
{
- Priority_Control priority_to_insert;
-
- priority_to_insert = _Thread_Get_priority( to_insert );
-
_Chain_Insert_ordered_unprotected(
chain,
&to_insert->Object.Node,
- &priority_to_insert,
- _Scheduler_simple_Insert_priority_fifo_order
+ &insert_priority,
+ _Scheduler_simple_Priority_less_equal
);
}