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>
6ef1d6178SAlexey 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)
23*fe8c4081SDavid Wang seq_put_decimal_ull_width(p, " ", kstat_softirqs_cpu(i, j), 10);
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 {
31ef1d6178SAlexey Dobriyan struct proc_dir_entry *pde;
32ef1d6178SAlexey Dobriyan
33ef1d6178SAlexey Dobriyan pde = proc_create_single("softirqs", 0, NULL, show_softirqs);
34ef1d6178SAlexey Dobriyan pde_make_permanent(pde);
35d3d64df2SKeika Kobayashi return 0;
36d3d64df2SKeika Kobayashi }
37abaf3787SPaul Gortmaker fs_initcall(proc_softirqs_init);
38