summaryrefslogtreecommitdiffstats
path: root/kernel/futex.c
diff options
context:
space:
mode:
authorXunlei Pang2017-03-23 15:56:09 +0100
committerThomas Gleixner2017-04-04 11:44:05 +0200
commit85e2d4f992868ad78dc8bb2c077b652fcfb3661a (patch)
treeb0c81f1685b1799f174bfe8ba0a914dd3f500f18 /kernel/futex.c
parentsched/rtmutex/deadline: Fix a PI crash for deadline tasks (diff)
downloadkernel-qcow2-linux-85e2d4f992868ad78dc8bb2c077b652fcfb3661a.tar.gz
kernel-qcow2-linux-85e2d4f992868ad78dc8bb2c077b652fcfb3661a.tar.xz
kernel-qcow2-linux-85e2d4f992868ad78dc8bb2c077b652fcfb3661a.zip
sched/deadline/rtmutex: Dont miss the dl_runtime/dl_period update
Currently dl tasks will actually return at the very beginning of rt_mutex_adjust_prio_chain() in !detect_deadlock cases: if (waiter->prio == task->prio) { if (!detect_deadlock) goto out_unlock_pi; // out here else requeue = false; } As the deadline value of blocked deadline tasks(waiters) without changing their sched_class(thus prio doesn't change) never changes, this seems reasonable, but it actually misses the chance of updating rt_mutex_waiter's "dl_runtime(period)_copy" if a waiter updates its deadline parameters(dl_runtime, dl_period) or boosted waiter changes to !deadline class. Thus, force deadline task not out by adding the !dl_prio() condition. Signed-off-by: Xunlei Pang <xlpang@redhat.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Acked-by: Steven Rostedt <rostedt@goodmis.org> Reviewed-by: Thomas Gleixner <tglx@linutronix.de> Cc: juri.lelli@arm.com Cc: bigeasy@linutronix.de Cc: mathieu.desnoyers@efficios.com Cc: jdesfossez@efficios.com Cc: bristot@redhat.com Link: http://lkml.kernel.org/r/1460633827-345-7-git-send-email-xlpang@redhat.com Link: http://lkml.kernel.org/r/20170323150216.206577901@infradead.org Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'kernel/futex.c')
0 files changed, 0 insertions, 0 deletions