aboutsummaryrefslogtreecommitdiffstats
path: root/litmus/sched_pfp.c
diff options
context:
space:
mode:
Diffstat (limited to 'litmus/sched_pfp.c')
-rw-r--r--litmus/sched_pfp.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/litmus/sched_pfp.c b/litmus/sched_pfp.c
index 91e52391a173..0e875a3b5cba 100644
--- a/litmus/sched_pfp.c
+++ b/litmus/sched_pfp.c
@@ -182,7 +182,7 @@ static struct task_struct* pfp_schedule(struct task_struct * prev)
182 np = exists && is_np(pfp->scheduled); 182 np = exists && is_np(pfp->scheduled);
183 sleep = exists && is_completed(pfp->scheduled); 183 sleep = exists && is_completed(pfp->scheduled);
184 migrate = exists && get_partition(pfp->scheduled) != pfp->cpu; 184 migrate = exists && get_partition(pfp->scheduled) != pfp->cpu;
185 preempt = migrate || fp_preemption_needed(&pfp->ready_queue, prev); 185 preempt = !blocks && (migrate || fp_preemption_needed(&pfp->ready_queue, prev));
186 186
187 /* If we need to preempt do so. 187 /* If we need to preempt do so.
188 * The following checks set resched to 1 in case of special 188 * The following checks set resched to 1 in case of special
@@ -1089,8 +1089,10 @@ static void pcp_priority_inheritance(void)
1089 fp_set_prio_inh(pfp, blocker, blocked); 1089 fp_set_prio_inh(pfp, blocker, blocked);
1090 } 1090 }
1091 1091
1092 /* check if anything changed */ 1092 /* Check if anything changed. If the blocked job is current, then it is
1093 if (fp_higher_prio(fp_prio_peek(&pfp->ready_queue), pfp->scheduled)) 1093 * just blocking and hence is going to call the scheduler anyway. */
1094 if (blocked != current &&
1095 fp_higher_prio(fp_prio_peek(&pfp->ready_queue), pfp->scheduled))
1094 preempt(pfp); 1096 preempt(pfp);
1095 1097
1096 raw_spin_unlock_irqrestore(&pfp->slock, flags); 1098 raw_spin_unlock_irqrestore(&pfp->slock, flags);
@@ -1201,10 +1203,10 @@ static void pcp_lower_ceiling(struct pcp_semaphore* sem)
1201 1203
1202 TRACE_CUR("PCP released sem %p\n", sem); 1204 TRACE_CUR("PCP released sem %p\n", sem);
1203 1205
1206 pcp_priority_inheritance();
1207
1204 /* Wake up all ceiling-blocked jobs that now pass the ceiling. */ 1208 /* Wake up all ceiling-blocked jobs that now pass the ceiling. */
1205 pcp_resume_unblocked(); 1209 pcp_resume_unblocked();
1206
1207 pcp_priority_inheritance();
1208} 1210}
1209 1211
1210static void pcp_update_prio_ceiling(struct pcp_semaphore* sem, 1212static void pcp_update_prio_ceiling(struct pcp_semaphore* sem,