diff options
author | Dario Faggioli <raistlin@linux.it> | 2013-11-07 08:43:45 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2014-01-13 07:46:42 -0500 |
commit | 332ac17ef5bfcff4766dfdfd3b4cdf10b8f8f155 (patch) | |
tree | 84c6663542da4310c5c555afaac88ac9b696fe4b /include | |
parent | 2d3d891d3344159d5b452a645e355bbe29591e8b (diff) |
sched/deadline: Add bandwidth management for SCHED_DEADLINE tasks
In order of deadline scheduling to be effective and useful, it is
important that some method of having the allocation of the available
CPU bandwidth to tasks and task groups under control.
This is usually called "admission control" and if it is not performed
at all, no guarantee can be given on the actual scheduling of the
-deadline tasks.
Since when RT-throttling has been introduced each task group have a
bandwidth associated to itself, calculated as a certain amount of
runtime over a period. Moreover, to make it possible to manipulate
such bandwidth, readable/writable controls have been added to both
procfs (for system wide settings) and cgroupfs (for per-group
settings).
Therefore, the same interface is being used for controlling the
bandwidth distrubution to -deadline tasks and task groups, i.e.,
new controls but with similar names, equivalent meaning and with
the same usage paradigm are added.
However, more discussion is needed in order to figure out how
we want to manage SCHED_DEADLINE bandwidth at the task group level.
Therefore, this patch adds a less sophisticated, but actually
very sensible, mechanism to ensure that a certain utilization
cap is not overcome per each root_domain (the single rq for !SMP
configurations).
Another main difference between deadline bandwidth management and
RT-throttling is that -deadline tasks have bandwidth on their own
(while -rt ones doesn't!), and thus we don't need an higher level
throttling mechanism to enforce the desired bandwidth.
This patch, therefore:
- adds system wide deadline bandwidth management by means of:
* /proc/sys/kernel/sched_dl_runtime_us,
* /proc/sys/kernel/sched_dl_period_us,
that determine (i.e., runtime / period) the total bandwidth
available on each CPU of each root_domain for -deadline tasks;
- couples the RT and deadline bandwidth management, i.e., enforces
that the sum of how much bandwidth is being devoted to -rt
-deadline tasks to stay below 100%.
This means that, for a root_domain comprising M CPUs, -deadline tasks
can be created until the sum of their bandwidths stay below:
M * (sched_dl_runtime_us / sched_dl_period_us)
It is also possible to disable this bandwidth management logic, and
be thus free of oversubscribing the system up to any arbitrary level.
Signed-off-by: Dario Faggioli <raistlin@linux.it>
Signed-off-by: Juri Lelli <juri.lelli@gmail.com>
Signed-off-by: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1383831828-15501-12-git-send-email-juri.lelli@gmail.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/sched.h | 1 | ||||
-rw-r--r-- | include/linux/sched/sysctl.h | 13 |
2 files changed, 14 insertions, 0 deletions
diff --git a/include/linux/sched.h b/include/linux/sched.h index 13c53a99920f..a196cb7fc6f2 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h | |||
@@ -1104,6 +1104,7 @@ struct sched_dl_entity { | |||
1104 | u64 dl_runtime; /* maximum runtime for each instance */ | 1104 | u64 dl_runtime; /* maximum runtime for each instance */ |
1105 | u64 dl_deadline; /* relative deadline of each instance */ | 1105 | u64 dl_deadline; /* relative deadline of each instance */ |
1106 | u64 dl_period; /* separation of two instances (period) */ | 1106 | u64 dl_period; /* separation of two instances (period) */ |
1107 | u64 dl_bw; /* dl_runtime / dl_deadline */ | ||
1107 | 1108 | ||
1108 | /* | 1109 | /* |
1109 | * Actual scheduling parameters. Initialized with the values above, | 1110 | * Actual scheduling parameters. Initialized with the values above, |
diff --git a/include/linux/sched/sysctl.h b/include/linux/sched/sysctl.h index 31e0193cb0c5..8070a83dbedc 100644 --- a/include/linux/sched/sysctl.h +++ b/include/linux/sched/sysctl.h | |||
@@ -81,6 +81,15 @@ static inline unsigned int get_sysctl_timer_migration(void) | |||
81 | extern unsigned int sysctl_sched_rt_period; | 81 | extern unsigned int sysctl_sched_rt_period; |
82 | extern int sysctl_sched_rt_runtime; | 82 | extern int sysctl_sched_rt_runtime; |
83 | 83 | ||
84 | /* | ||
85 | * control SCHED_DEADLINE reservations: | ||
86 | * | ||
87 | * /proc/sys/kernel/sched_dl_period_us | ||
88 | * /proc/sys/kernel/sched_dl_runtime_us | ||
89 | */ | ||
90 | extern unsigned int sysctl_sched_dl_period; | ||
91 | extern int sysctl_sched_dl_runtime; | ||
92 | |||
84 | #ifdef CONFIG_CFS_BANDWIDTH | 93 | #ifdef CONFIG_CFS_BANDWIDTH |
85 | extern unsigned int sysctl_sched_cfs_bandwidth_slice; | 94 | extern unsigned int sysctl_sched_cfs_bandwidth_slice; |
86 | #endif | 95 | #endif |
@@ -99,4 +108,8 @@ extern int sched_rt_handler(struct ctl_table *table, int write, | |||
99 | void __user *buffer, size_t *lenp, | 108 | void __user *buffer, size_t *lenp, |
100 | loff_t *ppos); | 109 | loff_t *ppos); |
101 | 110 | ||
111 | int sched_dl_handler(struct ctl_table *table, int write, | ||
112 | void __user *buffer, size_t *lenp, | ||
113 | loff_t *ppos); | ||
114 | |||
102 | #endif /* _SCHED_SYSCTL_H */ | 115 | #endif /* _SCHED_SYSCTL_H */ |