sparc64: Defer cpu_data() setup until end of per-cpu data initialization.
authorDavid S. Miller <davem@davemloft.net>
Wed, 27 May 2009 05:37:25 +0000 (22:37 -0700)
committerDavid S. Miller <davem@davemloft.net>
Tue, 16 Jun 2009 11:56:22 +0000 (04:56 -0700)
Signed-off-by: David S. Miller <davem@davemloft.net>
arch/sparc/kernel/ds.c
arch/sparc/kernel/mdesc.c
arch/sparc/kernel/prom_64.c
arch/sparc/kernel/smp_64.c
arch/sparc/mm/init_64.c

index 51b05c4..4a700f4 100644 (file)
@@ -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) {
index 6d2015e..938da19 100644 (file)
@@ -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
index 4d92f48..fb06ac2 100644 (file)
@@ -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();
index b20f253..045fbb5 100644 (file)
@@ -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);
 }
index 87fea94..785f0a2 100644 (file)
@@ -1799,20 +1799,16 @@ void __init paging_init(void)
        if (tlb_type == hypervisor)
                sun4v_ktsb_register();
 
-       /* We must setup the per-cpu areas before we pull in the
-        * PROM and the MDESC.  The code there fills in cpu and
-        * other information into per-cpu data structures.
-        */
-       real_setup_per_cpu_areas();
-
        prom_build_devicetree();
-       of_fill_in_cpu_data();
+       of_populate_present_mask();
 
        if (tlb_type == hypervisor) {
                sun4v_mdesc_init();
-               mdesc_fill_in_cpu_data(CPU_MASK_ALL_PTR);
+               mdesc_populate_present_mask(CPU_MASK_ALL_PTR);
        }
 
+       real_setup_per_cpu_areas();
+
        /* Once the OF device tree and MDESC have been setup, we know
         * the list of possible cpus.  Therefore we can allocate the
         * IRQ stacks.