blob: 923eaa1ba83b7ceba1612e764f29b0de7899e52e [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __ASM_HARDIRQ_H
2#define __ASM_HARDIRQ_H
3
Linus Torvalds1da177e2005-04-16 15:20:36 -07004#include <linux/cache.h>
5#include <linux/threads.h>
6#include <asm/irq.h>
7
8typedef struct {
9 unsigned int __softirq_pending;
Russell Kingec405ea2010-11-15 13:38:06 +000010#ifdef CONFIG_LOCAL_TIMERS
Russell King37ee16a2005-11-08 19:08:05 +000011 unsigned int local_timer_irqs;
Russell Kingec405ea2010-11-15 13:38:06 +000012#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070013} ____cacheline_aligned irq_cpustat_t;
14
15#include <linux/irq_cpustat.h> /* Standard mappings for irq_cpustat_t above */
16
Russell King46c48f22010-11-15 14:15:03 +000017#define __inc_irq_stat(cpu, member) __IRQ_STAT(cpu, member)++
18#define __get_irq_stat(cpu, member) __IRQ_STAT(cpu, member)
19
Magnus Damm27ada412010-05-19 09:58:27 +010020#if NR_IRQS > 512
21#define HARDIRQ_BITS 10
22#elif NR_IRQS > 256
Linus Torvalds1da177e2005-04-16 15:20:36 -070023#define HARDIRQ_BITS 9
24#else
25#define HARDIRQ_BITS 8
26#endif
27
28/*
29 * The hardirq mask has to be large enough to have space
30 * for potentially all IRQ sources in the system nesting
31 * on a single CPU:
32 */
33#if (1 << HARDIRQ_BITS) < NR_IRQS
34# error HARDIRQ_BITS is too low!
35#endif
36
37#define __ARCH_IRQ_EXIT_IRQS_DISABLED 1
38
39#endif /* __ASM_HARDIRQ_H */