/* * Carsten Langgaard, carstenl@mips.com * Copyright (C) 1999,2000 MIPS Technologies, Inc. All rights reserved. * * ######################################################################## * * This program is free software; you can distribute it and/or modify it * under the terms of the GNU General Public License (Version 2) as * published by the Free Software Foundation. * * This program is distributed in the hope it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 59 Temple Place - Suite 330, Boston MA 02111-1307, USA. * * ######################################################################## * * Reset the MIPS boards. * */ #include #include #include #if defined(CONFIG_MIPS_ATLAS) #include #endif /* CONFIG_MIPS_ATLAS */ #if defined(CONFIG_MIPS_AVALANCHE_SOC) #include #define AVALANCHE_RST_SWRCR (1<<0) /* System software reset */ #define AVALANCHE_GO_RESET 1 #define AVALANCHE_GO_IDLE 1 #define AVALANCHE_GO_STBY 2 #define AVALANCHE_GO_HALT 3 #endif /* CONFIG_MIPS_AVALANCHE_SOC */ static void mips_machine_restart(char *command); static void mips_machine_halt(void); #if defined(CONFIG_MIPS_ATLAS) static void atlas_machine_power_off(void); #endif static void mips_machine_restart(char *command) { #if defined(CONFIG_MIPS_AVALANCHE_SOC) avalanche_sys_reset(AVALANCHE_GO_RESET); { __asm__ __volatile( ".set noreorder\n\t" ".set mips3\n\t" "li $2,0xbfc00000\n\t" "jr $2\n\t" "nop\n\t" ".set mips0\n\t" ".set reorder\n\t"); } #else /* !CONFIG_MIPS_AVALANCHE_SOC */ volatile unsigned int *softres_reg = (void *)SOFTRES_REG; *softres_reg = GORESET; #endif /* CONFIG_MIPS_AVALANCHE_SOC */ } static void mips_machine_halt(void) { #if defined(CONFIG_MIPS_AVALANCHE_SOC) avalanche_set_global_power_mode(AVALANCHE_GO_HALT); #else volatile unsigned int *softres_reg = (void *)SOFTRES_REG; *softres_reg = GORESET; #endif /* CONFIG_MIPS_AVALANCHE_SOC */ } #if defined(CONFIG_MIPS_ATLAS) static void atlas_machine_power_off(void) { volatile unsigned int *psustby_reg = (void *)ATLAS_PSUSTBY_REG; *psustby_reg = ATLAS_GOSTBY; } #endif #if defined(CONFIG_MIPS_AVALANCHE_SOC) static void avalanche_machine_power_off(void) { avalanche_set_global_power_mode(AVALANCHE_GO_STBY); } #endif /* CONFIG_MIPS_AVALANCHE_SOC */ void mips_reboot_setup(void) { _machine_restart = mips_machine_restart; _machine_halt = mips_machine_halt; #if defined(CONFIG_MIPS_ATLAS) _machine_power_off = atlas_machine_power_off; #endif #if defined(CONFIG_MIPS_MALTA) _machine_power_off = mips_machine_halt; #endif #if defined(CONFIG_MIPS_AVALANCHE_SOC) _machine_power_off = avalanche_machine_power_off; #endif /* CONFIG_MIPS_AVALANCHE_SOC */ }