sparc64: Defer cpu_data() setup until end of per-cpu data initialization.
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
@@ -544,6 +544,7 @@ static int __cpuinit dr_cpu_configure(struct ds_info *dp,
|
||||
resp_len, ncpus, mask,
|
||||
DR_CPU_STAT_CONFIGURED);
|
||||
|
||||
mdesc_populate_present_mask(mask);
|
||||
mdesc_fill_in_cpu_data(mask);
|
||||
|
||||
for_each_cpu_mask(cpu, *mask) {
|
||||
|
@@ -861,7 +861,6 @@ void __cpuinit mdesc_fill_in_cpu_data(cpumask_t *mask)
|
||||
{
|
||||
struct mdesc_handle *hp;
|
||||
|
||||
mdesc_populate_present_mask(mask);
|
||||
mdesc_iterate_over_cpus(fill_in_one_cpu, NULL, mask);
|
||||
|
||||
#ifdef CONFIG_SMP
|
||||
|
@@ -535,7 +535,6 @@ void __init of_fill_in_cpu_data(void)
|
||||
if (tlb_type == hypervisor)
|
||||
return;
|
||||
|
||||
of_populate_present_mask();
|
||||
of_iterate_over_cpus(fill_in_one_cpu, 0);
|
||||
|
||||
smp_fill_in_sib_core_maps();
|
||||
|
@@ -1399,4 +1399,8 @@ void __init real_setup_per_cpu_areas(void)
|
||||
|
||||
/* Setup %g5 for the boot cpu. */
|
||||
__local_per_cpu_offset = __per_cpu_offset(smp_processor_id());
|
||||
|
||||
of_fill_in_cpu_data();
|
||||
if (tlb_type == hypervisor)
|
||||
mdesc_fill_in_cpu_data(CPU_MASK_ALL_PTR);
|
||||
}
|
||||
|
Reference in New Issue
Block a user