blob: 5f8bcc5fe423abc27f64064cf1602a2ecff370a3 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _ASM_IRQ_H
2#define _ASM_IRQ_H
3
Martin Schwidefsky1f44a222013-06-27 09:01:09 +02004#define EXT_INTERRUPT 1
5#define IO_INTERRUPT 2
6#define THIN_INTERRUPT 3
7
8#define NR_IRQS_BASE 4
9
10#ifdef CONFIG_PCI_NR_MSI
11# define NR_IRQS (NR_IRQS_BASE + CONFIG_PCI_NR_MSI)
12#else
13# define NR_IRQS NR_IRQS_BASE
14#endif
15
16/* This number is used when no interrupt has been assigned */
17#define NO_IRQ 0
18
19#ifndef __ASSEMBLY__
20
Linus Torvalds1da177e2005-04-16 15:20:36 -070021#include <linux/hardirq.h>
Heiko Carstens420f42e2013-01-02 15:18:18 +010022#include <linux/percpu.h>
23#include <linux/cache.h>
Heiko Carstensd7b250e2011-05-26 09:48:24 +020024#include <linux/types.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070025
Heiko Carstens420f42e2013-01-02 15:18:18 +010026enum interruption_class {
27 IRQEXT_CLK,
28 IRQEXT_EXC,
29 IRQEXT_EMS,
30 IRQEXT_TMR,
31 IRQEXT_TLA,
32 IRQEXT_PFL,
33 IRQEXT_DSD,
34 IRQEXT_VRT,
35 IRQEXT_SCP,
36 IRQEXT_IUC,
37 IRQEXT_CMS,
38 IRQEXT_CMC,
39 IRQEXT_CMR,
40 IRQIO_CIO,
41 IRQIO_QAI,
42 IRQIO_DAS,
43 IRQIO_C15,
44 IRQIO_C70,
45 IRQIO_TAP,
46 IRQIO_VMR,
47 IRQIO_LCS,
48 IRQIO_CLW,
49 IRQIO_CTC,
50 IRQIO_APB,
51 IRQIO_ADM,
52 IRQIO_CSC,
53 IRQIO_PCI,
54 IRQIO_MSI,
Linus Torvalds89f88332013-02-24 13:07:18 -080055 IRQIO_VIR,
Heiko Carstens420f42e2013-01-02 15:18:18 +010056 NMI_NMI,
Heiko Carstens93f3b2e2013-01-02 16:54:12 +010057 CPU_RST,
Heiko Carstens420f42e2013-01-02 15:18:18 +010058 NR_ARCH_IRQS
59};
60
61struct irq_stat {
62 unsigned int irqs[NR_ARCH_IRQS];
63};
64
65DECLARE_PER_CPU_SHARED_ALIGNED(struct irq_stat, irq_stat);
66
67static __always_inline void inc_irq_stat(enum interruption_class irq)
68{
69 __get_cpu_var(irq_stat).irqs[irq]++;
70}
71
Heiko Carstensfde15c32012-03-11 11:59:31 -040072struct ext_code {
73 unsigned short subcode;
74 unsigned short code;
75};
76
77typedef void (*ext_int_handler_t)(struct ext_code, unsigned int, unsigned long);
Heiko Carstensd7b250e2011-05-26 09:48:24 +020078
79int register_external_interrupt(u16 code, ext_int_handler_t handler);
80int unregister_external_interrupt(u16 code, ext_int_handler_t handler);
Heiko Carstens82003c32013-09-04 13:35:45 +020081
82enum irq_subclass {
83 IRQ_SUBCLASS_MEASUREMENT_ALERT = 5,
84 IRQ_SUBCLASS_SERVICE_SIGNAL = 9,
85};
86
87void irq_subclass_register(enum irq_subclass subclass);
88void irq_subclass_unregister(enum irq_subclass subclass);
Heiko Carstensd7b250e2011-05-26 09:48:24 +020089
Martin Schwidefsky1f44a222013-06-27 09:01:09 +020090#define irq_canonicalize(irq) (irq)
91
92#endif /* __ASSEMBLY__ */
Jan Glauber9a4da8a2012-11-29 13:05:05 +010093
Heiko Carstens052ff462011-01-05 12:47:28 +010094#endif /* _ASM_IRQ_H */