X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=drv%2Ftimer.h;h=09d97c1307a7b78a10a2e0e934482d79dbb6f2f9;hb=4afd09ec0c80aa1611fc3b5a3517e9c0d1755cfd;hp=da5a5d1c87ec3e544f7165c44eefa80918c861c9;hpb=1da31e2b251edb8174ea591b67da33b1ac27b554;p=bertos.git diff --git a/drv/timer.h b/drv/timer.h index da5a5d1c..09d97c13 100755 --- a/drv/timer.h +++ b/drv/timer.h @@ -15,6 +15,19 @@ /* * $Log$ + * Revision 1.14 2004/08/03 15:50:03 aleph + * Rename timer_tick() to timer_ticks() + * + * Revision 1.13 2004/08/02 20:20:29 aleph + * Merge from project_ks + * + * 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 +64,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 +88,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 +139,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 +155,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; @@ -154,23 +168,36 @@ INLINE time_t timer_tick(void) } /* OBSOLETE */ -#define timer_gettick timer_tick +#define timer_gettick 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 +#define timer_gettick_irq 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 */