2 * reset.c -- common ColdFire SoC reset support
4 * (C) Copyright 2012, Greg Ungerer <gerg@uclinux.org>
6 * This file is subject to the terms and conditions of the GNU General Public
7 * License. See the file COPYING in the main directory of this archive
11 #include <linux/kernel.h>
12 #include <linux/init.h>
14 #include <asm/machdep.h>
15 #include <asm/coldfire.h>
16 #include <asm/mcfsim.h>
19 * There are 2 common methods amongst the ColdFure parts for reseting
20 * the CPU. But there are couple of exceptions, the 5272 and the 547x
21 * have something completely special to them, and we let their specific
22 * subarch code handle them.
26 static void mcf_cpu_reset(void)
29 /* Set watchdog to soft reset, and enabled */
30 __raw_writeb(0xc0, MCFSIM_SYPCR);
32 /* wait for watchdog to timeout */;
37 static void mcf_cpu_reset(void)
40 __raw_writeb(MCF_RCR_SWRESET, MCF_RCR);
44 static int __init mcf_setup_reset(void)
46 mach_reset = mcf_cpu_reset;
50 arch_initcall(mcf_setup_reset);