summaryrefslogtreecommitdiff
path: root/arch/arm/mach-uniphier/arm32/psci_smp.S
diff options
context:
space:
mode:
authorTom Rini <trini@konsulko.com>2016-08-11 17:45:53 +0300
committerTom Rini <trini@konsulko.com>2016-08-11 17:45:53 +0300
commit28cd88baa3f11cdb52be3b6d0610dcf32c60871a (patch)
tree4d6150effe763b043c7e30499c8ec2061df81be1 /arch/arm/mach-uniphier/arm32/psci_smp.S
parent2f1eb66e2881a780e622e7fd50b3a497677fd373 (diff)
parente8a9293295a1a54f6e43970bed2d3bfd124be02c (diff)
downloadu-boot-28cd88baa3f11cdb52be3b6d0610dcf32c60871a.tar.xz
Merge branch 'master' of git://git.denx.de/u-boot-uniphier
Diffstat (limited to 'arch/arm/mach-uniphier/arm32/psci_smp.S')
-rw-r--r--arch/arm/mach-uniphier/arm32/psci_smp.S40
1 files changed, 40 insertions, 0 deletions
diff --git a/arch/arm/mach-uniphier/arm32/psci_smp.S b/arch/arm/mach-uniphier/arm32/psci_smp.S
new file mode 100644
index 0000000000..aa2fa5f3fc
--- /dev/null
+++ b/arch/arm/mach-uniphier/arm32/psci_smp.S
@@ -0,0 +1,40 @@
+/*
+ * Copyright (C) 2016 Socionext Inc.
+ * Author: Masahiro Yamada <yamada.masahiro@socionext.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0+
+ */
+
+#include <linux/linkage.h>
+#include <asm/system.h>
+
+ .section ._secure.text, "ax"
+
+ENTRY(uniphier_smp_trampoline)
+ ldr r0, 0f
+ mrc p15, 0, r1, c1, c0, 0 @ SCTLR (System Control Register)
+ orr r1, r1, #CR_I @ Enable ICache
+ bic r1, r1, #(CR_C | CR_M) @ Disable MMU and Dcache
+ mcr p15, 0, r1, c1, c0, 0
+
+ bx r0
+0: .word uniphier_secondary_startup
+ .globl uniphier_smp_trampoline_end
+uniphier_smp_trampoline_end:
+ENDPROC(uniphier_smp_trampoline)
+
+LENTRY(uniphier_secondary_startup)
+ mrc p15, 0, r1, c0, c0, 5 @ MPIDR (Multiprocessor Affinity Reg)
+ and r1, r1, #0xff
+
+ ldr r2, =uniphier_smp_booted
+ mov r0, #1
+ str r0, [r2, r1, lsl #2]
+
+ ldr r2, =uniphier_psci_holding_pen_release
+pen: ldr r0, [r2]
+ cmp r0, r1
+ beq psci_cpu_entry
+ wfe
+ b pen
+ENDPROC(uniphier_secondary_startup)