aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/irq
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2011-02-08 09:40:05 -0500
committerThomas Gleixner <tglx@linutronix.de>2011-02-19 06:58:19 -0500
commit6a58fb3bad099076f36f0f30f44507bc3275cdb6 (patch)
tree9a40117c941d914b1ef13463436657ae9721fea3 /kernel/irq
parentf230b6d5c48f8d12f4dfa1f8b5ab0b0320076d21 (diff)
genirq: Remove CONFIG_IRQ_PER_CPU
The saving of this switch is minimal versus the ifdef mess it creates. Simple enable PER_CPU unconditionally and remove the config switch. Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'kernel/irq')
-rw-r--r--kernel/irq/Kconfig3
-rw-r--r--kernel/irq/internals.h2
-rw-r--r--kernel/irq/manage.c9
3 files changed, 3 insertions, 11 deletions
diff --git a/kernel/irq/Kconfig b/kernel/irq/Kconfig
index 9e2256de1d1..48ad25f5fa5 100644
--- a/kernel/irq/Kconfig
+++ b/kernel/irq/Kconfig
@@ -32,9 +32,6 @@ config GENERIC_PENDING_IRQ
32config AUTO_IRQ_AFFINITY 32config AUTO_IRQ_AFFINITY
33 def_bool n 33 def_bool n
34 34
35config IRQ_PER_CPU
36 def_bool n
37
38config HARDIRQS_SW_RESEND 35config HARDIRQS_SW_RESEND
39 def_bool n 36 def_bool n
40 37
diff --git a/kernel/irq/internals.h b/kernel/irq/internals.h
index e93e6090cd4..9e32b3d35d3 100644
--- a/kernel/irq/internals.h
+++ b/kernel/irq/internals.h
@@ -163,9 +163,7 @@ static inline void print_irq_desc(unsigned int irq, struct irq_desc *desc)
163 } 163 }
164 164
165 P(IRQ_LEVEL); 165 P(IRQ_LEVEL);
166#ifdef CONFIG_IRQ_PER_CPU
167 P(IRQ_PER_CPU); 166 P(IRQ_PER_CPU);
168#endif
169 P(IRQ_NOPROBE); 167 P(IRQ_NOPROBE);
170 P(IRQ_NOREQUEST); 168 P(IRQ_NOREQUEST);
171 P(IRQ_NOAUTOEN); 169 P(IRQ_NOAUTOEN);
diff --git a/kernel/irq/manage.c b/kernel/irq/manage.c
index 9a99c471d47..056aa49698b 100644
--- a/kernel/irq/manage.c
+++ b/kernel/irq/manage.c
@@ -865,12 +865,10 @@ __setup_irq(unsigned int irq, struct irq_desc *desc, struct irqaction *new)
865 goto mismatch; 865 goto mismatch;
866 } 866 }
867 867
868#if defined(CONFIG_IRQ_PER_CPU)
869 /* All handlers must agree on per-cpuness */ 868 /* All handlers must agree on per-cpuness */
870 if ((old->flags & IRQF_PERCPU) != 869 if ((old->flags & IRQF_PERCPU) !=
871 (new->flags & IRQF_PERCPU)) 870 (new->flags & IRQF_PERCPU))
872 goto mismatch; 871 goto mismatch;
873#endif
874 872
875 /* add new interrupt at end of irq queue */ 873 /* add new interrupt at end of irq queue */
876 do { 874 do {
@@ -894,15 +892,14 @@ __setup_irq(unsigned int irq, struct irq_desc *desc, struct irqaction *new)
894 goto out_mask; 892 goto out_mask;
895 } else 893 } else
896 compat_irq_chip_set_default_handler(desc); 894 compat_irq_chip_set_default_handler(desc);
897#if defined(CONFIG_IRQ_PER_CPU)
898 if (new->flags & IRQF_PERCPU)
899 desc->status |= IRQ_PER_CPU;
900#endif
901 895
902 desc->istate &= ~(IRQS_AUTODETECT | IRQS_SPURIOUS_DISABLED | \ 896 desc->istate &= ~(IRQS_AUTODETECT | IRQS_SPURIOUS_DISABLED | \
903 IRQS_INPROGRESS | IRQS_ONESHOT | \ 897 IRQS_INPROGRESS | IRQS_ONESHOT | \
904 IRQS_WAITING); 898 IRQS_WAITING);
905 899
900 if (new->flags & IRQF_PERCPU)
901 desc->status |= IRQ_PER_CPU;
902
906 if (new->flags & IRQF_ONESHOT) 903 if (new->flags & IRQF_ONESHOT)
907 desc->istate |= IRQS_ONESHOT; 904 desc->istate |= IRQS_ONESHOT;
908 905