The offline CPUs need to assigned to something incase they come online later, otherwise anyone using the mapping for things other than affinity will have blank entries for that online CPU. Signed-off-by: Keith Busch <keith.busch@xxxxxxxxx> --- kernel/irq/affinity.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/kernel/irq/affinity.c b/kernel/irq/affinity.c index b25dce0..2367531 100644 --- a/kernel/irq/affinity.c +++ b/kernel/irq/affinity.c @@ -129,6 +129,14 @@ irq_create_affinity_masks(int nvecs, const struct irq_affinity *affd) } done: + /* + * Assign offline CPUs to first mask in case they come online later. A + * driver can rerun this from a cpu notifier if they want a more optimal + * spread. + */ + cpumask_andnot(nmsk, cpu_possible_mask, cpu_online_mask); + irq_spread_init_one(masks, nmsk, cpumask_weight(nmsk)); + put_online_cpus(); /* Fill out vectors at the end that don't need affinity */ -- 2.5.5 -- To unsubscribe from this list: send the line "unsubscribe linux-block" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html