xref: /openbmc/linux/arch/arm/include/asm/hardirq.h (revision b54992fe)
14baa9922SRussell King #ifndef __ASM_HARDIRQ_H
24baa9922SRussell King #define __ASM_HARDIRQ_H
34baa9922SRussell King 
44baa9922SRussell King #include <linux/cache.h>
54baa9922SRussell King #include <linux/threads.h>
64baa9922SRussell King #include <asm/irq.h>
74baa9922SRussell King 
84a88abd7SRussell King #define NR_IPI	5
94a88abd7SRussell King 
104baa9922SRussell King typedef struct {
114baa9922SRussell King 	unsigned int __softirq_pending;
12ec405ea9SRussell King #ifdef CONFIG_LOCAL_TIMERS
134baa9922SRussell King 	unsigned int local_timer_irqs;
14ec405ea9SRussell King #endif
15cab8c6f3SRussell King #ifdef CONFIG_SMP
164a88abd7SRussell King 	unsigned int ipi_irqs[NR_IPI];
17cab8c6f3SRussell King #endif
184baa9922SRussell King } ____cacheline_aligned irq_cpustat_t;
194baa9922SRussell King 
204baa9922SRussell King #include <linux/irq_cpustat.h>	/* Standard mappings for irq_cpustat_t above */
214baa9922SRussell King 
2246c48f22SRussell King #define __inc_irq_stat(cpu, member)	__IRQ_STAT(cpu, member)++
2346c48f22SRussell King #define __get_irq_stat(cpu, member)	__IRQ_STAT(cpu, member)
2446c48f22SRussell King 
25b54992feSRussell King #ifdef CONFIG_SMP
26b54992feSRussell King u64 smp_irq_stat_cpu(unsigned int cpu);
27b54992feSRussell King #else
28b54992feSRussell King #define smp_irq_stat_cpu(cpu)	0
29b54992feSRussell King #endif
30b54992feSRussell King 
31b54992feSRussell King #define arch_irq_stat_cpu	smp_irq_stat_cpu
32b54992feSRussell King 
3327ada410SMagnus Damm #if NR_IRQS > 512
3427ada410SMagnus Damm #define HARDIRQ_BITS	10
3527ada410SMagnus Damm #elif NR_IRQS > 256
364baa9922SRussell King #define HARDIRQ_BITS	9
374baa9922SRussell King #else
384baa9922SRussell King #define HARDIRQ_BITS	8
394baa9922SRussell King #endif
404baa9922SRussell King 
414baa9922SRussell King /*
424baa9922SRussell King  * The hardirq mask has to be large enough to have space
434baa9922SRussell King  * for potentially all IRQ sources in the system nesting
444baa9922SRussell King  * on a single CPU:
454baa9922SRussell King  */
464baa9922SRussell King #if (1 << HARDIRQ_BITS) < NR_IRQS
474baa9922SRussell King # error HARDIRQ_BITS is too low!
484baa9922SRussell King #endif
494baa9922SRussell King 
504baa9922SRussell King #define __ARCH_IRQ_EXIT_IRQS_DISABLED	1
514baa9922SRussell King 
524baa9922SRussell King #endif /* __ASM_HARDIRQ_H */
53