diff options
-rw-r--r-- | litmus/sched_cedf.c | 49 |
1 files changed, 25 insertions, 24 deletions
diff --git a/litmus/sched_cedf.c b/litmus/sched_cedf.c index a25f2a474263..10ada7edadf2 100644 --- a/litmus/sched_cedf.c +++ b/litmus/sched_cedf.c | |||
@@ -456,9 +456,10 @@ static struct task_struct* cedf_schedule(struct task_struct * prev) | |||
456 | if (exists) | 456 | if (exists) |
457 | TRACE_TASK(prev, | 457 | TRACE_TASK(prev, |
458 | "blocks:%d out_of_time:%d np:%d sleep:%d preempt:%d " | 458 | "blocks:%d out_of_time:%d np:%d sleep:%d preempt:%d " |
459 | "state:%d sig:%d\n", | 459 | "state:%d sig:%d boosted:%d\n", |
460 | blocks, out_of_time, np, sleep, preempt, | 460 | blocks, out_of_time, np, sleep, preempt, |
461 | prev->state, signal_pending(prev)); | 461 | prev->state, signal_pending(prev), |
462 | is_priority_boosted(entry->scheduled)); | ||
462 | if (entry->linked && preempt) | 463 | if (entry->linked && preempt) |
463 | TRACE_TASK(prev, "will be preempted by %s/%d\n", | 464 | TRACE_TASK(prev, "will be preempted by %s/%d\n", |
464 | entry->linked->comm, entry->linked->pid); | 465 | entry->linked->comm, entry->linked->pid); |
@@ -473,17 +474,24 @@ static struct task_struct* cedf_schedule(struct task_struct * prev) | |||
473 | 474 | ||
474 | /* We are either sending tokens or waiting for tokes. | 475 | /* We are either sending tokens or waiting for tokes. |
475 | If waiting: Boost priority so we'll be scheduled | 476 | If waiting: Boost priority so we'll be scheduled |
476 | immediately when needed tokens arrive. | 477 | immediately when needed tokens arrive. |
477 | If sending: Boost priority so no one (specifically, our | 478 | If sending: Boost priority so no one (specifically, our |
478 | consumers) will preempt us while signalling the token | 479 | consumers) will preempt us while signalling the token |
479 | transmission. | 480 | transmission. |
480 | */ | 481 | */ |
481 | tsk_rt(entry->scheduled)->priority_boosted = 1; | 482 | tsk_rt(entry->scheduled)->priority_boosted = 1; |
482 | tsk_rt(entry->scheduled)->boost_start_time = litmus_clock(); | 483 | tsk_rt(entry->scheduled)->boost_start_time = litmus_clock(); |
483 | 484 | ||
484 | if (likely(!blocks)) { | 485 | if (likely(!blocks)) { |
485 | unlink(entry->scheduled); | 486 | unlink(entry->scheduled); |
486 | cedf_job_arrival(entry->scheduled); | 487 | cedf_job_arrival(entry->scheduled); |
488 | /* we may regain the processor */ | ||
489 | if (preempt) { | ||
490 | preempt = entry->scheduled != entry->linked; | ||
491 | if (!preempt) { | ||
492 | TRACE_TASK(entry->scheduled, "blocked preemption by lazy boosting.\n"); | ||
493 | } | ||
494 | } | ||
487 | } | 495 | } |
488 | } | 496 | } |
489 | } | 497 | } |
@@ -500,26 +508,17 @@ static struct task_struct* cedf_schedule(struct task_struct * prev) | |||
500 | /* recheck priority */ | 508 | /* recheck priority */ |
501 | unlink(entry->scheduled); | 509 | unlink(entry->scheduled); |
502 | cedf_job_arrival(entry->scheduled); | 510 | cedf_job_arrival(entry->scheduled); |
511 | /* we may lose the processor */ | ||
512 | if (!preempt) { | ||
513 | preempt = entry->scheduled != entry->linked; | ||
514 | if (preempt) { | ||
515 | TRACE_TASK(entry->scheduled, "preempted by lazy unboosting.\n"); | ||
516 | } | ||
517 | } | ||
503 | } | 518 | } |
504 | } | 519 | } |
505 | } | 520 | } |
506 | } | 521 | } |
507 | #if 0 | ||
508 | else if(is_pgm_waiting(entry->scheduled)) { | ||
509 | int shifted_release; | ||
510 | |||
511 | TRACE_TASK(entry->scheduled, "is waiting for PGM tokens.\n"); | ||
512 | /* release the next job if we have the tokens we need */ | ||
513 | shifted_release = setup_pgm_release(entry->scheduled); | ||
514 | |||
515 | /* setup_pgm_release() can screw with our priority, | ||
516 | so recheck it */ | ||
517 | if (shifted_release && likely(!blocks)) { | ||
518 | unlink(entry->scheduled); | ||
519 | cedf_job_arrival(entry->scheduled); | ||
520 | } | ||
521 | } | ||
522 | #endif | ||
523 | } | 522 | } |
524 | #endif | 523 | #endif |
525 | 524 | ||
@@ -533,10 +532,13 @@ static struct task_struct* cedf_schedule(struct task_struct * prev) | |||
533 | * that we are still linked. Multiple calls to request_exit_np() don't | 532 | * that we are still linked. Multiple calls to request_exit_np() don't |
534 | * hurt. | 533 | * hurt. |
535 | */ | 534 | */ |
536 | if (np && (out_of_time || preempt || sleep)) { | 535 | if (np && (out_of_time || sleep)) { |
537 | unlink(entry->scheduled); | 536 | unlink(entry->scheduled); |
538 | request_exit_np(entry->scheduled); | 537 | request_exit_np(entry->scheduled); |
539 | } | 538 | } |
539 | else if(np && preempt) { | ||
540 | request_exit_np(entry->scheduled); | ||
541 | } | ||
540 | 542 | ||
541 | /* Any task that is preemptable and either exhausts its execution | 543 | /* Any task that is preemptable and either exhausts its execution |
542 | * budget or wants to sleep completes. We may have to reschedule after | 544 | * budget or wants to sleep completes. We may have to reschedule after |
@@ -586,7 +588,6 @@ static struct task_struct* cedf_schedule(struct task_struct * prev) | |||
586 | TRACE("becomes idle at %llu.\n", litmus_clock()); | 588 | TRACE("becomes idle at %llu.\n", litmus_clock()); |
587 | #endif | 589 | #endif |
588 | 590 | ||
589 | |||
590 | return next; | 591 | return next; |
591 | } | 592 | } |
592 | 593 | ||