1/* 2 * (C) Copyright 2001 3 * Erik Theisen, Wave 7 Optics, etheisen@mindspring.com. 4 * 5 * See file CREDITS for list of people who contributed to this 6 * project. 7 * 8 * This program is free software; you can redistribute it and/or 9 * modify it under the terms of the GNU General Public License as 10 * published by the Free Software Foundation; either version 2 of 11 * the License, or (at your option) any later version. 12 * 13 * This program is distributed in the hope that it will be useful, 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16 * GNU General Public License for more details. 17 * 18 * You should have received a copy of the GNU General Public License 19 * along with this program; if not, write to the Free Software 20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 21 * MA 02111-1307 USA 22 */ 23 24/* 25 * Watchdog functions and macros. 26 */ 27#ifndef _WATCHDOG_H_ 28#define _WATCHDOG_H_ 29 30#if defined(CONFIG_HW_WATCHDOG) && defined(CONFIG_WATCHDOG) 31# error "Configuration error: CONFIG_HW_WATCHDOG and CONFIG_WATCHDOG can't be used together." 32#endif 33 34/* 35 * Hardware watchdog 36 */ 37#ifdef CONFIG_HW_WATCHDOG 38 #if defined(__ASSEMBLY__) 39 #define WATCHDOG_RESET bl hw_watchdog_reset 40 #else 41 extern void hw_watchdog_reset(void); 42 43 #define WATCHDOG_RESET hw_watchdog_reset 44 #endif /* __ASSEMBLY__ */ 45#else 46 /* 47 * Maybe a software watchdog? 48 */ 49 #if defined(CONFIG_WATCHDOG) 50 #if defined(__ASSEMBLY__) 51 #define WATCHDOG_RESET bl watchdog_reset 52 #else 53 extern void watchdog_reset(void); 54 55 #define WATCHDOG_RESET watchdog_reset 56 #endif 57 #else 58 /* 59 * No hardware or software watchdog. 60 */ 61 #if defined(__ASSEMBLY__) 62 #define WATCHDOG_RESET /*XXX DO_NOT_DEL_THIS_COMMENT*/ 63 #else 64 #define WATCHDOG_RESET() {} 65 #endif /* __ASSEMBLY__ */ 66 #endif /* CONFIG_WATCHDOG && !__ASSEMBLY__ */ 67#endif /* CONFIG_HW_WATCHDOG */ 68 69/* 70 * Prototypes from $(CPU)/cpu.c. 71 */ 72 73/* MPC 8xx */ 74#if (defined(CONFIG_8xx) || defined(CONFIG_MPC860)) && !defined(__ASSEMBLY__) 75 void reset_8xx_watchdog(volatile immap_t *immr); 76#endif 77 78/* MPC 5xx */ 79#if defined(CONFIG_5xx) && !defined(__ASSEMBLY__) 80 void reset_5xx_watchdog(volatile immap_t *immr); 81#endif 82 83/* MPC 5xxx */ 84#if defined(CONFIG_MPC5xxx) && !defined(__ASSEMBLY__) 85 void reset_5xxx_watchdog(void); 86#endif 87 88/* AMCC 4xx */ 89#if defined(CONFIG_4xx) && !defined(__ASSEMBLY__) 90 void reset_4xx_watchdog(void); 91#endif 92 93#endif /* _WATCHDOG_H_ */ 94