diff options
author | Magnus Damm <damm@opensource.se> | 2013-07-31 03:07:12 -0400 |
---|---|---|
committer | Simon Horman <horms+renesas@verge.net.au> | 2013-08-06 05:07:24 -0400 |
commit | c970d4ef3ac6d56f5fd02902ad2ad80377c0bca1 (patch) | |
tree | e65617739137b1a044c214afcff595a07a88737e /arch | |
parent | 8b3e32c1fe5dce55e28e76b20361841dc863ec17 (diff) |
ARM: shmobile: Introduce shared SCU SMP boot code
Add SMP boot functions for SCU equipped mach-shmobile SoCs.
At this point shmobile_smp_scu_prepare_cpus() controls the SCU and
installs boot fn and arg, while shmobile_smp_scu_boot_secondary()
currently does nothing. In the future the boot function and arg
install code will be reworked, so the empty function is ground
work for that.
Signed-off-by: Magnus Damm <damm@opensource.se>
Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mach-shmobile/include/mach/common.h | 3 | ||||
-rw-r--r-- | arch/arm/mach-shmobile/platsmp-scu.c | 31 |
2 files changed, 34 insertions, 0 deletions
diff --git a/arch/arm/mach-shmobile/include/mach/common.h b/arch/arm/mach-shmobile/include/mach/common.h index e818f029d8e3..42761f4fb171 100644 --- a/arch/arm/mach-shmobile/include/mach/common.h +++ b/arch/arm/mach-shmobile/include/mach/common.h | |||
@@ -11,6 +11,9 @@ extern void shmobile_boot_vector(void); | |||
11 | extern unsigned long shmobile_boot_fn; | 11 | extern unsigned long shmobile_boot_fn; |
12 | extern unsigned long shmobile_boot_arg; | 12 | extern unsigned long shmobile_boot_arg; |
13 | extern void shmobile_boot_scu(void); | 13 | extern void shmobile_boot_scu(void); |
14 | extern void shmobile_smp_scu_prepare_cpus(unsigned int max_cpus); | ||
15 | extern int shmobile_smp_scu_boot_secondary(unsigned int cpu, | ||
16 | struct task_struct *idle); | ||
14 | struct clk; | 17 | struct clk; |
15 | extern int shmobile_clk_init(void); | 18 | extern int shmobile_clk_init(void); |
16 | extern void shmobile_handle_irq_intc(struct pt_regs *); | 19 | extern void shmobile_handle_irq_intc(struct pt_regs *); |
diff --git a/arch/arm/mach-shmobile/platsmp-scu.c b/arch/arm/mach-shmobile/platsmp-scu.c new file mode 100644 index 000000000000..8f478e4d4964 --- /dev/null +++ b/arch/arm/mach-shmobile/platsmp-scu.c | |||
@@ -0,0 +1,31 @@ | |||
1 | /* | ||
2 | * SMP support for SoCs with SCU covered by mach-shmobile | ||
3 | * | ||
4 | * Copyright (C) 2013 Magnus Damm | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | ||
7 | * it under the terms of the GNU General Public License version 2 as | ||
8 | * published by the Free Software Foundation. | ||
9 | */ | ||
10 | #include <linux/init.h> | ||
11 | #include <linux/io.h> | ||
12 | #include <linux/smp.h> | ||
13 | #include <asm/smp_plat.h> | ||
14 | #include <asm/smp_scu.h> | ||
15 | #include <mach/common.h> | ||
16 | |||
17 | void __init shmobile_smp_scu_prepare_cpus(unsigned int max_cpus) | ||
18 | { | ||
19 | shmobile_boot_fn = virt_to_phys(shmobile_boot_scu); | ||
20 | shmobile_boot_arg = (unsigned long)shmobile_scu_base; | ||
21 | |||
22 | /* enable SCU and cache coherency on booting CPU */ | ||
23 | scu_enable(shmobile_scu_base); | ||
24 | scu_power_mode(shmobile_scu_base, SCU_PM_NORMAL); | ||
25 | } | ||
26 | |||
27 | int shmobile_smp_scu_boot_secondary(unsigned int cpu, struct task_struct *idle) | ||
28 | { | ||
29 | /* do nothing for now */ | ||
30 | return 0; | ||
31 | } | ||