blob: 8e5b198c96ce6ed286c0367082dd13843482a6a8 [file] [log] [blame]
Masahiro Yamada063eb1e2016-04-21 14:43:18 +09001/*
Masahiro Yamadafa1f73f2016-07-19 21:56:13 +09002 * Copyright (C) 2016 Socionext Inc.
3 * Author: Masahiro Yamada <yamada.masahiro@socionext.com>
Masahiro Yamada063eb1e2016-04-21 14:43:18 +09004 *
5 * SPDX-License-Identifier: GPL-2.0+
6 */
7
Masahiro Yamada063eb1e2016-04-21 14:43:18 +09008#include <linux/io.h>
9#include <linux/sizes.h>
10
Masahiro Yamada5e05c4d2017-06-22 16:42:04 +090011#include "../init.h"
12
Masahiro Yamada063eb1e2016-04-21 14:43:18 +090013#define UNIPHIER_SMPCTRL_ROM_RSV0 0x59801200
14
15void uniphier_smp_setup(void);
16void uniphier_secondary_startup(void);
17
18void uniphier_smp_kick_all_cpus(void)
19{
20 void __iomem *rom_boot_rsv0;
21
Masahiro Yamadafa1f73f2016-07-19 21:56:13 +090022 rom_boot_rsv0 = ioremap(UNIPHIER_SMPCTRL_ROM_RSV0, SZ_8);
Masahiro Yamada063eb1e2016-04-21 14:43:18 +090023
24 writeq((u64)uniphier_secondary_startup, rom_boot_rsv0);
Masahiro Yamada063eb1e2016-04-21 14:43:18 +090025
Masahiro Yamadafa1f73f2016-07-19 21:56:13 +090026 iounmap(rom_boot_rsv0);
Masahiro Yamada063eb1e2016-04-21 14:43:18 +090027
28 uniphier_smp_setup();
29
Masahiro Yamadaf627ef12016-06-08 18:02:32 +090030 asm("dsb ishst\n" /* Ensure the write to ROM_RSV0 is visible */
31 "sev"); /* Bring up all secondary CPUs from Boot ROM into U-Boot */
Masahiro Yamada063eb1e2016-04-21 14:43:18 +090032}