aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/common/gic.c1
-rw-r--r--arch/arm/kernel/irq.c10
2 files changed, 2 insertions, 9 deletions
diff --git a/arch/arm/common/gic.c b/arch/arm/common/gic.c
index 4ddd0a6ac7ff..635d9857b07a 100644
--- a/arch/arm/common/gic.c
+++ b/arch/arm/common/gic.c
@@ -189,7 +189,6 @@ static int gic_set_affinity(struct irq_data *d, const struct cpumask *mask_val,
189 bit = 1 << (cpu + shift); 189 bit = 1 << (cpu + shift);
190 190
191 spin_lock(&irq_controller_lock); 191 spin_lock(&irq_controller_lock);
192 d->node = cpu;
193 val = readl_relaxed(reg) & ~mask; 192 val = readl_relaxed(reg) & ~mask;
194 writel_relaxed(val | bit, reg); 193 writel_relaxed(val | bit, reg);
195 spin_unlock(&irq_controller_lock); 194 spin_unlock(&irq_controller_lock);
diff --git a/arch/arm/kernel/irq.c b/arch/arm/kernel/irq.c
index 83bbad03fcc6..d7aa5c97877c 100644
--- a/arch/arm/kernel/irq.c
+++ b/arch/arm/kernel/irq.c
@@ -166,15 +166,9 @@ void migrate_irqs(void)
166 bool affinity_broken = false; 166 bool affinity_broken = false;
167 167
168 raw_spin_lock(&desc->lock); 168 raw_spin_lock(&desc->lock);
169 do { 169 if (desc->action != NULL &&
170 if (desc->action == NULL) 170 cpumask_test_cpu(smp_processor_id(), d->affinity))
171 break;
172
173 if (d->node != cpu)
174 break;
175
176 affinity_broken = migrate_one_irq(d); 171 affinity_broken = migrate_one_irq(d);
177 } while (0);
178 raw_spin_unlock(&desc->lock); 172 raw_spin_unlock(&desc->lock);
179 173
180 if (affinity_broken && printk_ratelimit()) 174 if (affinity_broken && printk_ratelimit())