blob: 31685d00094015ae14db436be0ec7590acd58108 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +09002/*
Masahiro Yamadaa7888922016-08-25 21:03:41 +09003 * Copyright (C) 2012-2014 Panasonic Corporation
4 * Copyright (C) 2015-2016 Socionext Inc.
5 * Author: Masahiro Yamada <yamada.masahiro@socionext.com>
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +09006 */
7
8#include <common.h>
Masahiro Yamada663a23f2015-05-29 17:30:00 +09009#include <linux/io.h>
Masahiro Yamadaa7888922016-08-25 21:03:41 +090010#include <asm/secure.h>
Masahiro Yamadaefdf3402016-01-09 01:51:13 +090011
12#include "sc-regs.h"
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090013
Masahiro Yamadaa7888922016-08-25 21:03:41 +090014/* If PSCI is enabled, this is used for SYSTEM_RESET function */
15#ifdef CONFIG_ARMV7_PSCI
16#define __SECURE __secure
17#else
18#define __SECURE
19#endif
20
21void __SECURE reset_cpu(unsigned long ignored)
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090022{
23 u32 tmp;
24
Masahiro Yamadac84024c2019-07-10 20:07:41 +090025 writel(5, sc_base + SC_IRQTIMSET); /* default value */
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090026
Masahiro Yamadac84024c2019-07-10 20:07:41 +090027 tmp = readl(sc_base + SC_SLFRSTSEL);
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090028 tmp &= ~0x3; /* mask [1:0] */
29 tmp |= 0x0; /* XRST reboot */
Masahiro Yamadac84024c2019-07-10 20:07:41 +090030 writel(tmp, sc_base + SC_SLFRSTSEL);
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090031
Masahiro Yamadac84024c2019-07-10 20:07:41 +090032 tmp = readl(sc_base + SC_SLFRSTCTL);
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090033 tmp |= 0x1;
Masahiro Yamadac84024c2019-07-10 20:07:41 +090034 writel(tmp, sc_base + SC_SLFRSTCTL);
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090035}