X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=drv%2Fwdt.h;h=1db1053841b438c81e3490e74d43bc16caf8983b;hb=626fc0c49d8ba16ccd126d5329faeb3351088cdf;hp=9f57618f663b26b46be162379a050e141ffb7839;hpb=bbc33efb70a0062b36cc415452922e7ba69c748f;p=bertos.git diff --git a/drv/wdt.h b/drv/wdt.h old mode 100755 new mode 100644 index 9f57618f..1db10538 --- a/drv/wdt.h +++ b/drv/wdt.h @@ -1,8 +1,33 @@ -/*! +/** * \file * * * \version $Id$ @@ -12,35 +37,12 @@ * \brief Watchdog interface */ -/*#* - *#* $Log$ - *#* Revision 1.7 2005/11/27 03:58:40 bernie - *#* Add POSIX timer emulator. - *#* - *#* Revision 1.6 2005/11/27 03:03:08 bernie - *#* Add Qt support hack. - *#* - *#* Revision 1.5 2005/11/04 16:20:02 bernie - *#* Fix reference to README.devlib in header. - *#* - *#* Revision 1.4 2005/04/12 01:37:17 bernie - *#* Prevent warning when watchdog is disabled. - *#* - *#* Revision 1.3 2005/04/11 19:10:28 bernie - *#* Include top-level headers from cfg/ subdir. - *#* - *#* Revision 1.2 2004/11/16 21:02:07 bernie - *#* Make driver optional; mark AVR specific parts as such. - *#* - *#* Revision 1.1 2004/10/26 08:34:47 bernie - *#* New DevLib module. - *#* - *#*/ #ifndef DRV_WDT_H #define DRV_WDT_H #include #include // INLINE +#include /* Configury sanity check */ #if !defined(CONFIG_WATCHDOG) || (CONFIG_WATCHDOG != 0 && CONFIG_WATCHDOG != 1) @@ -48,22 +50,31 @@ #endif #if CONFIG_WATCHDOG - #include + #include #include #if OS_QT - #include + #if _QT < 4 + #include + #else + #include + #endif #elif OS_POSIX #include #elif CPU_AVR #include #include // BV() + #if CPU_AVR_ATMEGA1281 // Name is different in atmega1281 + #define WDTCR WDTCSR + #endif + #elif defined(ARCH_FREERTOS) && (ARCH & ARCH_FREERTOS) + #include /* taskYIELD() */ #else #error unknown CPU #endif #endif /* CONFIG_WATCHDOG */ -/*! +/** * Reset the watchdog timer. */ INLINE void wdt_reset(void) @@ -76,6 +87,8 @@ INLINE void wdt_reset(void) #elif OS_POSIX static struct timeval tv = { 0, 0 }; select(0, NULL, NULL, NULL, &tv); + #elif defined(ARCH_FREERTOS) && (ARCH & ARCH_FREERTOS) + vTaskDelay(1); #elif CPU_AVR __asm__ __volatile__ ("wdr"); #else @@ -84,7 +97,7 @@ INLINE void wdt_reset(void) #endif /* CONFIG_WATCHDOG */ } -/*! +/** * Set watchdog timer timeout. * * \param timeout 0: 16.3ms, 7: 2.1s @@ -102,6 +115,8 @@ INLINE void wdt_init(uint8_t timeout) (void)timeout; #elif OS_POSIX (void)timeout; // NOP + #elif defined(ARCH_FREERTOS) && (ARCH & ARCH_FREERTOS) + /* nop */ #elif CPU_AVR WDTCR |= BV(WDCE) | BV(WDE); WDTCR = timeout; @@ -120,6 +135,8 @@ INLINE void wdt_start(void) // NOP #elif OS_POSIX // NOP + #elif defined(ARCH_FREERTOS) && (ARCH & ARCH_FREERTOS) + /* nop */ #elif CPU_AVR WDTCR |= BV(WDE); #else @@ -135,6 +152,8 @@ INLINE void wdt_stop(void) // NOP #elif OS_POSIX // NOP + #elif defined(ARCH_FREERTOS) && (ARCH & ARCH_FREERTOS) + /* nop */ #elif CPU_AVR WDTCR |= BV(WDCE) | BV(WDE); WDTCR &= ~BV(WDE);