]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
MIPS: SGI-IP27: do boot CPU init later
authorThomas Bogendoerfer <tbogendoerfer@suse.de>
Tue, 19 Feb 2019 15:57:19 +0000 (16:57 +0100)
committerPaul Burton <paul.burton@mips.com>
Tue, 19 Feb 2019 20:46:03 +0000 (12:46 -0800)
To make use of per_cpu variables in interrupt code per_cpu_init() must
be done after setup_per_cpu_areas(). This is achieved by calling it
in smp_prepare_boot_cpu() via a new smp_ops method.

Signed-off-by: Thomas Bogendoerfer <tbogendoerfer@suse.de>
Signed-off-by: Paul Burton <paul.burton@mips.com>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: James Hogan <jhogan@kernel.org>
Cc: linux-mips@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
arch/mips/include/asm/smp-ops.h
arch/mips/kernel/smp.c
arch/mips/sgi-ip27/ip27-init.c
arch/mips/sgi-ip27/ip27-smp.c

index b7123f9c0785c5953a7d1d8a6eb92b5e742490ef..65618ff1280c9687e0eeeb9aa14ac90311a88915 100644 (file)
@@ -29,6 +29,7 @@ struct plat_smp_ops {
        int (*boot_secondary)(int cpu, struct task_struct *idle);
        void (*smp_setup)(void);
        void (*prepare_cpus)(unsigned int max_cpus);
+       void (*prepare_boot_cpu)(void);
 #ifdef CONFIG_HOTPLUG_CPU
        int (*cpu_disable)(void);
        void (*cpu_die)(unsigned int cpu);
index 6fd9e94fc87e56b5e9df7bbf4835c8ea17c54610..bc4bb3c6bd00518bc9b0f4c64af4c9acca56a10c 100644 (file)
@@ -444,6 +444,8 @@ void __init smp_prepare_cpus(unsigned int max_cpus)
 /* preload SMP state for boot cpu */
 void smp_prepare_boot_cpu(void)
 {
+       if (mp_ops->prepare_boot_cpu)
+               mp_ops->prepare_boot_cpu();
        set_cpu_possible(0, true);
        set_cpu_online(0, true);
 }
index aba985cf07c03e15cc35232d90ca02a7b070c358..e6fa9d0c708a04299eed9c086419a1a8200cc3c3 100644 (file)
@@ -212,7 +212,6 @@ void __init plat_mem_setup(void)
 #endif
 
        ioc3_eth_init();
-       per_cpu_init();
 
        set_io_port_base(IO_BASE);
 }
index 545446dfe7faa4f1cf16b0fec3a2369606922ae2..20b81209c6b84b6e932ae16d28492ea1c08f9471 100644 (file)
@@ -177,7 +177,7 @@ static void ip27_send_ipi_mask(const struct cpumask *mask, unsigned int action)
                ip27_send_ipi_single(i, action);
 }
 
-static void ip27_init_secondary(void)
+static void ip27_init_cpu(void)
 {
        per_cpu_init();
 }
@@ -235,9 +235,10 @@ static void __init ip27_prepare_cpus(unsigned int max_cpus)
 const struct plat_smp_ops ip27_smp_ops = {
        .send_ipi_single        = ip27_send_ipi_single,
        .send_ipi_mask          = ip27_send_ipi_mask,
-       .init_secondary         = ip27_init_secondary,
+       .init_secondary         = ip27_init_cpu,
        .smp_finish             = ip27_smp_finish,
        .boot_secondary         = ip27_boot_secondary,
        .smp_setup              = ip27_smp_setup,
        .prepare_cpus           = ip27_prepare_cpus,
+       .prepare_boot_cpu       = ip27_init_cpu,
 };