blob: 9546e80bcb3b5cc842d0638d9b5ef2d83162c5fd [file] [log] [blame]
Vipin KUMAR7cb16352010-01-15 19:15:43 +05301/*
2 * (C) Copyright 2009
3 * Vipin Kumar, ST Micoelectronics, vipin.kumar@st.com.
4 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02005 * SPDX-License-Identifier: GPL-2.0+
Vipin KUMAR7cb16352010-01-15 19:15:43 +05306 */
7
8#include <common.h>
9#include <asm/io.h>
10#include <asm/arch/hardware.h>
11#include <asm/arch/spr_syscntl.h>
12
13void reset_cpu(ulong ignored)
14{
15 struct syscntl_regs *syscntl_regs_p =
16 (struct syscntl_regs *)CONFIG_SPEAR_SYSCNTLBASE;
17
18 printf("System is going to reboot ...\n");
19
20 /*
21 * This 1 second delay will allow the above message
22 * to be printed before reset
23 */
24 udelay((1000 * 1000));
25
26 /* Going into slow mode before resetting SOC */
27 writel(0x02, &syscntl_regs_p->scctrl);
28
29 /*
30 * Writing any value to the system status register will
31 * reset the SoC
32 */
33 writel(0x00, &syscntl_regs_p->scsysstat);
34
35 /* system will restart */
36 while (1)
37 ;
38}