aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/genapic_flat_64.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86/kernel/genapic_flat_64.c')
-rw-r--r--arch/x86/kernel/genapic_flat_64.c21
1 files changed, 11 insertions, 10 deletions
diff --git a/arch/x86/kernel/genapic_flat_64.c b/arch/x86/kernel/genapic_flat_64.c
index 1efecd206a74..c772bb10b173 100644
--- a/arch/x86/kernel/genapic_flat_64.c
+++ b/arch/x86/kernel/genapic_flat_64.c
@@ -158,13 +158,13 @@ static unsigned int flat_cpu_mask_to_apicid(const cpumask_t *cpumask)
158 return cpus_addr(*cpumask)[0] & APIC_ALL_CPUS; 158 return cpus_addr(*cpumask)[0] & APIC_ALL_CPUS;
159} 159}
160 160
161static unsigned int flat_cpu_mask_to_apicid_and(const cpumask_t *cpumask, 161static unsigned int flat_cpu_mask_to_apicid_and(const struct cpumask *cpumask,
162 const cpumask_t *andmask) 162 const struct cpumask *andmask)
163{ 163{
164 unsigned long mask1 = cpus_addr(*cpumask)[0] & APIC_ALL_CPUS; 164 unsigned long mask1 = cpumask_bits(cpumask)[0] & APIC_ALL_CPUS;
165 unsigned long mask2 = cpus_addr(*andmask)[0] & APIC_ALL_CPUS; 165 unsigned long mask2 = cpumask_bits(andmask)[0] & APIC_ALL_CPUS;
166 166
167 return (int)(mask1 & mask2); 167 return mask1 & mask2;
168} 168}
169 169
170static unsigned int phys_pkg_id(int index_msb) 170static unsigned int phys_pkg_id(int index_msb)
@@ -264,8 +264,9 @@ static unsigned int physflat_cpu_mask_to_apicid(const cpumask_t *cpumask)
264 return BAD_APICID; 264 return BAD_APICID;
265} 265}
266 266
267static unsigned int physflat_cpu_mask_to_apicid_and(const cpumask_t *cpumask, 267static unsigned int
268 const cpumask_t *andmask) 268physflat_cpu_mask_to_apicid_and(const struct cpumask *cpumask,
269 const struct cpumask *andmask)
269{ 270{
270 int cpu; 271 int cpu;
271 272
@@ -273,9 +274,9 @@ static unsigned int physflat_cpu_mask_to_apicid_and(const cpumask_t *cpumask,
273 * We're using fixed IRQ delivery, can only return one phys APIC ID. 274 * We're using fixed IRQ delivery, can only return one phys APIC ID.
274 * May as well be the first. 275 * May as well be the first.
275 */ 276 */
276 while ((cpu = next_cpu(-1, *cpumask)) < nr_cpu_ids) 277 cpu = cpumask_any_and(cpumask, andmask);
277 if (cpu_isset(cpu, *andmask)) 278 if (cpu < nr_cpu_ids)
278 return per_cpu(x86_cpu_to_apicid, cpu); 279 return per_cpu(x86_cpu_to_apicid, cpu);
279 return BAD_APICID; 280 return BAD_APICID;
280} 281}
281 282