xref: /openbmc/linux/fs/proc/softirqs.c (revision ef1d6178)
1b2441318SGreg Kroah-Hartman // SPDX-License-Identifier: GPL-2.0
2d3d64df2SKeika Kobayashi #include <linux/init.h>
3d3d64df2SKeika Kobayashi #include <linux/kernel_stat.h>
4d3d64df2SKeika Kobayashi #include <linux/proc_fs.h>
5d3d64df2SKeika Kobayashi #include <linux/seq_file.h>
6*ef1d6178SAlexey Dobriyan #include "internal.h"
7d3d64df2SKeika Kobayashi 
8d3d64df2SKeika Kobayashi /*
9d3d64df2SKeika Kobayashi  * /proc/softirqs  ... display the number of softirqs
10d3d64df2SKeika Kobayashi  */
show_softirqs(struct seq_file * p,void * v)11d3d64df2SKeika Kobayashi static int show_softirqs(struct seq_file *p, void *v)
12d3d64df2SKeika Kobayashi {
13d3d64df2SKeika Kobayashi 	int i, j;
14d3d64df2SKeika Kobayashi 
159d6de12fSAlexey Dobriyan 	seq_puts(p, "                    ");
16d3d64df2SKeika Kobayashi 	for_each_possible_cpu(i)
17d3d64df2SKeika Kobayashi 		seq_printf(p, "CPU%-8d", i);
189d6de12fSAlexey Dobriyan 	seq_putc(p, '\n');
19d3d64df2SKeika Kobayashi 
20d3d64df2SKeika Kobayashi 	for (i = 0; i < NR_SOFTIRQS; i++) {
2119cd56c4SDavidlohr Bueso 		seq_printf(p, "%12s:", softirq_to_name[i]);
22d3d64df2SKeika Kobayashi 		for_each_possible_cpu(j)
23d3d64df2SKeika Kobayashi 			seq_printf(p, " %10u", kstat_softirqs_cpu(i, j));
249d6de12fSAlexey Dobriyan 		seq_putc(p, '\n');
25d3d64df2SKeika Kobayashi 	}
26d3d64df2SKeika Kobayashi 	return 0;
27d3d64df2SKeika Kobayashi }
28d3d64df2SKeika Kobayashi 
proc_softirqs_init(void)29d3d64df2SKeika Kobayashi static int __init proc_softirqs_init(void)
30d3d64df2SKeika Kobayashi {
31*ef1d6178SAlexey Dobriyan 	struct proc_dir_entry *pde;
32*ef1d6178SAlexey Dobriyan 
33*ef1d6178SAlexey Dobriyan 	pde = proc_create_single("softirqs", 0, NULL, show_softirqs);
34*ef1d6178SAlexey Dobriyan 	pde_make_permanent(pde);
35d3d64df2SKeika Kobayashi 	return 0;
36d3d64df2SKeika Kobayashi }
37abaf3787SPaul Gortmaker fs_initcall(proc_softirqs_init);
38