Skip to content

Commit 2c86562

Browse files
Thomas Bogendoerferpaulburton
authored andcommitted
MIPS: SGI-IP27: do boot CPU init later
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
1 parent 9707b7e commit 2c86562

File tree

4 files changed

+6
-3
lines changed

4 files changed

+6
-3
lines changed

arch/mips/include/asm/smp-ops.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -29,6 +29,7 @@ struct plat_smp_ops {
2929
int (*boot_secondary)(int cpu, struct task_struct *idle);
3030
void (*smp_setup)(void);
3131
void (*prepare_cpus)(unsigned int max_cpus);
32+
void (*prepare_boot_cpu)(void);
3233
#ifdef CONFIG_HOTPLUG_CPU
3334
int (*cpu_disable)(void);
3435
void (*cpu_die)(unsigned int cpu);

arch/mips/kernel/smp.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -444,6 +444,8 @@ void __init smp_prepare_cpus(unsigned int max_cpus)
444444
/* preload SMP state for boot cpu */
445445
void smp_prepare_boot_cpu(void)
446446
{
447+
if (mp_ops->prepare_boot_cpu)
448+
mp_ops->prepare_boot_cpu();
447449
set_cpu_possible(0, true);
448450
set_cpu_online(0, true);
449451
}

arch/mips/sgi-ip27/ip27-init.c

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -212,7 +212,6 @@ void __init plat_mem_setup(void)
212212
#endif
213213

214214
ioc3_eth_init();
215-
per_cpu_init();
216215

217216
set_io_port_base(IO_BASE);
218217
}

arch/mips/sgi-ip27/ip27-smp.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -177,7 +177,7 @@ static void ip27_send_ipi_mask(const struct cpumask *mask, unsigned int action)
177177
ip27_send_ipi_single(i, action);
178178
}
179179

180-
static void ip27_init_secondary(void)
180+
static void ip27_init_cpu(void)
181181
{
182182
per_cpu_init();
183183
}
@@ -235,9 +235,10 @@ static void __init ip27_prepare_cpus(unsigned int max_cpus)
235235
const struct plat_smp_ops ip27_smp_ops = {
236236
.send_ipi_single = ip27_send_ipi_single,
237237
.send_ipi_mask = ip27_send_ipi_mask,
238-
.init_secondary = ip27_init_secondary,
238+
.init_secondary = ip27_init_cpu,
239239
.smp_finish = ip27_smp_finish,
240240
.boot_secondary = ip27_boot_secondary,
241241
.smp_setup = ip27_smp_setup,
242242
.prepare_cpus = ip27_prepare_cpus,
243+
.prepare_boot_cpu = ip27_init_cpu,
243244
};

0 commit comments

Comments
 (0)