aboutsummaryrefslogtreecommitdiffstats
path: root/fs/proc/proc_misc.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/proc/proc_misc.c')
-rw-r--r--fs/proc/proc_misc.c43
1 files changed, 5 insertions, 38 deletions
diff --git a/fs/proc/proc_misc.c b/fs/proc/proc_misc.c
index d68c3592fe4a..3f5c7b9d1a70 100644
--- a/fs/proc/proc_misc.c
+++ b/fs/proc/proc_misc.c
@@ -529,13 +529,10 @@ static int show_stat(struct seq_file *p, void *v)
529 softirq = cputime64_add(softirq, kstat_cpu(i).cpustat.softirq); 529 softirq = cputime64_add(softirq, kstat_cpu(i).cpustat.softirq);
530 steal = cputime64_add(steal, kstat_cpu(i).cpustat.steal); 530 steal = cputime64_add(steal, kstat_cpu(i).cpustat.steal);
531 guest = cputime64_add(guest, kstat_cpu(i).cpustat.guest); 531 guest = cputime64_add(guest, kstat_cpu(i).cpustat.guest);
532
532 for_each_irq_desc(j, desc) 533 for_each_irq_desc(j, desc)
533 { 534 sum += kstat_irqs_cpu(j, i);
534 unsigned int temp;
535 535
536 temp = kstat_irqs_cpu(j, i);
537 sum += temp;
538 }
539 sum += arch_irq_stat_cpu(i); 536 sum += arch_irq_stat_cpu(i);
540 } 537 }
541 sum += arch_irq_stat(); 538 sum += arch_irq_stat();
@@ -578,21 +575,13 @@ static int show_stat(struct seq_file *p, void *v)
578 seq_printf(p, "intr %llu", (unsigned long long)sum); 575 seq_printf(p, "intr %llu", (unsigned long long)sum);
579 576
580 /* sum again ? it could be updated? */ 577 /* sum again ? it could be updated? */
581 for_each_irq_desc(j, desc) 578 for_each_irq_desc(j, desc) {
582 {
583 per_irq_sum = 0; 579 per_irq_sum = 0;
584 for_each_possible_cpu(i) {
585 unsigned int temp;
586 580
587 temp = kstat_irqs_cpu(j, i); 581 for_each_possible_cpu(i)
588 per_irq_sum += temp; 582 per_irq_sum += kstat_irqs_cpu(j, i);
589 }
590 583
591#ifdef CONFIG_HAVE_SPARSE_IRQ
592 seq_printf(p, " %#x:%u", j, per_irq_sum);
593#else
594 seq_printf(p, " %u", per_irq_sum); 584 seq_printf(p, " %u", per_irq_sum);
595#endif
596 } 585 }
597 586
598 seq_printf(p, 587 seq_printf(p,
@@ -645,36 +634,14 @@ static const struct file_operations proc_stat_operations = {
645 */ 634 */
646static void *int_seq_start(struct seq_file *f, loff_t *pos) 635static void *int_seq_start(struct seq_file *f, loff_t *pos)
647{ 636{
648#ifdef CONFIG_HAVE_SPARSE_IRQ
649 struct irq_desc *desc;
650 int irq;
651 int count = *pos;
652
653 for_each_irq_desc(irq, desc) {
654 if (count-- == 0)
655 return desc;
656 }
657
658 return NULL;
659#else
660 return (*pos <= nr_irqs) ? pos : NULL; 637 return (*pos <= nr_irqs) ? pos : NULL;
661#endif
662} 638}
663 639
664 640
665static void *int_seq_next(struct seq_file *f, void *v, loff_t *pos) 641static void *int_seq_next(struct seq_file *f, void *v, loff_t *pos)
666{ 642{
667#ifdef CONFIG_HAVE_SPARSE_IRQ
668 struct irq_desc *desc;
669
670 desc = ((struct irq_desc *)v)->next;
671 (*pos)++;
672
673 return desc;
674#else
675 (*pos)++; 643 (*pos)++;
676 return (*pos <= nr_irqs) ? pos : NULL; 644 return (*pos <= nr_irqs) ? pos : NULL;
677#endif
678} 645}
679 646
680static void int_seq_stop(struct seq_file *f, void *v) 647static void int_seq_stop(struct seq_file *f, void *v)