1 /*- 2 * Copyright (c) 2010 Isilon Systems, Inc. 3 * Copyright (c) 2010 iX Systems, Inc. 4 * Copyright (c) 2010 Panasas, Inc. 5 * Copyright (c) 2013-2015 Mellanox Technologies, Ltd. 6 * All rights reserved. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice unmodified, this list of conditions, and the following 13 * disclaimer. 14 * 2. Redistributions in binary form must reproduce the above copyright 15 * notice, this list of conditions and the following disclaimer in the 16 * documentation and/or other materials provided with the distribution. 17 * 18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 * 29 * $FreeBSD$ 30 */ 31 #ifndef _LINUXKPI_LINUX_INTERRUPT_H_ 32 #define _LINUXKPI_LINUX_INTERRUPT_H_ 33 34 #include "linux/kernel.h" 35 #include "los_base.h" 36 #include "linux/workqueue.h" 37 38 #ifdef __cplusplus 39 #if __cplusplus 40 extern "C" { 41 #endif /* __cplusplus */ 42 #endif /* __cplusplus */ 43 44 #define IRQ_RETVAL(x) ((x) != IRQ_NONE) 45 46 /** 47 * These correspond to the IORESOURCE_IRQ_* defines in 48 * linux/ioport.h to select the interrupt line behaviour. 49 */ 50 #define IRQF_TRIGGER_LOW 0x00000008 51 #define IRQF_TRIGGER_HIGH 0x00000004 52 #define IRQF_TRIGGER_FALLING 0x00000002 53 #define IRQF_TRIGGER_RISING 0x00000001 54 #define IRQF_TRIGGER_NONE 0x00000000 55 #define IRQF_TRIGGER_MASK (IRQF_TRIGGER_HIGH | IRQF_TRIGGER_LOW | \ 56 IRQF_TRIGGER_RISING | IRQF_TRIGGER_FALLING) 57 #define IRQF_PROBE_SHARED 0x00000100 58 59 #define IRQ_DEFAULT_PRIORITY 0x0 60 61 typedef enum irqreturn { 62 IRQ_NONE = (0U << 0), /* interrupt was not from this device. */ 63 IRQ_HANDLED = (1U << 0), /* interrupt was handled by this device. */ 64 IRQ_WAKE_THREAD = (1U << 1) /* handler requests to wake the handler thread. */ 65 } irqreturn_t; 66 67 typedef irqreturn_t (*irq_handler_t)(int, void *); 68 typedef void (*irq_bottom_half_handler_t)(struct work_struct *); 69 70 typedef struct irq_args { 71 int iIrq; 72 void *pDevId; 73 const char *pName; 74 } irq_args; 75 76 #define request_irq(irq, handler, flags, name, dev) \ 77 linux_request_irq(irq, handler, flags, name, dev) 78 79 #define free_irq(irq, dev_id) \ 80 linux_free_irq(irq, dev_id) 81 82 #define enable_irq(irq) \ 83 linux_enable_irq(irq) 84 85 #define disable_irq(irq) \ 86 linux_disable_irq(irq) 87 88 extern int linux_request_irq(unsigned int irq, irq_handler_t handler, unsigned long flags, 89 const char *name, void *dev); 90 extern void linux_free_irq(unsigned int irq, void *dev_id); 91 extern void linux_enable_irq(unsigned int irq); 92 extern void linux_disable_irq(unsigned int irq); 93 94 #ifdef WORKQUEUE_SUPPORT_PRIORITY 95 extern bool irq_bottom_half(struct workqueue_struct *workQueue, irq_bottom_half_handler_t handler, void *data, 96 unsigned int pri); 97 #else 98 extern bool irq_bottom_half(struct workqueue_struct *workQueue, irq_bottom_half_handler_t handler, void *data); 99 #endif 100 101 #ifdef __cplusplus 102 #if __cplusplus 103 } 104 #endif /* __cplusplus */ 105 #endif /* __cplusplus */ 106 107 #endif /* _LINUXKPI_LINUX_INTERRUPT_H_ */ 108