mirror of
https://github.com/apache/nuttx.git
synced 2025-01-13 10:58:49 +08:00
wdog: add new API wd_start_realtime() support
Signed-off-by: ligd <liguiding1@xiaomi.com>
This commit is contained in:
parent
9c423ee5fa
commit
578ecef975
3 changed files with 157 additions and 0 deletions
|
@ -492,6 +492,28 @@ EXTERN volatile clock_t g_system_ticks;
|
||||||
} \
|
} \
|
||||||
while (0)
|
while (0)
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: clock_realtime2absticks
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Convert real time to monotonic ticks.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* mono - Return the converted time here.
|
||||||
|
* abstime - Convert this absolute time to ticks
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* OK (0) on success; a negated errno value on failure.
|
||||||
|
*
|
||||||
|
* Assumptions:
|
||||||
|
* Interrupts should be disabled so that the time is not changing during
|
||||||
|
* the calculation
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int clock_realtime2absticks(FAR const struct timespec *reltime,
|
||||||
|
FAR clock_t *absticks);
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: clock_compare
|
* Name: clock_compare
|
||||||
*
|
*
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
#include <nuttx/compiler.h>
|
||||||
#include <nuttx/clock.h>
|
#include <nuttx/clock.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
|
@ -176,6 +177,105 @@ int wd_start(FAR struct wdog_s *wdog, sclock_t delay,
|
||||||
int wd_start_abstick(FAR struct wdog_s *wdog, clock_t ticks,
|
int wd_start_abstick(FAR struct wdog_s *wdog, clock_t ticks,
|
||||||
wdentry_t wdentry, wdparm_t arg);
|
wdentry_t wdentry, wdparm_t arg);
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: wd_start_abstime
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* This function adds a watchdog timer to the active timer queue. The
|
||||||
|
* specified watchdog function at 'wdentry' will be called from the
|
||||||
|
* interrupt level after the specified number of ticks has reached.
|
||||||
|
* Watchdog timers may be started from the interrupt level.
|
||||||
|
*
|
||||||
|
* Watchdog timers execute in the address environment that was in effect
|
||||||
|
* when wd_start() is called.
|
||||||
|
*
|
||||||
|
* Watchdog timers execute only once.
|
||||||
|
*
|
||||||
|
* To replace either the timeout delay or the function to be executed,
|
||||||
|
* call wd_start again with the same wdog; only the most recent wdStart()
|
||||||
|
* on a given watchdog ID has any effect.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* wdog - Watchdog ID
|
||||||
|
* abstime - Absolute time with struct timespec
|
||||||
|
* wdentry - Function to call on timeout
|
||||||
|
* arg - Parameter to pass to wdentry.
|
||||||
|
*
|
||||||
|
* NOTE: The parameter must be of type wdparm_t.
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* Zero (OK) is returned on success; a negated errno value is return to
|
||||||
|
* indicate the nature of any failure.
|
||||||
|
*
|
||||||
|
* Assumptions:
|
||||||
|
* The watchdog routine runs in the context of the timer interrupt handler
|
||||||
|
* and is subject to all ISR restrictions.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#define wd_start_abstime(wdog, abstime, wdentry, arg) \
|
||||||
|
wd_start_abstick(wdog, clock_time2ticks(abstime), wdentry, arg)
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: wd_start_realtime
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* This function adds a watchdog timer to the active timer queue. The
|
||||||
|
* specified watchdog function at 'wdentry' will be called from the
|
||||||
|
* interrupt level after the specified number of ticks has reached.
|
||||||
|
* Watchdog timers may be started from the interrupt level.
|
||||||
|
*
|
||||||
|
* Watchdog timers execute in the address environment that was in effect
|
||||||
|
* when wd_start() is called.
|
||||||
|
*
|
||||||
|
* Watchdog timers execute only once.
|
||||||
|
*
|
||||||
|
* To replace either the timeout delay or the function to be executed,
|
||||||
|
* call wd_start again with the same wdog; only the most recent wdStart()
|
||||||
|
* on a given watchdog ID has any effect.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* wdog - Watchdog ID
|
||||||
|
* realtime - Realtime with struct timespec
|
||||||
|
* wdentry - Function to call on timeout
|
||||||
|
* arg - Parameter to pass to wdentry.
|
||||||
|
*
|
||||||
|
* NOTE: The parameter must be of type wdparm_t.
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* Zero (OK) is returned on success; a negated errno value is return to
|
||||||
|
* indicate the nature of any failure.
|
||||||
|
*
|
||||||
|
* Assumptions:
|
||||||
|
* The watchdog routine runs in the context of the timer interrupt handler
|
||||||
|
* and is subject to all ISR restrictions.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
static inline int wd_start_realtime(FAR struct wdog_s *wdog,
|
||||||
|
FAR const struct timespec *realtime,
|
||||||
|
wdentry_t wdentry,
|
||||||
|
wdparm_t arg)
|
||||||
|
{
|
||||||
|
#ifdef CONFIG_CLOCK_TIMEKEEPING
|
||||||
|
irqstate_t flags;
|
||||||
|
clock_t ticks;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
flags = enter_critical_section();
|
||||||
|
clock_abstime2ticks(CLOCK_REALTIME, realtime, &ticks);
|
||||||
|
ret = wd_start(wdog, ticks, wdentry, arg);
|
||||||
|
leave_critical_section(flags);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
#else
|
||||||
|
clock_t absticks;
|
||||||
|
|
||||||
|
clock_realtime2absticks(realtime, &absticks);
|
||||||
|
return wd_start_abstick(wdog, absticks, wdentry, arg);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: wd_cancel
|
* Name: wd_cancel
|
||||||
*
|
*
|
||||||
|
|
|
@ -104,3 +104,38 @@ int clock_abstime2ticks(clockid_t clockid,
|
||||||
|
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: clock_realtime2absticks
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Convert real time to monotonic ticks.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* mono - Return the converted time here.
|
||||||
|
* abstime - Convert this absolute time to ticks
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* OK (0) on success; a negated errno value on failure.
|
||||||
|
*
|
||||||
|
* Assumptions:
|
||||||
|
* Interrupts should be disabled so that the time is not changing during
|
||||||
|
* the calculation
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int clock_realtime2absticks(FAR const struct timespec *reltime,
|
||||||
|
FAR clock_t *absticks)
|
||||||
|
{
|
||||||
|
#ifndef CONFIG_CLOCK_TIMEKEEPING
|
||||||
|
struct timespec mono;
|
||||||
|
|
||||||
|
clock_timespec_subtract(reltime, &g_basetime, &mono);
|
||||||
|
|
||||||
|
*absticks = clock_time2ticks(&mono);
|
||||||
|
|
||||||
|
return OK;
|
||||||
|
#else
|
||||||
|
return -ENOSYS;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue