summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2016-07-01 11:50:41 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2016-07-01 11:51:48 +0200
commit4142f73762a3ced0128dca6766b4c0e094bb39e4 (patch)
tree7330695106c17fb71cdfb50e7b0fed99fc992df9
parentsmptests/smpstrongapa01: Simplify (diff)
downloadrtems-4142f73762a3ced0128dca6766b4c0e094bb39e4.tar.bz2
score: Fix priority affinity SMP scheduler
Bug introduced by 9bfad8cd519f17cbb26a672868169fcd304d5bd5.
-rw-r--r--cpukit/score/src/schedulerpriorityaffinitysmp.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/cpukit/score/src/schedulerpriorityaffinitysmp.c b/cpukit/score/src/schedulerpriorityaffinitysmp.c
index 76b46010cb..cec09729fb 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 );