diff options
author | Lucas De Marchi <lucas.de.marchi@gmail.com> | 2010-03-10 21:37:45 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2010-03-11 09:22:28 -0500 |
commit | 41acab8851a0408c1d5ad6c21a07456f88b54d40 (patch) | |
tree | 28b23b930571c1f6dfd5c4e8129a2a7ea2056307 /kernel/sched_debug.c | |
parent | 3d07467b7aa91623b31d7b5888a123a2c8c8e9cc (diff) |
sched: Implement group scheduler statistics in one struct
Put all statistic fields of sched_entity in one struct, sched_statistics,
and embed it into sched_entity.
This change allows to memset the sched_statistics to 0 when needed (for
instance when forking), avoiding bugs of non initialized fields.
Signed-off-by: Lucas De Marchi <lucas.de.marchi@gmail.com>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
LKML-Reference: <1268275065-18542-1-git-send-email-lucas.de.marchi@gmail.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/sched_debug.c')
-rw-r--r-- | kernel/sched_debug.c | 101 |
1 files changed, 38 insertions, 63 deletions
diff --git a/kernel/sched_debug.c b/kernel/sched_debug.c index 67f95aada4b9..ad9df4422763 100644 --- a/kernel/sched_debug.c +++ b/kernel/sched_debug.c | |||
@@ -70,16 +70,16 @@ static void print_cfs_group_stats(struct seq_file *m, int cpu, | |||
70 | PN(se->vruntime); | 70 | PN(se->vruntime); |
71 | PN(se->sum_exec_runtime); | 71 | PN(se->sum_exec_runtime); |
72 | #ifdef CONFIG_SCHEDSTATS | 72 | #ifdef CONFIG_SCHEDSTATS |
73 | PN(se->wait_start); | 73 | PN(se->statistics.wait_start); |
74 | PN(se->sleep_start); | 74 | PN(se->statistics.sleep_start); |
75 | PN(se->block_start); | 75 | PN(se->statistics.block_start); |
76 | PN(se->sleep_max); | 76 | PN(se->statistics.sleep_max); |
77 | PN(se->block_max); | 77 | PN(se->statistics.block_max); |
78 | PN(se->exec_max); | 78 | PN(se->statistics.exec_max); |
79 | PN(se->slice_max); | 79 | PN(se->statistics.slice_max); |
80 | PN(se->wait_max); | 80 | PN(se->statistics.wait_max); |
81 | PN(se->wait_sum); | 81 | PN(se->statistics.wait_sum); |
82 | P(se->wait_count); | 82 | P(se->statistics.wait_count); |
83 | #endif | 83 | #endif |
84 | P(se->load.weight); | 84 | P(se->load.weight); |
85 | #undef PN | 85 | #undef PN |
@@ -104,7 +104,7 @@ print_task(struct seq_file *m, struct rq *rq, struct task_struct *p) | |||
104 | SEQ_printf(m, "%9Ld.%06ld %9Ld.%06ld %9Ld.%06ld", | 104 | SEQ_printf(m, "%9Ld.%06ld %9Ld.%06ld %9Ld.%06ld", |
105 | SPLIT_NS(p->se.vruntime), | 105 | SPLIT_NS(p->se.vruntime), |
106 | SPLIT_NS(p->se.sum_exec_runtime), | 106 | SPLIT_NS(p->se.sum_exec_runtime), |
107 | SPLIT_NS(p->se.sum_sleep_runtime)); | 107 | SPLIT_NS(p->se.statistics.sum_sleep_runtime)); |
108 | #else | 108 | #else |
109 | SEQ_printf(m, "%15Ld %15Ld %15Ld.%06ld %15Ld.%06ld %15Ld.%06ld", | 109 | SEQ_printf(m, "%15Ld %15Ld %15Ld.%06ld %15Ld.%06ld %15Ld.%06ld", |
110 | 0LL, 0LL, 0LL, 0L, 0LL, 0L, 0LL, 0L); | 110 | 0LL, 0LL, 0LL, 0L, 0LL, 0L, 0LL, 0L); |
@@ -413,34 +413,34 @@ void proc_sched_show_task(struct task_struct *p, struct seq_file *m) | |||
413 | nr_switches = p->nvcsw + p->nivcsw; | 413 | nr_switches = p->nvcsw + p->nivcsw; |
414 | 414 | ||
415 | #ifdef CONFIG_SCHEDSTATS | 415 | #ifdef CONFIG_SCHEDSTATS |
416 | PN(se.wait_start); | 416 | PN(se.statistics.wait_start); |
417 | PN(se.sleep_start); | 417 | PN(se.statistics.sleep_start); |
418 | PN(se.block_start); | 418 | PN(se.statistics.block_start); |
419 | PN(se.sleep_max); | 419 | PN(se.statistics.sleep_max); |
420 | PN(se.block_max); | 420 | PN(se.statistics.block_max); |
421 | PN(se.exec_max); | 421 | PN(se.statistics.exec_max); |
422 | PN(se.slice_max); | 422 | PN(se.statistics.slice_max); |
423 | PN(se.wait_max); | 423 | PN(se.statistics.wait_max); |
424 | PN(se.wait_sum); | 424 | PN(se.statistics.wait_sum); |
425 | P(se.wait_count); | 425 | P(se.statistics.wait_count); |
426 | PN(se.iowait_sum); | 426 | PN(se.statistics.iowait_sum); |
427 | P(se.iowait_count); | 427 | P(se.statistics.iowait_count); |
428 | P(sched_info.bkl_count); | 428 | P(sched_info.bkl_count); |
429 | P(se.nr_migrations); | 429 | P(se.nr_migrations); |
430 | P(se.nr_migrations_cold); | 430 | P(se.statistics.nr_migrations_cold); |
431 | P(se.nr_failed_migrations_affine); | 431 | P(se.statistics.nr_failed_migrations_affine); |
432 | P(se.nr_failed_migrations_running); | 432 | P(se.statistics.nr_failed_migrations_running); |
433 | P(se.nr_failed_migrations_hot); | 433 | P(se.statistics.nr_failed_migrations_hot); |
434 | P(se.nr_forced_migrations); | 434 | P(se.statistics.nr_forced_migrations); |
435 | P(se.nr_wakeups); | 435 | P(se.statistics.nr_wakeups); |
436 | P(se.nr_wakeups_sync); | 436 | P(se.statistics.nr_wakeups_sync); |
437 | P(se.nr_wakeups_migrate); | 437 | P(se.statistics.nr_wakeups_migrate); |
438 | P(se.nr_wakeups_local); | 438 | P(se.statistics.nr_wakeups_local); |
439 | P(se.nr_wakeups_remote); | 439 | P(se.statistics.nr_wakeups_remote); |
440 | P(se.nr_wakeups_affine); | 440 | P(se.statistics.nr_wakeups_affine); |
441 | P(se.nr_wakeups_affine_attempts); | 441 | P(se.statistics.nr_wakeups_affine_attempts); |
442 | P(se.nr_wakeups_passive); | 442 | P(se.statistics.nr_wakeups_passive); |
443 | P(se.nr_wakeups_idle); | 443 | P(se.statistics.nr_wakeups_idle); |
444 | 444 | ||
445 | { | 445 | { |
446 | u64 avg_atom, avg_per_cpu; | 446 | u64 avg_atom, avg_per_cpu; |
@@ -491,32 +491,7 @@ void proc_sched_show_task(struct task_struct *p, struct seq_file *m) | |||
491 | void proc_sched_set_task(struct task_struct *p) | 491 | void proc_sched_set_task(struct task_struct *p) |
492 | { | 492 | { |
493 | #ifdef CONFIG_SCHEDSTATS | 493 | #ifdef CONFIG_SCHEDSTATS |
494 | p->se.wait_max = 0; | 494 | memset(&p->se.statistics, 0, sizeof(p->se.statistics)); |
495 | p->se.wait_sum = 0; | ||
496 | p->se.wait_count = 0; | ||
497 | p->se.iowait_sum = 0; | ||
498 | p->se.iowait_count = 0; | ||
499 | p->se.sleep_max = 0; | ||
500 | p->se.sum_sleep_runtime = 0; | ||
501 | p->se.block_max = 0; | ||
502 | p->se.exec_max = 0; | ||
503 | p->se.slice_max = 0; | ||
504 | p->se.nr_migrations = 0; | ||
505 | p->se.nr_migrations_cold = 0; | ||
506 | p->se.nr_failed_migrations_affine = 0; | ||
507 | p->se.nr_failed_migrations_running = 0; | ||
508 | p->se.nr_failed_migrations_hot = 0; | ||
509 | p->se.nr_forced_migrations = 0; | ||
510 | p->se.nr_wakeups = 0; | ||
511 | p->se.nr_wakeups_sync = 0; | ||
512 | p->se.nr_wakeups_migrate = 0; | ||
513 | p->se.nr_wakeups_local = 0; | ||
514 | p->se.nr_wakeups_remote = 0; | ||
515 | p->se.nr_wakeups_affine = 0; | ||
516 | p->se.nr_wakeups_affine_attempts = 0; | ||
517 | p->se.nr_wakeups_passive = 0; | ||
518 | p->se.nr_wakeups_idle = 0; | ||
519 | p->sched_info.bkl_count = 0; | ||
520 | #endif | 495 | #endif |
521 | p->se.sum_exec_runtime = 0; | 496 | p->se.sum_exec_runtime = 0; |
522 | p->se.prev_sum_exec_runtime = 0; | 497 | p->se.prev_sum_exec_runtime = 0; |