commit 0fefae8354e9045e720def1233bfe51592e2dc90 Author: Lars-Peter Clausen Date: Thu Mar 31 19:47:41 2011 +0200 IRQF_NOAUTOEN diff --git a/include/linux/interrupt.h b/include/linux/interrupt.h index 943c9b5..d596640 100644 --- a/include/linux/interrupt.h +++ b/include/linux/interrupt.h @@ -59,6 +59,7 @@ * IRQF_NO_SUSPEND - Do not disable this IRQ during suspend * IRQF_FORCE_RESUME - Force enable it on resume even if IRQF_NO_SUSPEND is set * IRQF_NO_THREAD - Interrupt cannot be threaded + * IRQF_NOAUTOEN - Do not enable the interrupt on request */ #define IRQF_DISABLED 0x00000020 #define IRQF_SAMPLE_RANDOM 0x00000040 @@ -72,6 +73,7 @@ #define IRQF_NO_SUSPEND 0x00004000 #define IRQF_FORCE_RESUME 0x00008000 #define IRQF_NO_THREAD 0x00010000 +#define IRQF_NOAUTOEN 0x00020000 #define IRQF_TIMER (__IRQF_TIMER | IRQF_NO_SUSPEND | IRQF_NO_THREAD) diff --git a/kernel/irq/manage.c b/kernel/irq/manage.c index 12a80fd..e5c538f 100644 --- a/kernel/irq/manage.c +++ b/kernel/irq/manage.c @@ -863,6 +863,10 @@ __setup_irq(unsigned int irq, struct irq_desc *desc, struct irqaction *new) int ret, nested, shared = 0; cpumask_var_t mask; + if (new->flags & (IRQF_NOAUTOEN | IRQF_SHARED) == + (IRQF_NOAUTOEN | IRQF_SHARED)) + return -EINVAL; + if (!desc) return -EINVAL; @@ -998,7 +1002,8 @@ __setup_irq(unsigned int irq, struct irq_desc *desc, struct irqaction *new) if (new->flags & IRQF_ONESHOT) desc->istate |= IRQS_ONESHOT; - if (irq_settings_can_autoenable(desc)) + if (irq_settings_can_autoenable(desc) && + !(new->flags & IRQF_NOAUTOEN)) irq_startup(desc); else /* Undo nested disables: */