summaryrefslogtreecommitdiff
path: root/arch/arm/mach-mvebu/cpu-reset.c
diff options
context:
space:
mode:
authorThomas Petazzoni <thomas.petazzoni@free-electrons.com>2014-04-14 15:50:29 +0200
committerJason Cooper <jason@lakedaemon.net>2014-04-24 05:24:03 +0000
commit49754ffef5dca1d212e5fea5957a2a164585e92c (patch)
treef183b8cc30a9cde37e22c5ce71a71ce40f2d5cbc /arch/arm/mach-mvebu/cpu-reset.c
parent3f20fb1153b374737acd40d42cb3cab2ae5dae35 (diff)
ARM: mvebu: start using the CPU reset driver
This commit changes the PMSU driver to no longer map itself the CPU reset registers, and instead call into the CPU reset driver to deassert the secondary CPUs for SMP booting. In order to provide Device Tree backward compatibility, the CPU reset driver is extended to not only support its official compatible string "marvell,armada-370-cpu-reset", but to also look at the PMSU compatible string "marvell,armada-370-xp-pmsu" to find the CPU reset registers address. This allows old Device Tree to work correctly with newer kernel versions. Therefore, the CPU reset driver implements the following logic: * If one of the normal compatible strings "marvell,armada-370-cpu-reset" is found, then we map its first memory resource as the CPU reset registers. * Otherwise, if none of the normal compatible strings have been found, we look for the "marvell,armada-370-xp-pmsu" compatible string, and we map the second memory as the CPU reset registers. Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> Link: https://lkml.kernel.org/r/1397483433-25836-3-git-send-email-thomas.petazzoni@free-electrons.com Acked-by: Gregory CLEMENT <gregory.clement@free-electrons.com> Signed-off-by: Jason Cooper <jason@lakedaemon.net>
Diffstat (limited to 'arch/arm/mach-mvebu/cpu-reset.c')
-rw-r--r--arch/arm/mach-mvebu/cpu-reset.c53
1 files changed, 37 insertions, 16 deletions
diff --git a/arch/arm/mach-mvebu/cpu-reset.c b/arch/arm/mach-mvebu/cpu-reset.c
index 4ff4ce77f8b6..4a8f9eebebea 100644
--- a/arch/arm/mach-mvebu/cpu-reset.c
+++ b/arch/arm/mach-mvebu/cpu-reset.c
@@ -40,42 +40,63 @@ int mvebu_cpu_reset_deassert(int cpu)
return 0;
}
-static int __init mvebu_cpu_reset_init(void)
+static int mvebu_cpu_reset_map(struct device_node *np, int res_idx)
{
- struct device_node *np;
struct resource res;
- int ret = 0;
-
- np = of_find_compatible_node(NULL, NULL,
- "marvell,armada-370-cpu-reset");
- if (!np)
- return 0;
- if (of_address_to_resource(np, 0, &res)) {
+ if (of_address_to_resource(np, res_idx, &res)) {
pr_err("unable to get resource\n");
- ret = -ENOENT;
- goto out;
+ return -ENOENT;
}
if (!request_mem_region(res.start, resource_size(&res),
np->full_name)) {
pr_err("unable to request region\n");
- ret = -EBUSY;
- goto out;
+ return -EBUSY;
}
cpu_reset_base = ioremap(res.start, resource_size(&res));
if (!cpu_reset_base) {
pr_err("unable to map registers\n");
release_mem_region(res.start, resource_size(&res));
- ret = -ENOMEM;
- goto out;
+ return -ENOMEM;
}
cpu_reset_size = resource_size(&res);
-out:
+ return 0;
+}
+
+int __init mvebu_cpu_reset_init(void)
+{
+ struct device_node *np;
+ int res_idx;
+ int ret;
+
+ np = of_find_compatible_node(NULL, NULL,
+ "marvell,armada-370-cpu-reset");
+ if (np) {
+ res_idx = 0;
+ } else {
+ /*
+ * This code is kept for backward compatibility with
+ * old Device Trees.
+ */
+ np = of_find_compatible_node(NULL, NULL,
+ "marvell,armada-370-xp-pmsu");
+ if (np) {
+ pr_warn(FW_WARN "deprecated pmsu binding\n");
+ res_idx = 1;
+ }
+ }
+
+ /* No reset node found */
+ if (!np)
+ return -ENODEV;
+
+ ret = mvebu_cpu_reset_map(np, res_idx);
of_node_put(np);
+
return ret;
}