Skip to content

Commit

Permalink
sparc64: Defer cpu_data() setup until end of per-cpu data initializat…
Browse files Browse the repository at this point in the history
…ion.

Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
David S. Miller committed Jun 16, 2009
1 parent a209450 commit b696fdc
Show file tree
Hide file tree
Showing 5 changed files with 9 additions and 10 deletions.
1 change: 1 addition & 0 deletions arch/sparc/kernel/ds.c
Original file line number Diff line number Diff line change
Expand Up @@ -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) {
Expand Down
1 change: 0 additions & 1 deletion arch/sparc/kernel/mdesc.c
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
1 change: 0 additions & 1 deletion arch/sparc/kernel/prom_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -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();
Expand Down
4 changes: 4 additions & 0 deletions arch/sparc/kernel/smp_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -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);
}
12 changes: 4 additions & 8 deletions arch/sparc/mm/init_64.c
Original file line number Diff line number Diff line change
Expand Up @@ -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.
Expand Down

0 comments on commit b696fdc

Please sign in to comment.