mirror of
https://github.com/apache/nuttx.git
synced 2025-01-12 22:08:35 +08:00
drivers/timers/watchdog: add watchdog timer notifier chain
Add support for watchdog timer notifer chain so that users can customize the callback function when the watchdog timer times out which enabled by Auto-monitor Signed-off-by: yaojiaqi <yaojiaqi@lixiang.com>
This commit is contained in:
parent
aa0aecbd80
commit
43797ea6cc
3 changed files with 146 additions and 0 deletions
|
@ -439,6 +439,14 @@ menuconfig WATCHDOG_AUTOMONITOR
|
||||||
|
|
||||||
if WATCHDOG_AUTOMONITOR
|
if WATCHDOG_AUTOMONITOR
|
||||||
|
|
||||||
|
config WATCHDOG_TIMEOUT_NOTIFIER
|
||||||
|
bool "Enable watchdog timeout notifier"
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
The watchdog timeout notifier chain mechanism supports users registering
|
||||||
|
custom callback functions, which will be called when the watchdog timer
|
||||||
|
managed by Auto-monitor times out.
|
||||||
|
|
||||||
choice
|
choice
|
||||||
prompt "Auto-monitor keepalive by"
|
prompt "Auto-monitor keepalive by"
|
||||||
default WATCHDOG_AUTOMONITOR_BY_WDOG
|
default WATCHDOG_AUTOMONITOR_BY_WDOG
|
||||||
|
|
|
@ -71,6 +71,20 @@
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_WATCHDOG_AUTOMONITOR_BY_ONESHOT)
|
||||||
|
# define WATCHDOG_NOTIFIER_ACTION WATCHDOG_KEEPALIVE_BY_ONESHOT
|
||||||
|
#elif defined(CONFIG_WATCHDOG_AUTOMONITOR_BY_TIMER)
|
||||||
|
# define WATCHDOG_NOTIFIER_ACTION WATCHDOG_KEEPALIVE_BY_TIMER
|
||||||
|
#elif defined(CONFIG_WATCHDOG_AUTOMONITOR_BY_WDOG)
|
||||||
|
# define WATCHDOG_NOTIFIER_ACTION WATCHDOG_KEEPALIVE_BY_WDOG
|
||||||
|
#elif defined(CONFIG_WATCHDOG_AUTOMONITOR_BY_WORKER)
|
||||||
|
# define WATCHDOG_NOTIFIER_ACTION WATCHDOG_KEEPALIVE_BY_WORKER
|
||||||
|
#elif defined(CONFIG_WATCHDOG_AUTOMONITOR_BY_CAPTURE)
|
||||||
|
# define WATCHDOG_NOTIFIER_ACTION WATCHDOG_KEEPALIVE_BY_CAPTURE
|
||||||
|
#elif defined(CONFIG_WATCHDOG_AUTOMONITOR_BY_IDLE)
|
||||||
|
# define WATCHDOG_NOTIFIER_ACTION WATCHDOG_KEEPALIVE_BY_IDLE
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Type Definitions
|
* Private Type Definitions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
@ -135,6 +149,10 @@ static const struct file_operations g_wdogops =
|
||||||
wdog_ioctl, /* ioctl */
|
wdog_ioctl, /* ioctl */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef CONFIG_WATCHDOG_TIMEOUT_NOTIFIER
|
||||||
|
static ATOMIC_NOTIFIER_HEAD(g_watchdog_notifier_list);
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Functions
|
* Private Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
@ -699,6 +717,55 @@ static int wdog_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_WATCHDOG_TIMEOUT_NOTIFIER
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: watchdog_notifier_chain_register
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Add notifier to the watchdog notifier chain
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* nb - New entry in notifier chain
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void watchdog_notifier_chain_register(FAR struct notifier_block *nb)
|
||||||
|
{
|
||||||
|
atomic_notifier_chain_register(&g_watchdog_notifier_list, nb);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: watchdog_notifier_chain_unregister
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Remove notifier from the watchdog notifier chain
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* nb - Entry to remove from notifier chain
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void watchdog_notifier_chain_unregister(FAR struct notifier_block *nb)
|
||||||
|
{
|
||||||
|
atomic_notifier_chain_unregister(&g_watchdog_notifier_list, nb);
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: watchdog_automonitor_timeout
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* This function can be called in the watchdog timeout interrupt handler.
|
||||||
|
* If so, callbacks on the watchdog timer notify chain are called when the
|
||||||
|
* watchdog timer times out.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void watchdog_automonitor_timeout(void)
|
||||||
|
{
|
||||||
|
atomic_notifier_call_chain(&g_watchdog_notifier_list, action, data);
|
||||||
|
}
|
||||||
|
#endif /* CONFIG_WATCHDOG_TIMEOUT_NOTIFIER */
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: watchdog_register
|
* Name: watchdog_register
|
||||||
*
|
*
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
#include <nuttx/compiler.h>
|
#include <nuttx/compiler.h>
|
||||||
#include <nuttx/irq.h>
|
#include <nuttx/irq.h>
|
||||||
#include <nuttx/fs/ioctl.h>
|
#include <nuttx/fs/ioctl.h>
|
||||||
|
#include <nuttx/notifier.h>
|
||||||
|
|
||||||
#ifdef CONFIG_WATCHDOG
|
#ifdef CONFIG_WATCHDOG
|
||||||
|
|
||||||
|
@ -88,6 +89,35 @@
|
||||||
#define WDFLAGS_CAPTURE (1 << 2) /* 1=Call the user function when the
|
#define WDFLAGS_CAPTURE (1 << 2) /* 1=Call the user function when the
|
||||||
* watchdog timer expires */
|
* watchdog timer expires */
|
||||||
|
|
||||||
|
/* Keepalive Actions ********************************************************/
|
||||||
|
|
||||||
|
/* According to the keepalive action specified by the Auto-monitor, callback
|
||||||
|
* functions registered on the watchdog notifier chain may take corresponding
|
||||||
|
* actions.
|
||||||
|
*
|
||||||
|
* These are detected and handled by the "upper half" watchdog timer driver.
|
||||||
|
*
|
||||||
|
* WATCHDOG_KEEPALIVE_BY_ONESHOT - The watchdog timer is keepalive by
|
||||||
|
* oneshot timer.
|
||||||
|
* WATCHDOG_KEEPALIVE_BY_TIMER - The watchdog timer is keepalive by
|
||||||
|
* timer.
|
||||||
|
* WATCHDOG_KEEPALIVE_BY_WDOG - The watchdog timer is keepalive by
|
||||||
|
* wdog.
|
||||||
|
* WATCHDOG_KEEPALIVE_BY_WORKER - The watchdog timer is keepalive by
|
||||||
|
* worker queue.
|
||||||
|
* WATCHDOG_KEEPALIVE_BY_CAPTURE - The watchdog timer is keepalive by
|
||||||
|
* capture.
|
||||||
|
* WATCHDOG_KEEPALIVE_BY_IDLE - The watchdog timer is keepalive by
|
||||||
|
* idle task.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define WATCHDOG_KEEPALIVE_BY_ONESHOT 0
|
||||||
|
#define WATCHDOG_KEEPALIVE_BY_TIMER 1
|
||||||
|
#define WATCHDOG_KEEPALIVE_BY_WDOG 2
|
||||||
|
#define WATCHDOG_KEEPALIVE_BY_WORKER 3
|
||||||
|
#define WATCHDOG_KEEPALIVE_BY_CAPTURE 4
|
||||||
|
#define WATCHDOG_KEEPALIVE_BY_IDLE 5
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Types
|
* Public Types
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
@ -197,6 +227,47 @@ extern "C"
|
||||||
#define EXTERN extern
|
#define EXTERN extern
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_WATCHDOG_TIMEOUT_NOTIFIER
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: watchdog_notifier_chain_register
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Add notifier to the watchdog notifier chain
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* nb - New entry in notifier chain
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void watchdog_notifier_chain_register(FAR struct notifier_block *nb);
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: watchdog_notifier_chain_unregister
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Remove notifier from the watchdog notifier chain
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* nb - Entry to remove from notifier chain
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void watchdog_notifier_chain_unregister(FAR struct notifier_block *nb);
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: watchdog_automonitor_timeout
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* This function can be called in the watchdog timeout interrupt handler.
|
||||||
|
* If so, callbacks on the watchdog timer notify chain are called when the
|
||||||
|
* watchdog timer times out.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void watchdog_automonitor_timeout(void);
|
||||||
|
|
||||||
|
#endif /* CONFIG_WATCHDOG_TIMEOUT_NOTIFIER */
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: watchdog_register
|
* Name: watchdog_register
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in a new issue