diff options
author | Kirill Tkhai <tkhai@yandex.ru> | 2014-03-14 18:14:49 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2014-04-18 06:07:25 -0400 |
commit | 22abdef37cebcdd4933c72339401a174b7d87768 (patch) | |
tree | b97925c04883e92c563e81b02a3f803fd838bb42 /kernel/sched | |
parent | 8698a745d800c59cd5a576398bdeccd578ac66f1 (diff) |
sched/rt: Sum number of all children tasks in hierarhy at ->rt_nr_running
{inc,dec}_rt_tasks() used to count entities which are directly queued
on the rt_rq. If an entity was not a task (i.e., it is some queue), its
children were not counted.
There is no problem here, but now we want to count number of all tasks
which are actually queued under the rt_rq in all the hierarchy (except
throttled rt queues).
Empty queues are not able to be queued and all of the places, which
use ->rt_nr_running, just compare it with zero, so we do not break
anything here.
Signed-off-by: Kirill Tkhai <tkhai@yandex.ru>
Reviewed-by: Preeti U Murthy <preeti@linux.vnet.ibm.com>
Signed-off-by: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1394835289.18748.31.camel@HP-250-G1-Notebook-PC
Cc: linux-kernel@vger.kernel.org
[ Twiddled the changelog. ]
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel/sched')
-rw-r--r-- | kernel/sched/rt.c | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/kernel/sched/rt.c b/kernel/sched/rt.c index 1e4992eb5166..6892ed7d644b 100644 --- a/kernel/sched/rt.c +++ b/kernel/sched/rt.c | |||
@@ -1045,12 +1045,23 @@ void dec_rt_group(struct sched_rt_entity *rt_se, struct rt_rq *rt_rq) {} | |||
1045 | #endif /* CONFIG_RT_GROUP_SCHED */ | 1045 | #endif /* CONFIG_RT_GROUP_SCHED */ |
1046 | 1046 | ||
1047 | static inline | 1047 | static inline |
1048 | unsigned int rt_se_nr_running(struct sched_rt_entity *rt_se) | ||
1049 | { | ||
1050 | struct rt_rq *group_rq = group_rt_rq(rt_se); | ||
1051 | |||
1052 | if (group_rq) | ||
1053 | return group_rq->rt_nr_running; | ||
1054 | else | ||
1055 | return 1; | ||
1056 | } | ||
1057 | |||
1058 | static inline | ||
1048 | void inc_rt_tasks(struct sched_rt_entity *rt_se, struct rt_rq *rt_rq) | 1059 | void inc_rt_tasks(struct sched_rt_entity *rt_se, struct rt_rq *rt_rq) |
1049 | { | 1060 | { |
1050 | int prio = rt_se_prio(rt_se); | 1061 | int prio = rt_se_prio(rt_se); |
1051 | 1062 | ||
1052 | WARN_ON(!rt_prio(prio)); | 1063 | WARN_ON(!rt_prio(prio)); |
1053 | rt_rq->rt_nr_running++; | 1064 | rt_rq->rt_nr_running += rt_se_nr_running(rt_se); |
1054 | 1065 | ||
1055 | inc_rt_prio(rt_rq, prio); | 1066 | inc_rt_prio(rt_rq, prio); |
1056 | inc_rt_migration(rt_se, rt_rq); | 1067 | inc_rt_migration(rt_se, rt_rq); |
@@ -1062,7 +1073,7 @@ void dec_rt_tasks(struct sched_rt_entity *rt_se, struct rt_rq *rt_rq) | |||
1062 | { | 1073 | { |
1063 | WARN_ON(!rt_prio(rt_se_prio(rt_se))); | 1074 | WARN_ON(!rt_prio(rt_se_prio(rt_se))); |
1064 | WARN_ON(!rt_rq->rt_nr_running); | 1075 | WARN_ON(!rt_rq->rt_nr_running); |
1065 | rt_rq->rt_nr_running--; | 1076 | rt_rq->rt_nr_running -= rt_se_nr_running(rt_se); |
1066 | 1077 | ||
1067 | dec_rt_prio(rt_rq, rt_se_prio(rt_se)); | 1078 | dec_rt_prio(rt_rq, rt_se_prio(rt_se)); |
1068 | dec_rt_migration(rt_se, rt_rq); | 1079 | dec_rt_migration(rt_se, rt_rq); |