12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- #ifndef _ASM_IRQ_H
- #define _ASM_IRQ_H
- #include <linux/hardirq.h>
- #include <linux/percpu.h>
- #include <linux/cache.h>
- #include <linux/types.h>
- enum interruption_main_class {
- EXTERNAL_INTERRUPT,
- IO_INTERRUPT,
- NR_IRQS
- };
- enum interruption_class {
- IRQEXT_CLK,
- IRQEXT_EXC,
- IRQEXT_EMS,
- IRQEXT_TMR,
- IRQEXT_TLA,
- IRQEXT_PFL,
- IRQEXT_DSD,
- IRQEXT_VRT,
- IRQEXT_SCP,
- IRQEXT_IUC,
- IRQEXT_CMS,
- IRQEXT_CMC,
- IRQEXT_CMR,
- IRQIO_CIO,
- IRQIO_QAI,
- IRQIO_DAS,
- IRQIO_C15,
- IRQIO_C70,
- IRQIO_TAP,
- IRQIO_VMR,
- IRQIO_LCS,
- IRQIO_CLW,
- IRQIO_CTC,
- IRQIO_APB,
- IRQIO_ADM,
- IRQIO_CSC,
- IRQIO_PCI,
- IRQIO_MSI,
- IRQIO_VIR,
- NMI_NMI,
- CPU_RST,
- NR_ARCH_IRQS
- };
- struct irq_stat {
- unsigned int irqs[NR_ARCH_IRQS];
- };
- DECLARE_PER_CPU_SHARED_ALIGNED(struct irq_stat, irq_stat);
- static __always_inline void inc_irq_stat(enum interruption_class irq)
- {
- __get_cpu_var(irq_stat).irqs[irq]++;
- }
- struct ext_code {
- unsigned short subcode;
- unsigned short code;
- };
- typedef void (*ext_int_handler_t)(struct ext_code, unsigned int, unsigned long);
- int register_external_interrupt(u16 code, ext_int_handler_t handler);
- int unregister_external_interrupt(u16 code, ext_int_handler_t handler);
- void service_subclass_irq_register(void);
- void service_subclass_irq_unregister(void);
- void measurement_alert_subclass_register(void);
- void measurement_alert_subclass_unregister(void);
- #ifdef CONFIG_LOCKDEP
- # define disable_irq_nosync_lockdep(irq) disable_irq_nosync(irq)
- # define disable_irq_nosync_lockdep_irqsave(irq, flags) \
- disable_irq_nosync(irq)
- # define disable_irq_lockdep(irq) disable_irq(irq)
- # define enable_irq_lockdep(irq) enable_irq(irq)
- # define enable_irq_lockdep_irqrestore(irq, flags) \
- enable_irq(irq)
- #endif
- #endif /* _ASM_IRQ_H */
|