aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/irq.h7
-rw-r--r--include/linux/kernel_stat.h22
2 files changed, 22 insertions, 7 deletions
diff --git a/include/linux/irq.h b/include/linux/irq.h
index 60c856aaac0f..cbf471aee1ce 100644
--- a/include/linux/irq.h
+++ b/include/linux/irq.h
@@ -158,6 +158,11 @@ struct irq_desc {
158 struct irq_desc *next; 158 struct irq_desc *next;
159 struct timer_rand_state *timer_rand_state; 159 struct timer_rand_state *timer_rand_state;
160#endif 160#endif
161#ifdef CONFIG_HAVE_DYN_ARRAY
162 unsigned int *kstat_irqs;
163#else
164 unsigned int kstat_irqs[NR_CPUS];
165#endif
161 irq_flow_handler_t handle_irq; 166 irq_flow_handler_t handle_irq;
162 struct irq_chip *chip; 167 struct irq_chip *chip;
163 struct msi_desc *msi_desc; 168 struct msi_desc *msi_desc;
@@ -190,6 +195,8 @@ extern struct irq_desc *irq_to_desc(unsigned int irq);
190/* could be removed if we get rid of all irq_desc reference */ 195/* could be removed if we get rid of all irq_desc reference */
191extern struct irq_desc irq_desc[NR_IRQS]; 196extern struct irq_desc irq_desc[NR_IRQS];
192#endif 197#endif
198#define kstat_irqs_this_cpu(DESC) \
199 ((DESC)->kstat_irqs[smp_processor_id()])
193 200
194/* 201/*
195 * Migration helpers for obsolete names, they will go away: 202 * Migration helpers for obsolete names, they will go away:
diff --git a/include/linux/kernel_stat.h b/include/linux/kernel_stat.h
index fe1f7fe534b4..f10616712de5 100644
--- a/include/linux/kernel_stat.h
+++ b/include/linux/kernel_stat.h
@@ -28,10 +28,8 @@ struct cpu_usage_stat {
28 28
29struct kernel_stat { 29struct kernel_stat {
30 struct cpu_usage_stat cpustat; 30 struct cpu_usage_stat cpustat;
31#ifdef CONFIG_HAVE_DYN_ARRAY 31#ifndef CONFIG_GENERIC_HARDIRQS
32 unsigned int *irqs; 32 unsigned int irqs[NR_IRQS];
33#else
34 unsigned int irqs[NR_IRQS];
35#endif 33#endif
36}; 34};
37 35
@@ -43,15 +41,25 @@ DECLARE_PER_CPU(struct kernel_stat, kstat);
43 41
44extern unsigned long long nr_context_switches(void); 42extern unsigned long long nr_context_switches(void);
45 43
44#ifndef CONFIG_GENERIC_HARDIRQS
45static inline unsigned int kstat_irqs_cpu(unsigned int irq, int cpu)
46{
47 return kstat_cpu(cpu).irqs[irq];
48}
49#else
50extern unsigned int kstat_irqs_cpu(unsigned int irq, int cpu);
51#endif
52
46/* 53/*
47 * Number of interrupts per specific IRQ source, since bootup 54 * Number of interrupts per specific IRQ source, since bootup
48 */ 55 */
49static inline int kstat_irqs(int irq) 56static inline unsigned int kstat_irqs(unsigned int irq)
50{ 57{
51 int cpu, sum = 0; 58 unsigned int sum = 0;
59 int cpu;
52 60
53 for_each_possible_cpu(cpu) 61 for_each_possible_cpu(cpu)
54 sum += kstat_cpu(cpu).irqs[irq]; 62 sum += kstat_irqs_cpu(irq, cpu);
55 63
56 return sum; 64 return sum;
57} 65}