diff options
| author | fishsoupisgood <github@madingley.org> | 2019-04-29 01:17:54 +0100 | 
|---|---|---|
| committer | fishsoupisgood <github@madingley.org> | 2019-05-27 03:43:43 +0100 | 
| commit | 3f2546b2ef55b661fd8dd69682b38992225e86f6 (patch) | |
| tree | 65ca85f13617aee1dce474596800950f266a456c /roms/u-boot/arch/arm/cpu/arm920t/ep93xx/cpu.c | |
| download | qemu-master.tar.gz qemu-master.tar.bz2 qemu-master.zip | |
Diffstat (limited to 'roms/u-boot/arch/arm/cpu/arm920t/ep93xx/cpu.c')
| -rw-r--r-- | roms/u-boot/arch/arm/cpu/arm920t/ep93xx/cpu.c | 37 | 
1 files changed, 37 insertions, 0 deletions
| diff --git a/roms/u-boot/arch/arm/cpu/arm920t/ep93xx/cpu.c b/roms/u-boot/arch/arm/cpu/arm920t/ep93xx/cpu.c new file mode 100644 index 00000000..bb5ffd29 --- /dev/null +++ b/roms/u-boot/arch/arm/cpu/arm920t/ep93xx/cpu.c @@ -0,0 +1,37 @@ +/* + * Cirrus Logic EP93xx CPU-specific support. + * + * Copyright (C) 2009 Matthias Kaehlcke <matthias@kaehlcke.net> + * + * Copyright (C) 2004, 2005 + * Cory T. Tusar, Videon Central, Inc., <ctusar@videon-central.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/arch/ep93xx.h> +#include <asm/io.h> + +/* We reset the CPU by generating a 1-->0 transition on DeviceCfg bit 31. */ +extern void reset_cpu(ulong addr) +{ +	struct syscon_regs *syscon = (struct syscon_regs *)SYSCON_BASE; +	uint32_t value; + +	/* Unlock DeviceCfg and set SWRST */ +	writel(0xAA, &syscon->sysswlock); +	value = readl(&syscon->devicecfg); +	value |= SYSCON_DEVICECFG_SWRST; +	writel(value, &syscon->devicecfg); + +	/* Unlock DeviceCfg and clear SWRST */ +	writel(0xAA, &syscon->sysswlock); +	value = readl(&syscon->devicecfg); +	value &= ~SYSCON_DEVICECFG_SWRST; +	writel(value, &syscon->devicecfg); + +	/* Dying... */ +	while (1) +		; /* noop */ +} | 
