/* * (C) Copyright 2002 * Sysgo Real-Time Solutions, GmbH <www.elinos.com> * Marius Groeger <mgroeger@sysgo.de> * * (C) Copyright 2002 * Sysgo Real-Time Solutions, GmbH <www.elinos.com> * Alex Zuepke <azu@sysgo.de> * * SPDX-License-Identifier: GPL-2.0+ */ /* * CPU specific code */ #include <common.h> #include <command.h> #include <asm/system.h> #include <asm/io.h> #ifdef CONFIG_USE_IRQ DECLARE_GLOBAL_DATA_PTR; #endif static void cache_flush(void); int cleanup_before_linux (void) { /* * this function is called just before we call linux * it prepares the processor for linux * * just disable everything that can disturb booting linux */ disable_interrupts (); /* turn off I-cache */ icache_disable(); dcache_disable(); /* flush I-cache */ cache_flush(); return (0); } /* flush I/D-cache */ static void cache_flush (void) { unsigned long i = 0; asm ("mcr p15, 0, %0, c7, c5, 0": :"r" (i)); } #define RST_BASE 0x90030000 #define RSRR 0x00 #define RCSR 0x04 __attribute__((noreturn)) void reset_cpu(ulong addr __attribute__((unused))) { /* repeat endlessly */ while (1) { writel(0, RST_BASE + RCSR); writel(1, RST_BASE + RSRR); } }