X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=drv%2Ftimer.h;h=d88168f078e816299845d678453e81706bbd40c9;hb=ed046ec2e30d22f13729f02739a5aa80806d72ec;hp=5a9c93e2b3f2a633bfe715e761046930eae9857e;hpb=2708af4ade1a189c58adb4a6e543ea80be781730;p=bertos.git diff --git a/drv/timer.h b/drv/timer.h index 5a9c93e2..d88168f0 100755 --- a/drv/timer.h +++ b/drv/timer.h @@ -15,6 +15,19 @@ /* * $Log$ + * Revision 1.15 2004/08/10 06:59:09 bernie + * timer_gettick(): Rename to timer_ticks() and add backwards compatibility inline. + * + * Revision 1.12 2004/07/30 14:34:10 rasky + * Vari fix per documentazione e commenti + * Aggiunte PP_CATn e STATIC_ASSERT + * + * Revision 1.11 2004/07/29 22:40:12 bernie + * Spelling fix. + * + * Revision 1.10 2004/07/21 00:13:57 bernie + * Put timer driver on diet. + * * Revision 1.9 2004/07/20 23:45:01 bernie * Finally remove redundant protos. * @@ -48,17 +61,36 @@ #include "cpu.h" #include "compiler.h" +#include #include +/*! Number of timer ticks per second. */ +#define TICKS_PER_SEC ((time_t)1000) + +/* Function protos */ +extern void timer_init(void); +extern void timer_delay(time_t time); + +#ifndef CONFIG_TIMER_DISABLE_UDELAY +extern void timer_udelay(utime_t utime); +#endif + + +#ifndef CONFIG_TIMER_DISABLE_EVENTS + #ifdef CONFIG_KERNEL #include #else #include #endif -/*! Number of timer ticks per second. */ -#define TICKS_PER_SEC 1000 - +/*! + * The timer driver supports multiple synchronous timers + * that can trigger an event when they expire. + * + * \sa timer_add() + * \sa timer_abort() + */ typedef struct Timer { Node link; /*!< Link into timers queue */ @@ -67,12 +99,8 @@ typedef struct Timer Event expire; /*!< Event to execute when the timer expires */ } Timer; -/* Function protos */ -extern void timer_init(void); extern void timer_add(Timer *timer); extern Timer *timer_abort(Timer *timer); -extern void timer_delay(time_t time); -extern void timer_udelay(utime_t utime); #if defined(CONFIG_KERN_SIGNALS) && CONFIG_KERN_SIGNALS @@ -96,6 +124,7 @@ INLINE void timer_set_delay(Timer* timer, time_t delay) timer->delay = delay; } +#endif /* CONFIG_TIMER_DISABLE_EVENTS */ extern volatile time_t _clock; @@ -107,14 +136,14 @@ extern volatile time_t _clock; * * The following code is safe: * - * \example + * \code * time_t tea_start_time = get_tick(); * * boil_water(); * * if (get_tick() - tea_start_time > TEAPOT_DELAY) * printf("Your tea, Sir.\n"); - * \endexample + * \endcode * * When the tick counter increments every millisecond and time_t * is 32bit wide, the tick count will overflow every 49.7 days. @@ -123,7 +152,7 @@ extern volatile time_t _clock; * clock variable is larger than the processor word size and can't * be copied atomically. */ -INLINE time_t timer_tick(void) +INLINE time_t timer_ticks(void) { time_t result; cpuflags_t flags; @@ -135,23 +164,41 @@ INLINE time_t timer_tick(void) return result; } -/* OBSOLETE */ -#define timer_gettick timer_tick +DEPRECATED INLINE time_t timer_gettick(void) +{ + return timer_ticks(); +} /*! - * Like \c timer_tick, faster version to be called - * from interrupt context only. + * Faster version of timer_ticks(), to be called only when the timer + * interrupt is disabled (DISABLE_INTS) or overridden by a + * higher-priority or non-nesting interrupt. * - * \sa timer_tick + * \sa timer_ticks */ -INLINE time_t timer_tick_unlocked(void) +INLINE time_t timer_ticks_unlocked(void) { return _clock; } -/* OBSOLETE */ -#define timer_gettick_irq timer_tick_unlocked +DEPRECATED INLINE time_t timer_gettick_irq(void) +{ + return timer_ticks_unlocked(); +} + + +/*! + * Return the minutes passed since timer start. + * + * The minutes uptime is computed directly from system tick counter: + * in case of a 4 bytes time_t after 71582 minutes the value will + * wrap around. + */ +INLINE time_t timer_minutes(void) +{ + return timer_ticks() / (TICKS_PER_SEC * 60); +} #endif /* DRV_TIMER_H */