aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/irqchip/irq-xtensa-mx.c
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2014-03-04 09:19:16 -0500
committerThomas Gleixner <tglx@linutronix.de>2014-03-04 11:37:55 -0500
commit5c331c8626f5d39722d07101c699c8e794f5629d (patch)
tree31472b882b476598f9d79bebf44da818856c8687 /drivers/irqchip/irq-xtensa-mx.c
parent6decf1a33c386d4addc2ed9d269c3868f08c70bb (diff)
irqchip: xtensa: Select only an online cpu
The user space interface does not filter out offline cpus. It merily verifies that the mask contains at least one online cpu. So the selector in the irq chip implementation needs to make sure to pick only an online cpu because otherwise: Offline Core 1 Set affinity to 0xe Selector will pick first set bit, i.e. core 1 Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Cc: Chris Zankel <chris@zankel.net> Cc: xtensa <linux-xtensa@linux-xtensa.org>
Diffstat (limited to 'drivers/irqchip/irq-xtensa-mx.c')
-rw-r--r--drivers/irqchip/irq-xtensa-mx.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/irqchip/irq-xtensa-mx.c b/drivers/irqchip/irq-xtensa-mx.c
index f693f1bc1348..e1c2f9632893 100644
--- a/drivers/irqchip/irq-xtensa-mx.c
+++ b/drivers/irqchip/irq-xtensa-mx.c
@@ -122,7 +122,7 @@ static int xtensa_mx_irq_retrigger(struct irq_data *d)
122static int xtensa_mx_irq_set_affinity(struct irq_data *d, 122static int xtensa_mx_irq_set_affinity(struct irq_data *d,
123 const struct cpumask *dest, bool force) 123 const struct cpumask *dest, bool force)
124{ 124{
125 unsigned mask = 1u << cpumask_any(dest); 125 unsigned mask = 1u << cpumask_any_and(dest, cpu_online_mask);
126 126
127 set_er(mask, MIROUT(d->hwirq - HW_IRQ_MX_BASE)); 127 set_er(mask, MIROUT(d->hwirq - HW_IRQ_MX_BASE));
128 return 0; 128 return 0;