]> git.sur5r.net Git - u-boot/blob - arch/arm/mach-uniphier/arm64/smp_kick_cpus.c
Merge branch 'master' of git://www.denx.de/git/u-boot-sunxi
[u-boot] / arch / arm / mach-uniphier / arm64 / smp_kick_cpus.c
1 /*
2  * Copyright (C) 2016 Socionext Inc.
3  *   Author: Masahiro Yamada <yamada.masahiro@socionext.com>
4  *
5  * SPDX-License-Identifier:     GPL-2.0+
6  */
7
8 #include <linux/io.h>
9 #include <linux/sizes.h>
10
11 #define UNIPHIER_SMPCTRL_ROM_RSV0       0x59801200
12
13 void uniphier_smp_setup(void);
14 void uniphier_secondary_startup(void);
15
16 void uniphier_smp_kick_all_cpus(void)
17 {
18         void __iomem *rom_boot_rsv0;
19
20         rom_boot_rsv0 = ioremap(UNIPHIER_SMPCTRL_ROM_RSV0, SZ_8);
21
22         writeq((u64)uniphier_secondary_startup, rom_boot_rsv0);
23
24         iounmap(rom_boot_rsv0);
25
26         uniphier_smp_setup();
27
28         asm("dsb        ishst\n" /* Ensure the write to ROM_RSV0 is visible */
29             "sev"); /* Bring up all secondary CPUs from Boot ROM into U-Boot */
30 }