|| ||Raistlin <email@example.com> |
|| ||Peter Zijlstra <firstname.lastname@example.org> |
|| ||[RFC][PATCH 0/11] sched: SCHED_DEADLINE v2 |
|| ||Sun, 28 Feb 2010 20:06:16 +0100|
|| ||Ingo Molnar <email@example.com>, Thomas Gleixner <firstname.lastname@example.org>,
Steven Rostedt <email@example.com>,
Chris Friesen <firstname.lastname@example.org>,
Frederic Weisbecker <email@example.com>,
Darren Hart <firstname.lastname@example.org>,
Henrik Austad <email@example.com>,
Johan Eker <firstname.lastname@example.org>,
Claudio Scordino <email@example.com>,
michael trimarchi <firstname.lastname@example.org>,
Fabio Checconi <email@example.com>,
Tommaso Cucinotta <firstname.lastname@example.org>,
Juri Lelli <email@example.com>,
Nicola Manica <firstname.lastname@example.org>,
Luca Abeni <email@example.com>|
|| ||Article, Thread
Here it is the new version of the SCHED_DEADLINE patchset.
For the ones that missed the first posting[*], it is basically a new
scheduling policy (implemented inside its own scheduling class) aiming
at introducing deadline scheduling for Linux tasks, and it is being
developed by Evidence S.r.l. (http://www.evidence.eu.com) in the context
of the EU-Funded project ACTORS (http://www.actors-project.eu/).
From the previous version, mainly:
- I followed all the suggestions --about bug-fixing and code
restyling-- that Peter kindly gave us in his review;
- in particular, I rewrote from scratch the group part, i.e.,
bandwidth is now accounted for in a per-CPU fashion, such that
the interface is the same we already have for RT-throttling;
- I added a first drafted implementation of deadline inheritance, even
though it surely needs thorough testing and refinements.
The official page of the project is:
while the development is taking place at[**]:
Still Missing parts:
- bandwidth reclaiming mechanisms, i.e., methods that avoid stopping
the tasks until their next deadline when overrunning. There are at
least three of them that are very simple, and patches are on their
- porting to PREEMPT-RT is almost done --thanks to Nicola and Luca--
and separate patches will be available on the project website soon;
- migration of tasks throughout push and pull (as in -rt), to make it
possible to deploy global-EDF scheduling. Patches are ready, they're
just being tested and adapted to this last version;
- refinements in deadline inheritance, especially regarding the
possibility of retaining bandwidth isolation among non-interacting
tasks. This is being studied from both theoretical and practical
points of view, and hopefully we can have some demonstrative code
As Fabio said recently, I also would like to remark that we are
addressing different problems and providing the kernel with different
new features, but we can share some code and we'll definitely do that if
it is the case.
Patchset against Linus' master (at the time of this writing) follows,
comments and any kind of feedback is, as usual, more than welcome.
Many thanks and Regards,
[**] the repositories are outdated right now, I'll post the last changes
and the last version of utilities and testing programs in the very
Dario Faggioli, SCHED_DEADLINE (11)
sched: add sched_class->task_dead.
sched: SCHED_DEADLINE policy implementation.
sched: add extended scheduling interface.
sched: add resource limits for -deadline tasks.
sched: add a syscall to wait for the next instance.
sched: add the sched-debug bits for sched_dl.
sched: add latency tracing for -deadline tasks.
sched: send SIGXCPU at -deadline task overruns.
sched: first draft of deadline inheritance.
sched: add bandwidth management for sched_dl.
sched: add sched_dl documentation.
Documentation/scheduler/sched-deadline.txt | 188 ++++
arch/arm/include/asm/unistd.h | 4 +
arch/arm/kernel/calls.S | 4 +
arch/x86/ia32/ia32entry.S | 4 +
arch/x86/include/asm/unistd_32.h | 6 +-
arch/x86/include/asm/unistd_64.h | 8 +
arch/x86/kernel/syscall_table_32.S | 4 +
include/asm-generic/resource.h | 7 +-
include/linux/sched.h | 173 ++++
include/linux/syscalls.h | 9 +
init/Kconfig | 15 +
kernel/fork.c | 12 +
kernel/hrtimer.c | 2 +-
kernel/sched.c | 1329 +++++++++++++++++++++++++++-
kernel/sched_debug.c | 36 +-
kernel/sched_dl.c | 787 ++++++++++++++++
kernel/sched_fair.c | 2 +-
kernel/sched_rt.c | 2 +-
kernel/sysctl.c | 21 +
kernel/trace/trace_sched_wakeup.c | 44 +-
kernel/trace/trace_selftest.c | 30 +-
21 files changed, 2630 insertions(+), 57 deletions(-)
<<This happens because I choose it to happen!>> (Raistlin Majere)
Dario Faggioli, ReTiS Lab, Scuola Superiore Sant'Anna, Pisa (Italy)
http://blog.linux.it/raistlin / firstname.lastname@example.org /