X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=drv%2Ftimer.h;h=d88168f078e816299845d678453e81706bbd40c9;hb=f4728b42ccad4af069fb30adea6e5a0527bcf566;hp=da5a5d1c87ec3e544f7165c44eefa80918c861c9;hpb=1da31e2b251edb8174ea591b67da33b1ac27b554;p=bertos.git diff --git a/drv/timer.h b/drv/timer.h index da5a5d1c..d88168f0 100755 --- a/drv/timer.h +++ b/drv/timer.h @@ -15,6 +15,16 @@ /* * $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. * @@ -51,10 +61,11 @@ #include "cpu.h" #include "compiler.h" +#include #include /*! Number of timer ticks per second. */ -#define TICKS_PER_SEC 1000 +#define TICKS_PER_SEC ((time_t)1000) /* Function protos */ extern void timer_init(void); @@ -74,7 +85,7 @@ extern void timer_udelay(utime_t utime); #endif /*! - * The timer driver supports multiple ssynchronous timers + * The timer driver supports multiple synchronous timers * that can trigger an event when they expire. * * \sa timer_add() @@ -125,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. @@ -141,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; @@ -153,24 +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(); +} /*! - * Faster version of timer_tick(), to be called only when the timer + * 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 */