[rtems commit] score: Fix priority affinity SMP scheduler
Sebastian Huber
sebh at rtems.org
Fri Jul 1 09:58:20 UTC 2016
Module: rtems
Branch: master
Commit: 4142f73762a3ced0128dca6766b4c0e094bb39e4
Changeset: http://git.rtems.org/rtems/commit/?id=4142f73762a3ced0128dca6766b4c0e094bb39e4
Author: Sebastian Huber <sebastian.huber at embedded-brains.de>
Date: Fri Jul 1 11:50:41 2016 +0200
score: Fix priority affinity SMP scheduler
Bug introduced by 9bfad8cd519f17cbb26a672868169fcd304d5bd5.
---
cpukit/score/src/schedulerpriorityaffinitysmp.c | 12 ++++++++++--
1 file changed, 10 insertions(+), 2 deletions(-)
diff --git a/cpukit/score/src/schedulerpriorityaffinitysmp.c b/cpukit/score/src/schedulerpriorityaffinitysmp.c
index 76b4601..cec0972 100644
--- a/cpukit/score/src/schedulerpriorityaffinitysmp.c
+++ b/cpukit/score/src/schedulerpriorityaffinitysmp.c
@@ -306,10 +306,18 @@ static void _Scheduler_priority_affinity_SMP_Check_for_migrations(
Scheduler_Context *context
)
{
- Scheduler_Node *lowest_scheduled;
- Scheduler_Node *highest_ready;
+ Scheduler_priority_SMP_Context *self;
+ Scheduler_Node *lowest_scheduled;
+ Scheduler_Node *highest_ready;
+
+ self = _Scheduler_priority_SMP_Get_self( context );
while (1) {
+ if ( _Priority_bit_map_Is_empty( &self->Bit_map ) ) {
+ /* Nothing to do */
+ break;
+ }
+
highest_ready =
_Scheduler_priority_affinity_SMP_Get_highest_ready( context, NULL );
More information about the vc
mailing list