xref: /rk3399_rockchip-uboot/arch/arm/cpu/arm926ejs/mx27/reset.c (revision 814013253fd4cf932d0fb32f7043f09a2a748d9a)
184ad6884SPeter Tyser /*
284ad6884SPeter Tyser  * (C) Copyright 2002
384ad6884SPeter Tyser  * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
484ad6884SPeter Tyser  * Marius Groeger <mgroeger@sysgo.de>
584ad6884SPeter Tyser  *
684ad6884SPeter Tyser  * (C) Copyright 2002
784ad6884SPeter Tyser  * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
884ad6884SPeter Tyser  * Alex Zuepke <azu@sysgo.de>
984ad6884SPeter Tyser  *
1084ad6884SPeter Tyser  * (C) Copyright 2002
1184ad6884SPeter Tyser  * Gary Jennejohn, DENX Software Engineering, <gj@denx.de>
1284ad6884SPeter Tyser  *
1384ad6884SPeter Tyser  * (C) Copyright 2009
1484ad6884SPeter Tyser  * Ilya Yanok, Emcraft Systems Ltd, <yanok@emcraft.com>
1584ad6884SPeter Tyser  *
161a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
1784ad6884SPeter Tyser  */
1884ad6884SPeter Tyser 
1984ad6884SPeter Tyser #include <common.h>
2084ad6884SPeter Tyser #include <asm/io.h>
2184ad6884SPeter Tyser #include <asm/arch/imx-regs.h>
2284ad6884SPeter Tyser 
2384ad6884SPeter Tyser /*
2484ad6884SPeter Tyser  * Reset the cpu by setting up the watchdog timer and let it time out
2584ad6884SPeter Tyser  */
reset_cpu(ulong ignored)2684ad6884SPeter Tyser void reset_cpu(ulong ignored)
2784ad6884SPeter Tyser {
2884ad6884SPeter Tyser 	struct wdog_regs *regs = (struct wdog_regs *)IMX_WDT_BASE;
2984ad6884SPeter Tyser 	/* Disable watchdog and set Time-Out field to 0 */
30*f7440928SLeonid Iziumtsev 	writew(0x0000, &regs->wcr);
3184ad6884SPeter Tyser 
3284ad6884SPeter Tyser 	/* Write Service Sequence */
33*f7440928SLeonid Iziumtsev 	writew(0x5555, &regs->wsr);
34*f7440928SLeonid Iziumtsev 	writew(0xAAAA, &regs->wsr);
3584ad6884SPeter Tyser 
3684ad6884SPeter Tyser 	/* Enable watchdog */
37*f7440928SLeonid Iziumtsev 	writew(WCR_WDE, &regs->wcr);
3884ad6884SPeter Tyser 
3984ad6884SPeter Tyser 	while (1);
4084ad6884SPeter Tyser 	/*NOTREACHED*/
4184ad6884SPeter Tyser }
42