forked from rrcarlosr/Jetpack
103 lines
2.3 KiB
C
103 lines
2.3 KiB
C
/*
|
|
* (C) Copyright 2001
|
|
* Erik Theisen, Wave 7 Optics, etheisen@mindspring.com.
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
/*
|
|
* Watchdog functions and macros.
|
|
*/
|
|
#ifndef _WATCHDOG_H_
|
|
#define _WATCHDOG_H_
|
|
|
|
#if !defined(__ASSEMBLY__)
|
|
/*
|
|
* Reset the watchdog timer, always returns 0
|
|
*
|
|
* This function is here since it is shared between board_f() and board_r(),
|
|
* and the legacy arch/<arch>/board.c code.
|
|
*/
|
|
int init_func_watchdog_reset(void);
|
|
#endif
|
|
|
|
#if defined(CONFIG_WATCHDOG) || defined(CONFIG_HW_WATCHDOG)
|
|
#define INIT_FUNC_WATCHDOG_INIT init_func_watchdog_init,
|
|
#define INIT_FUNC_WATCHDOG_RESET init_func_watchdog_reset,
|
|
#else
|
|
#define INIT_FUNC_WATCHDOG_INIT
|
|
#define INIT_FUNC_WATCHDOG_RESET
|
|
#endif
|
|
|
|
#if defined(CONFIG_HW_WATCHDOG) && defined(CONFIG_WATCHDOG)
|
|
# error "Configuration error: CONFIG_HW_WATCHDOG and CONFIG_WATCHDOG can't be used together."
|
|
#endif
|
|
|
|
/*
|
|
* Hardware watchdog
|
|
*/
|
|
#ifdef CONFIG_HW_WATCHDOG
|
|
#if defined(__ASSEMBLY__)
|
|
#define WATCHDOG_RESET bl hw_watchdog_reset
|
|
#else
|
|
extern void hw_watchdog_reset(void);
|
|
|
|
#define WATCHDOG_RESET hw_watchdog_reset
|
|
#endif /* __ASSEMBLY__ */
|
|
#else
|
|
/*
|
|
* Maybe a software watchdog?
|
|
*/
|
|
#if defined(CONFIG_WATCHDOG)
|
|
#if defined(__ASSEMBLY__)
|
|
#define WATCHDOG_RESET bl watchdog_reset
|
|
#else
|
|
extern void watchdog_reset(void);
|
|
|
|
#define WATCHDOG_RESET watchdog_reset
|
|
#endif
|
|
#else
|
|
/*
|
|
* No hardware or software watchdog.
|
|
*/
|
|
#if defined(__ASSEMBLY__)
|
|
#define WATCHDOG_RESET /*XXX DO_NOT_DEL_THIS_COMMENT*/
|
|
#else
|
|
#define WATCHDOG_RESET() {}
|
|
#endif /* __ASSEMBLY__ */
|
|
#endif /* CONFIG_WATCHDOG && !__ASSEMBLY__ */
|
|
#endif /* CONFIG_HW_WATCHDOG */
|
|
|
|
/*
|
|
* Prototypes from $(CPU)/cpu.c.
|
|
*/
|
|
|
|
/* MPC 8xx */
|
|
#if (defined(CONFIG_8xx) || defined(CONFIG_MPC860)) && !defined(__ASSEMBLY__)
|
|
void reset_8xx_watchdog(volatile immap_t *immr);
|
|
#endif
|
|
|
|
/* MPC 5xx */
|
|
#if defined(CONFIG_5xx) && !defined(__ASSEMBLY__)
|
|
void reset_5xx_watchdog(volatile immap_t *immr);
|
|
#endif
|
|
|
|
/* MPC 5xxx */
|
|
#if defined(CONFIG_MPC5xxx) && !defined(__ASSEMBLY__)
|
|
void reset_5xxx_watchdog(void);
|
|
#endif
|
|
|
|
/* AMCC 4xx */
|
|
#if defined(CONFIG_4xx) && !defined(__ASSEMBLY__)
|
|
void reset_4xx_watchdog(void);
|
|
#endif
|
|
|
|
#if defined(CONFIG_HW_WATCHDOG) && !defined(__ASSEMBLY__)
|
|
void hw_watchdog_init(void);
|
|
#endif
|
|
|
|
#if defined(CONFIG_MPC85xx) && !defined(__ASSEMBLY__)
|
|
void init_85xx_watchdog(void);
|
|
#endif
|
|
#endif /* _WATCHDOG_H_ */
|