diff options
author | Nikhil Rao <ncrao@google.com> | 2011-07-21 12:43:40 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2011-08-14 06:03:49 -0400 |
commit | e8da1b18b32064c43881bceef0f051c2110c9ab9 (patch) | |
tree | 8d6e9e5713c1da4cee3ceba1da67df6cab22ab9f /kernel/sched.c | |
parent | d3d9dc3302368269acf94b7381663b93000fe2fe (diff) |
sched: Add exports tracking cfs bandwidth control statistics
This change introduces statistics exports for the cpu sub-system, these are
added through the use of a stat file similar to that exported by other
subsystems.
The following exports are included:
nr_periods: number of periods in which execution occurred
nr_throttled: the number of periods above in which execution was throttle
throttled_time: cumulative wall-time that any cpus have been throttled for
this group
Signed-off-by: Paul Turner <pjt@google.com>
Signed-off-by: Nikhil Rao <ncrao@google.com>
Signed-off-by: Bharata B Rao <bharata@linux.vnet.ibm.com>
Reviewed-by: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/20110721184758.198901931@google.com
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/sched.c')
-rw-r--r-- | kernel/sched.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/kernel/sched.c b/kernel/sched.c index 397317248ddd..35c91859f8a6 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
@@ -262,6 +262,9 @@ struct cfs_bandwidth { | |||
262 | struct hrtimer period_timer; | 262 | struct hrtimer period_timer; |
263 | struct list_head throttled_cfs_rq; | 263 | struct list_head throttled_cfs_rq; |
264 | 264 | ||
265 | /* statistics */ | ||
266 | int nr_periods, nr_throttled; | ||
267 | u64 throttled_time; | ||
265 | #endif | 268 | #endif |
266 | }; | 269 | }; |
267 | 270 | ||
@@ -402,6 +405,7 @@ struct cfs_rq { | |||
402 | u64 runtime_expires; | 405 | u64 runtime_expires; |
403 | s64 runtime_remaining; | 406 | s64 runtime_remaining; |
404 | 407 | ||
408 | u64 throttled_timestamp; | ||
405 | int throttled, throttle_count; | 409 | int throttled, throttle_count; |
406 | struct list_head throttled_list; | 410 | struct list_head throttled_list; |
407 | #endif | 411 | #endif |
@@ -9397,6 +9401,19 @@ static int __cfs_schedulable(struct task_group *tg, u64 period, u64 quota) | |||
9397 | 9401 | ||
9398 | return ret; | 9402 | return ret; |
9399 | } | 9403 | } |
9404 | |||
9405 | static int cpu_stats_show(struct cgroup *cgrp, struct cftype *cft, | ||
9406 | struct cgroup_map_cb *cb) | ||
9407 | { | ||
9408 | struct task_group *tg = cgroup_tg(cgrp); | ||
9409 | struct cfs_bandwidth *cfs_b = tg_cfs_bandwidth(tg); | ||
9410 | |||
9411 | cb->fill(cb, "nr_periods", cfs_b->nr_periods); | ||
9412 | cb->fill(cb, "nr_throttled", cfs_b->nr_throttled); | ||
9413 | cb->fill(cb, "throttled_time", cfs_b->throttled_time); | ||
9414 | |||
9415 | return 0; | ||
9416 | } | ||
9400 | #endif /* CONFIG_CFS_BANDWIDTH */ | 9417 | #endif /* CONFIG_CFS_BANDWIDTH */ |
9401 | #endif /* CONFIG_FAIR_GROUP_SCHED */ | 9418 | #endif /* CONFIG_FAIR_GROUP_SCHED */ |
9402 | 9419 | ||
@@ -9443,6 +9460,10 @@ static struct cftype cpu_files[] = { | |||
9443 | .read_u64 = cpu_cfs_period_read_u64, | 9460 | .read_u64 = cpu_cfs_period_read_u64, |
9444 | .write_u64 = cpu_cfs_period_write_u64, | 9461 | .write_u64 = cpu_cfs_period_write_u64, |
9445 | }, | 9462 | }, |
9463 | { | ||
9464 | .name = "stat", | ||
9465 | .read_map = cpu_stats_show, | ||
9466 | }, | ||
9446 | #endif | 9467 | #endif |
9447 | #ifdef CONFIG_RT_GROUP_SCHED | 9468 | #ifdef CONFIG_RT_GROUP_SCHED |
9448 | { | 9469 | { |