The two-stage spread is done on same irq vectors, and we just need that either one stage covers all vector, not two stage work together to cover all vectors.
So enhance the warning check to make sure all vectors are spread. Cc: Christoph Hellwig <[email protected]> Cc: Keith Busch <[email protected]> Cc: [email protected], Cc: Jon Derrick <[email protected]> Cc: Jens Axboe <[email protected]> Fixes: 6da4b3ab9a6 ("genirq/affinity: Add support for allocating interrupt sets") Signed-off-by: Ming Lei <[email protected]> --- kernel/irq/affinity.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/kernel/irq/affinity.c b/kernel/irq/affinity.c index 927dcbe80482..178dc7eb7b35 100644 --- a/kernel/irq/affinity.c +++ b/kernel/irq/affinity.c @@ -318,8 +318,7 @@ static int irq_build_affinity_masks(unsigned int startvec, unsigned int numvecs, npresmsk, nmsk, masks); put_online_cpus(); - if (nr_present < numvecs) - WARN_ON(nr_present + nr_others < numvecs); + WARN_ON(max(nr_present, nr_others) < numvecs); free_node_to_cpumask(node_to_cpumask); -- 2.20.1

