]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
genirq/affinity: Use default affinity mask for reserved vectors
authorThomas Gleixner <tglx@linutronix.de>
Wed, 16 Nov 2016 17:36:44 +0000 (18:36 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Wed, 16 Nov 2016 17:44:01 +0000 (18:44 +0100)
The reserved vectors at the beginning and the end of the vector space get
cpu_possible_mask assigned as their affinity mask.

All other non-auto affine interrupts get the default irq affinity mask
assigned. Using cpu_possible_mask breaks that rule.

Treat them like any other interrupt and use irq_default_affinity as target
mask.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Christoph Hellwig <hch@lst.de>
kernel/irq/affinity.c

index 49eb38d48816859f97f7b1696552bcfef8c8768d..9be9bda7c1f94cf633bb11b4be141ceecf0244b4 100644 (file)
@@ -75,7 +75,7 @@ irq_create_affinity_masks(int nvecs, const struct irq_affinity *affd)
 
        /* Fill out vectors at the beginning that don't need affinity */
        for (curvec = 0; curvec < affd->pre_vectors; curvec++)
-               cpumask_copy(masks + curvec, cpu_possible_mask);
+               cpumask_copy(masks + curvec, irq_default_affinity);
 
        /* Stabilize the cpumasks */
        get_online_cpus();
@@ -130,7 +130,7 @@ done:
 
        /* Fill out vectors at the end that don't need affinity */
        for (; curvec < nvecs; curvec++)
-               cpumask_copy(masks + curvec, cpu_possible_mask);
+               cpumask_copy(masks + curvec, irq_default_affinity);
 out:
        free_cpumask_var(nmsk);
        return masks;