On Sat, 3 Jun 2017, Christoph Hellwig wrote: > + > +bool irq_affinity_set(int irq, struct irq_desc *desc, const cpumask_t *mask) > +{ > + struct irq_data *data = irq_desc_get_irq_data(desc); > + struct irq_chip *chip = irq_data_get_irq_chip(data); > + bool ret = false; > + > + if (!irq_can_move_pcntxt(data) && chip->irq_mask) > + chip->irq_mask(data); > + > + if (chip->irq_set_affinity) { > + if (chip->irq_set_affinity(data, mask, true) == -ENOSPC) > + pr_crit("IRQ %d set affinity failed because there are no available vectors. The device assigned to this IRQ is unstable.\n", irq); > + ret = true; > + } > + > + /* > + * We unmask if the irq was not marked masked by the core code. > + * That respects the lazy irq disable behaviour. > + */ > + if (!irq_can_move_pcntxt(data) && > + !irqd_irq_masked(data) && chip->irq_unmask) > + chip->irq_unmask(data); > + > + return ret; > +} That needs even more care as this does not include the handling for move in progress, which will make your affinity setting fail. Ideally we include that managed shutdown magic into fixup_irqs(), but that's arch specific. So that needs the long dragged out update to the generic irq cpuhotplug code to handle the x86'isms proper. Thanks, tglx