RTEMS 6.1-rc4
|
This group contains the Strong APA Scheduler implementation. More...
Files | |
file | schedulerstrongapa.h |
This header file provides the interfaces of the Strong APA Scheduler. | |
file | schedulerstrongapa.c |
This source file contains the implementation of _Scheduler_strong_APA_Add_processor(), _Scheduler_strong_APA_Allocate_processor(), _Scheduler_strong_APA_Ask_for_help(), _Scheduler_strong_APA_Block(), _Scheduler_strong_APA_Do_ask_for_help(), _Scheduler_strong_APA_Do_enqueue(), _Scheduler_strong_APA_Do_set_affinity(), _Scheduler_strong_APA_Do_update(), _Scheduler_strong_APA_Enqueue(), _Scheduler_strong_APA_Enqueue_scheduled(), _Scheduler_strong_APA_Extract_from_ready(), _Scheduler_strong_APA_Extract_from_scheduled(), _Scheduler_strong_APA_Find_highest_ready(), _Scheduler_strong_APA_Get_highest_ready(), _Scheduler_strong_APA_Get_lowest_reachable(), _Scheduler_strong_APA_Get_lowest_scheduled(), _Scheduler_strong_APA_Has_ready(), _Scheduler_strong_APA_Initialize(), _Scheduler_strong_APA_Insert_ready(), _Scheduler_strong_APA_Move_from_ready_to_scheduled(), _Scheduler_strong_APA_Move_from_scheduled_to_ready(), _Scheduler_strong_APA_Node_initialize(), _Scheduler_strong_APA_Reconsider_help_request(), _Scheduler_strong_APA_Register_idle(), _Scheduler_strong_APA_Remove_processor(), _Scheduler_strong_APA_Set_affinity(), _Scheduler_strong_APA_Set_scheduled(), _Scheduler_strong_APA_Start_idle(), _Scheduler_strong_APA_Unblock(), _Scheduler_strong_APA_Update_priority(), _Scheduler_strong_APA_Withdraw_node(), _Scheduler_strong_APA_Make_sticky(), _Scheduler_strong_APA_Clean_sticky(), and _Scheduler_strong_APA_Yield(). | |
Data Structures | |
struct | Scheduler_strong_APA_Node |
Scheduler node specialization for Strong APA schedulers. More... | |
struct | Scheduler_strong_APA_CPU |
CPU related variables and a CPU_Control to implement BFS. More... | |
struct | Scheduler_strong_APA_Context |
Scheduler context and node definition for Strong APA scheduler. More... | |
Macros | |
#define | SCHEDULER_STRONG_APA_MAXIMUM_PRIORITY 255 |
#define | SCHEDULER_STRONG_APA_ENTRY_POINTS |
Entry points for the Strong APA Scheduler. | |
Functions | |
void | _Scheduler_strong_APA_Initialize (const Scheduler_Control *scheduler) |
Initializes the scheduler. | |
void | _Scheduler_strong_APA_Node_initialize (const Scheduler_Control *scheduler, Scheduler_Node *node, Thread_Control *the_thread, Priority_Control priority) |
Initializes the node with the given priority. | |
void | _Scheduler_strong_APA_Block (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Blocks the thread. | |
void | _Scheduler_strong_APA_Unblock (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Unblocks the thread. | |
void | _Scheduler_strong_APA_Update_priority (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Updates the priority of the node. | |
bool | _Scheduler_strong_APA_Ask_for_help (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Asks for help. | |
void | _Scheduler_strong_APA_Reconsider_help_request (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Reconsiders help request. | |
void | _Scheduler_strong_APA_Withdraw_node (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node, Thread_Scheduler_state next_state) |
Withdraws the node. | |
void | _Scheduler_strong_APA_Make_sticky (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Makes the node sticky. | |
void | _Scheduler_strong_APA_Clean_sticky (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Cleans the sticky property from the node. | |
void | _Scheduler_strong_APA_sticky (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Cleans the sticky property from the node. | |
void | _Scheduler_strong_APA_Add_processor (const Scheduler_Control *scheduler, Thread_Control *idle) |
Adds the idle thread to a processor. | |
Thread_Control * | _Scheduler_strong_APA_Remove_processor (const Scheduler_Control *scheduler, struct Per_CPU_Control *cpu) |
Removes an idle thread from the given cpu. | |
void | _Scheduler_strong_APA_Yield (const Scheduler_Control *scheduler, Thread_Control *the_thread, Scheduler_Node *node) |
Performs a yield operation. | |
void | _Scheduler_strong_APA_Start_idle (const Scheduler_Control *scheduler, Thread_Control *idle, struct Per_CPU_Control *cpu) |
Starts an idle thread. | |
Status_Control | _Scheduler_strong_APA_Set_affinity (const Scheduler_Control *scheduler, Thread_Control *thread, Scheduler_Node *node_base, const Processor_mask *affinity) |
Sets the affinity . | |
This group contains the Strong APA Scheduler implementation.
This is an implementation of the Strong APA scheduler defined by Cerqueira et al. in Linux's Processor Affinity API, Refined: Shifting Real-Time Tasks Towards Higher Schedulability.
The scheduled and ready nodes are accessed via the Scheduler_strong_APA_Context::Ready which helps in backtracking when a node which is executing on a CPU gets blocked. New node is allocated to the cpu by checking all the executing nodes in the affinity set of the node and the subsequent nodes executing on the processors in its affinity set.
#define SCHEDULER_STRONG_APA_ENTRY_POINTS |
Entry points for the Strong APA Scheduler.
void _Scheduler_strong_APA_Add_processor | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | idle | ||
) |
Adds the idle thread to a processor.
scheduler | The scheduler control instance. | |
[in,out] | The | idle thread to add to the processor. |
bool _Scheduler_strong_APA_Ask_for_help | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Asks for help.
scheduler | The scheduler control instance. |
the_thread | The thread that asks for help. |
node | The node of the_thread. |
true | The request for help was successful. |
false | The request for help was not successful. |
void _Scheduler_strong_APA_Block | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Blocks the thread.
scheduler | The scheduler control instance. | |
[in,out] | the_thread | The thread to block. |
[in,out] | node | The node of the thread to block. |
void _Scheduler_strong_APA_Clean_sticky | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Cleans the sticky property from the node.
scheduler | is the scheduler of the node. | |
[in,out] | the_thread | is the thread owning the node. |
[in,out] | node | is the scheduler node to clean the sticky property. |
void _Scheduler_strong_APA_Initialize | ( | const Scheduler_Control * | scheduler | ) |
Initializes the scheduler.
scheduler | The scheduler to initialize. |
void _Scheduler_strong_APA_Make_sticky | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Makes the node sticky.
scheduler | is the scheduler of the node. | |
[in,out] | the_thread | is the thread owning the node. |
[in,out] | node | is the scheduler node to make sticky. |
scheduler | is the scheduler of the node. | |
[in,out] | the_thread | is the thread owning the node. |
[in,out] | node | is the scheduler node to make sticky. |
void _Scheduler_strong_APA_Node_initialize | ( | const Scheduler_Control * | scheduler, |
Scheduler_Node * | node, | ||
Thread_Control * | the_thread, | ||
Priority_Control | priority | ||
) |
Initializes the node with the given priority.
scheduler | The scheduler control instance. | |
[out] | node | The node to initialize. |
the_thread | The thread of the node to initialize. | |
priority | The priority for node. |
void _Scheduler_strong_APA_Reconsider_help_request | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Reconsiders help request.
scheduler | The scheduler control instance. | |
the_thread | The thread to reconsider the help request of. | |
[in,out] | node | The node of the_thread |
Thread_Control * _Scheduler_strong_APA_Remove_processor | ( | const Scheduler_Control * | scheduler, |
struct Per_CPU_Control * | cpu | ||
) |
Removes an idle thread from the given cpu.
scheduler | The scheduler instance. |
cpu | The cpu control to remove from scheduler. |
Status_Control _Scheduler_strong_APA_Set_affinity | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | thread, | ||
Scheduler_Node * | node_base, | ||
const Processor_mask * | affinity | ||
) |
Sets the affinity .
scheduler | The scheduler control instance. | |
the_thread | The thread to yield. | |
[in,out] | node | The node of the_thread. |
void _Scheduler_strong_APA_Start_idle | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | idle, | ||
struct Per_CPU_Control * | cpu | ||
) |
Starts an idle thread.
scheduler | The scheduler instance. | |
[in,out] | the_thread | An idle thread. |
cpu | The cpu for the operation. |
void _Scheduler_strong_APA_sticky | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Cleans the sticky property from the node.
scheduler | is the scheduler of the node. | |
[in,out] | the_thread | is the thread owning the node. |
[in,out] | node | is the scheduler node to clean the sticky property. |
void _Scheduler_strong_APA_Unblock | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Unblocks the thread.
scheduler | The scheduler control instance. | |
[in,out] | the_thread | The thread to unblock. |
[in,out] | node | The node of the thread to unblock. |
void _Scheduler_strong_APA_Update_priority | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Updates the priority of the node.
scheduler | The scheduler control instance. | |
the_thread | The thread for the operation. | |
[in,out] | node | The node to update the priority of. |
void _Scheduler_strong_APA_Withdraw_node | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node, | ||
Thread_Scheduler_state | next_state | ||
) |
Withdraws the node.
scheduler | The scheduler control instance. | |
[in,out] | the_thread | The thread to change the state to next_state. |
[in,out] | node | The node to withdraw. |
next_state | The next state for the_thread. |
void _Scheduler_strong_APA_Yield | ( | const Scheduler_Control * | scheduler, |
Thread_Control * | the_thread, | ||
Scheduler_Node * | node | ||
) |
Performs a yield operation.
scheduler | The scheduler control instance. | |
the_thread | The thread to yield. | |
[in,out] | node | The node of the_thread. |