diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2016-11-16 12:36:44 -0500 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2016-11-16 12:44:01 -0500 |
commit | b6e5d5b947527558afac4aa0cdfa2ac586332e03 (patch) | |
tree | b4d8c37c70f0513eae15eb6f9a4e84e8981090f2 /kernel/irq/affinity.c | |
parent | bfe130773862bb3a02cdc4d4c2169f7f0210a46b (diff) |
genirq/affinity: Use default affinity mask for reserved vectors
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>
Diffstat (limited to 'kernel/irq/affinity.c')
-rw-r--r-- | kernel/irq/affinity.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/kernel/irq/affinity.c b/kernel/irq/affinity.c index 49eb38d48816..9be9bda7c1f9 100644 --- a/kernel/irq/affinity.c +++ b/kernel/irq/affinity.c | |||
@@ -75,7 +75,7 @@ irq_create_affinity_masks(int nvecs, const struct irq_affinity *affd) | |||
75 | 75 | ||
76 | /* Fill out vectors at the beginning that don't need affinity */ | 76 | /* Fill out vectors at the beginning that don't need affinity */ |
77 | for (curvec = 0; curvec < affd->pre_vectors; curvec++) | 77 | for (curvec = 0; curvec < affd->pre_vectors; curvec++) |
78 | cpumask_copy(masks + curvec, cpu_possible_mask); | 78 | cpumask_copy(masks + curvec, irq_default_affinity); |
79 | 79 | ||
80 | /* Stabilize the cpumasks */ | 80 | /* Stabilize the cpumasks */ |
81 | get_online_cpus(); | 81 | get_online_cpus(); |
@@ -130,7 +130,7 @@ done: | |||
130 | 130 | ||
131 | /* Fill out vectors at the end that don't need affinity */ | 131 | /* Fill out vectors at the end that don't need affinity */ |
132 | for (; curvec < nvecs; curvec++) | 132 | for (; curvec < nvecs; curvec++) |
133 | cpumask_copy(masks + curvec, cpu_possible_mask); | 133 | cpumask_copy(masks + curvec, irq_default_affinity); |
134 | out: | 134 | out: |
135 | free_cpumask_var(nmsk); | 135 | free_cpumask_var(nmsk); |
136 | return masks; | 136 | return masks; |