Preparatory changes for Proxy Execution v12
From: | John Stultz <jstultz-AT-google.com> | |
To: | LKML <linux-kernel-AT-vger.kernel.org> | |
Subject: | [RESEND x3][PATCH v12 0/7] Preparatory changes for Proxy Execution v12 | |
Date: | Wed, 09 Oct 2024 16:53:33 -0700 | |
Message-ID: | <20241009235352.1614323-1-jstultz@google.com> | |
Cc: | John Stultz <jstultz-AT-google.com>, Joel Fernandes <joelaf-AT-google.com>, Qais Yousef <qyousef-AT-layalina.io>, Ingo Molnar <mingo-AT-redhat.com>, Peter Zijlstra <peterz-AT-infradead.org>, Juri Lelli <juri.lelli-AT-redhat.com>, Vincent Guittot <vincent.guittot-AT-linaro.org>, Dietmar Eggemann <dietmar.eggemann-AT-arm.com>, Valentin Schneider <vschneid-AT-redhat.com>, Steven Rostedt <rostedt-AT-goodmis.org>, Ben Segall <bsegall-AT-google.com>, Zimuzo Ezeozue <zezeozue-AT-google.com>, Mel Gorman <mgorman-AT-suse.de>, Will Deacon <will-AT-kernel.org>, Waiman Long <longman-AT-redhat.com>, Boqun Feng <boqun.feng-AT-gmail.com>, "Paul E. McKenney" <paulmck-AT-kernel.org>, Metin Kaya <Metin.Kaya-AT-arm.com>, Xuewen Yan <xuewen.yan94-AT-gmail.com>, K Prateek Nayak <kprateek.nayak-AT-amd.com>, Thomas Gleixner <tglx-AT-linutronix.de>, Daniel Lezcano <daniel.lezcano-AT-linaro.org>, kernel-team-AT-android.com | |
Archive-link: | Article |
Hey All, I wanted to re-send (again) v12 of the preparatory patches for Proxy Execution - an approach for a generalized form of priority inheritance. Here again, I’m only submitting the early / preparatory changes for review, in the hope that we can move these more straightforward patches along and then iteratively move through the more interesting patches in the Proxy Execution series. There have been a few changes to the preparatory patches in v12: * Peter suggested I switch from using “selected” to denote the task chosen to be scheduled, and instead use “donor” * K Prateek Nayak and Peter both pointed out issues in the “Remove wakeups from under mutex::wait_lock” patch that needed some work to solve. Thank you for all the detailed review and feedback there! The only change in this resend is rebasing the series on top of the current tip/sched/core branch and resolving some minor collisions. Usually I link to the full proxy-execution series here, but while these preparatory changes rebased easily, I still have some work to do on later changes in the full proxy-execution series to adapt to recent delayed dequeuing and dl_server rework that landed in 6.12-rc1. I'll post separately with those changes once I've hammered all the details out. Credit/Disclaimer: —-------------------- As mentioned previously, this Proxy Execution series has a long history: First described in a paper[1] by Watkins, Straub, Niehaus, then from patches from Peter Zijlstra, extended with lots of work by Juri Lelli, Valentin Schneider, and Connor O'Brien. (and thank you to Steven Rostedt for providing additional details here!) So again, many thanks to those above, as all the credit for this series really is due to them - while the mistakes are likely mine. Thanks so much! -john [1] https://static.lwn.net/images/conf/rtlws11/papers/proc/p3... Cc: Joel Fernandes <joelaf@google.com> Cc: Qais Yousef <qyousef@layalina.io> Cc: Ingo Molnar <mingo@redhat.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Juri Lelli <juri.lelli@redhat.com> Cc: Vincent Guittot <vincent.guittot@linaro.org> Cc: Dietmar Eggemann <dietmar.eggemann@arm.com> Cc: Valentin Schneider <vschneid@redhat.com> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: Ben Segall <bsegall@google.com> Cc: Zimuzo Ezeozue <zezeozue@google.com> Cc: Mel Gorman <mgorman@suse.de> Cc: Will Deacon <will@kernel.org> Cc: Waiman Long <longman@redhat.com> Cc: Boqun Feng <boqun.feng@gmail.com> Cc: "Paul E. McKenney" <paulmck@kernel.org> Cc: Metin Kaya <Metin.Kaya@arm.com> Cc: Xuewen Yan <xuewen.yan94@gmail.com> Cc: K Prateek Nayak <kprateek.nayak@amd.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Daniel Lezcano <daniel.lezcano@linaro.org> Cc: kernel-team@android.com Connor O'Brien (2): sched: Add move_queued_task_locked helper sched: Consolidate pick_*_task to task_is_pushable helper John Stultz (1): sched: Split out __schedule() deactivate task logic into a helper Juri Lelli (2): locking/mutex: Make mutex::wait_lock irq safe locking/mutex: Expose __mutex_owner() Peter Zijlstra (2): locking/mutex: Remove wakeups from under mutex::wait_lock sched: Split scheduler and execution contexts kernel/futex/pi.c | 6 +- kernel/locking/mutex.c | 59 ++++++--------- kernel/locking/mutex.h | 27 +++++++ kernel/locking/rtmutex.c | 49 +++++++++---- kernel/locking/rtmutex_api.c | 11 ++- kernel/locking/rtmutex_common.h | 3 +- kernel/locking/rwbase_rt.c | 8 ++- kernel/locking/rwsem.c | 4 +- kernel/locking/spinlock_rt.c | 3 +- kernel/locking/ww_mutex.h | 51 +++++++------ kernel/sched/core.c | 123 ++++++++++++++++++-------------- kernel/sched/deadline.c | 57 ++++++--------- kernel/sched/fair.c | 28 ++++---- kernel/sched/pelt.c | 2 +- kernel/sched/rt.c | 67 +++++++---------- kernel/sched/sched.h | 50 ++++++++++++- kernel/sched/syscalls.c | 4 +- 17 files changed, 324 insertions(+), 228 deletions(-) -- 2.47.0.rc0.187.ge670bccf7e-goog