ARM: CPU hotplug: pass in proper affinity mask on IRQ migration
authorRussell King <rmk+kernel@arm.linux.org.uk>
Thu, 21 Jul 2011 14:07:56 +0000 (15:07 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Thu, 21 Jul 2011 14:07:56 +0000 (15:07 +0100)
Now that the GIC takes care of selecting a target interrupt from the
affinity mask, we don't need all this complexity in the core code
anymore.  Just detect when we need to break affinity.

Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/kernel/irq.c

index d7aa5c97877cc34797069c670cf380ba29b703d7..ab63c05290e5e5801525a12e2ec193e3a14b0be3 100644 (file)
@@ -133,17 +133,15 @@ int __init arch_probe_nr_irqs(void)
 
 static bool migrate_one_irq(struct irq_data *d)
 {
-       unsigned int cpu = cpumask_any_and(d->affinity, cpu_online_mask);
+       const struct cpumask *affinity = d->affinity;
        bool ret = false;
 
-       if (cpu >= nr_cpu_ids) {
-               cpu = cpumask_any(cpu_online_mask);
+       if (cpumask_any_and(affinity, cpu_online_mask) >= nr_cpu_ids) {
+               affinity cpu_online_mask;
                ret = true;
        }
 
-       pr_debug("IRQ%u: moving from cpu%u to cpu%u\n", d->irq, d->node, cpu);
-
-       d->chip->irq_set_affinity(d, cpumask_of(cpu), true);
+       d->chip->irq_set_affinity(d, affinity, true);
 
        return ret;
 }