diff options
author | Daniel Bristot de Oliveira <bristot@redhat.com> | 2017-06-26 11:07:14 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2017-06-30 03:32:07 -0400 |
commit | 48365b38849fdb1ee6dc65beac044ca59f669683 (patch) | |
tree | 857ce08a75d008ea32dc44c96dcb61dc75966822 | |
parent | ff801b716effd652f420204eddb36f6e4a716819 (diff) |
sched/debug: Expose the number of RT/DL tasks that can migrate
Add the value of the rt_rq.rt_nr_migratory and dl_rq.dl_nr_migratory
to the sched_debug output, for instance:
rt_rq[0]:
.rt_nr_running : 2
.rt_nr_migratory : 1 <--- Like this
.rt_throttled : 0
.rt_time : 828.645877
.rt_runtime : 1000.000000
This is useful to debug problems related to the RT/DL schedulers.
This also fixes the format of some variables, that were unsigned, rather
than signed.
Signed-off-by: Daniel Bristot de Oliveira <bristot@redhat.com>
Cc: Clark Williams <williams@redhat.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Luis Claudio R. Goncalves <lgoncalv@redhat.com>
Cc: Luiz Capitulino <lcapitulino@redhat.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: linux-rt-users <linux-rt-users@vger.kernel.org>
Link: http://lkml.kernel.org/r/7896f71cada54ee7dd8507bb666063a2e051c3d4.1498482127.git.bristot@redhat.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r-- | kernel/sched/debug.c | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/kernel/sched/debug.c b/kernel/sched/debug.c index 38f019324f1a..4fa66de52bd6 100644 --- a/kernel/sched/debug.c +++ b/kernel/sched/debug.c | |||
@@ -552,15 +552,21 @@ void print_rt_rq(struct seq_file *m, int cpu, struct rt_rq *rt_rq) | |||
552 | 552 | ||
553 | #define P(x) \ | 553 | #define P(x) \ |
554 | SEQ_printf(m, " .%-30s: %Ld\n", #x, (long long)(rt_rq->x)) | 554 | SEQ_printf(m, " .%-30s: %Ld\n", #x, (long long)(rt_rq->x)) |
555 | #define PU(x) \ | ||
556 | SEQ_printf(m, " .%-30s: %lu\n", #x, (unsigned long)(rt_rq->x)) | ||
555 | #define PN(x) \ | 557 | #define PN(x) \ |
556 | SEQ_printf(m, " .%-30s: %Ld.%06ld\n", #x, SPLIT_NS(rt_rq->x)) | 558 | SEQ_printf(m, " .%-30s: %Ld.%06ld\n", #x, SPLIT_NS(rt_rq->x)) |
557 | 559 | ||
558 | P(rt_nr_running); | 560 | PU(rt_nr_running); |
561 | #ifdef CONFIG_SMP | ||
562 | PU(rt_nr_migratory); | ||
563 | #endif | ||
559 | P(rt_throttled); | 564 | P(rt_throttled); |
560 | PN(rt_time); | 565 | PN(rt_time); |
561 | PN(rt_runtime); | 566 | PN(rt_runtime); |
562 | 567 | ||
563 | #undef PN | 568 | #undef PN |
569 | #undef PU | ||
564 | #undef P | 570 | #undef P |
565 | } | 571 | } |
566 | 572 | ||
@@ -569,14 +575,21 @@ void print_dl_rq(struct seq_file *m, int cpu, struct dl_rq *dl_rq) | |||
569 | struct dl_bw *dl_bw; | 575 | struct dl_bw *dl_bw; |
570 | 576 | ||
571 | SEQ_printf(m, "\ndl_rq[%d]:\n", cpu); | 577 | SEQ_printf(m, "\ndl_rq[%d]:\n", cpu); |
572 | SEQ_printf(m, " .%-30s: %ld\n", "dl_nr_running", dl_rq->dl_nr_running); | 578 | |
579 | #define PU(x) \ | ||
580 | SEQ_printf(m, " .%-30s: %lu\n", #x, (unsigned long)(dl_rq->x)) | ||
581 | |||
582 | PU(dl_nr_running); | ||
573 | #ifdef CONFIG_SMP | 583 | #ifdef CONFIG_SMP |
584 | PU(dl_nr_migratory); | ||
574 | dl_bw = &cpu_rq(cpu)->rd->dl_bw; | 585 | dl_bw = &cpu_rq(cpu)->rd->dl_bw; |
575 | #else | 586 | #else |
576 | dl_bw = &dl_rq->dl_bw; | 587 | dl_bw = &dl_rq->dl_bw; |
577 | #endif | 588 | #endif |
578 | SEQ_printf(m, " .%-30s: %lld\n", "dl_bw->bw", dl_bw->bw); | 589 | SEQ_printf(m, " .%-30s: %lld\n", "dl_bw->bw", dl_bw->bw); |
579 | SEQ_printf(m, " .%-30s: %lld\n", "dl_bw->total_bw", dl_bw->total_bw); | 590 | SEQ_printf(m, " .%-30s: %lld\n", "dl_bw->total_bw", dl_bw->total_bw); |
591 | |||
592 | #undef PU | ||
580 | } | 593 | } |
581 | 594 | ||
582 | extern __read_mostly int sched_clock_running; | 595 | extern __read_mostly int sched_clock_running; |