On Thu, 2013-05-16 at 18:20 +0800, Li Zhong wrote: > It seems following race is possible: >
.../... > vdso_getcpu_init(); > #endif > - notify_cpu_starting(cpu); > - set_cpu_online(cpu, true); > /* Update sibling maps */ > base = cpu_first_thread_sibling(cpu); > for (i = 0; i < threads_per_core; i++) { > - if (cpu_is_offline(base + i)) > + if (cpu_is_offline(base + i) && (cpu != base + i)) > continue; > cpumask_set_cpu(cpu, cpu_sibling_mask(base + i)); > cpumask_set_cpu(base + i, cpu_sibling_mask(cpu)); > @@ -667,6 +665,10 @@ __cpuinit void start_secondary(void *unused) > } > of_node_put(l2_cache); > > + smp_wmb(); > + notify_cpu_starting(cpu); > + set_cpu_online(cpu, true); > + So we could have an online CPU with an empty sibling mask. Now we can have a sibling that isn't online ... Is that ok ? Or should we do a two pass mechanism: - Pass 1, set the new cpu siblings - set_cpu_online - Pass 2, set other CPU sibling of this cpu ? Cheers, Ben. _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev