X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=drv%2Ftimer.c;h=92152bc1059f6a1063a45d70c219ba72f300eacb;hb=0168eb0bee0da568cd3ea8f8dfffa9343175efd9;hp=b2caf90d9706526aed8ba8f065c40a2a7e5c4ee6;hpb=e36fa6f27fe2d6abf188913f058a4f95d287a308;p=bertos.git diff --git a/drv/timer.c b/drv/timer.c index b2caf90d..92152bc1 100755 --- a/drv/timer.c +++ b/drv/timer.c @@ -1,62 +1,73 @@ /*! * \file * * - * \version $Id$ + * \brief Hardware independent timer driver (implementation) * + * \version $Id$ * \author Bernardo Innocenti - * - * \brief Hardware independent timer driver (implementation) */ -/* - * $Log$ - * Revision 1.13 2004/08/10 06:59:09 bernie - * timer_gettick(): Rename to timer_ticks() and add backwards compatibility inline. - * - * Revision 1.12 2004/08/08 05:59:37 bernie - * Remove a few useless casts. - * - * Revision 1.11 2004/08/02 20:20:29 aleph - * Merge from project_ks - * - * Revision 1.10 2004/07/30 14:15:53 rasky - * Nuovo supporto unificato per detect della CPU - * - * Revision 1.9 2004/07/21 00:15:13 bernie - * Put timer driver on diet. - * - * Revision 1.8 2004/07/18 21:57:07 bernie - * Fix preprocessor warning with potentially undefined symbol. - * - * Revision 1.6 2004/06/07 18:10:06 aleph - * Remove free pool of timers; use user-provided Timer structure instead - * - * Revision 1.5 2004/06/07 15:56:55 aleph - * Some tabs cleanup and add timer strobe macros - * - * Revision 1.4 2004/06/06 18:25:44 bernie - * Rename event macros to look like regular functions. - * - * Revision 1.3 2004/06/06 17:18:42 bernie - * Fix \!CONFIG_KERN_SIGNALS code paths. - * - * Revision 1.2 2004/06/03 11:27:09 bernie - * Add dual-license information. - * - * Revision 1.1 2004/05/23 18:23:30 bernie - * Import drv/timer module. - * - */ +/*#* + *#* $Log$ + *#* Revision 1.17 2004/10/03 18:52:08 bernie + *#* Move \brief on top in header to please Doxygen. + *#* + *#* Revision 1.16 2004/10/03 18:48:01 bernie + *#* timer_delay(): Add a sanity check to avoid sleeping forever. + *#* + *#* Revision 1.15 2004/09/14 21:07:18 bernie + *#* Use debug.h instead of kdebug.h. + *#* + *#* Revision 1.14 2004/08/25 14:12:08 rasky + *#* Aggiornato il comment block dei log RCS + *#* + *#* Revision 1.13 2004/08/10 06:59:09 bernie + *#* timer_gettick(): Rename to timer_ticks() and add backwards compatibility inline. + *#* + *#* Revision 1.12 2004/08/08 05:59:37 bernie + *#* Remove a few useless casts. + *#* + *#* Revision 1.11 2004/08/02 20:20:29 aleph + *#* Merge from project_ks + *#* + *#* Revision 1.10 2004/07/30 14:15:53 rasky + *#* Nuovo supporto unificato per detect della CPU + *#* + *#* Revision 1.9 2004/07/21 00:15:13 bernie + *#* Put timer driver on diet. + *#* + *#* Revision 1.8 2004/07/18 21:57:07 bernie + *#* Fix preprocessor warning with potentially undefined symbol. + *#* + *#* Revision 1.6 2004/06/07 18:10:06 aleph + *#* Remove free pool of timers; use user-provided Timer structure instead + *#* + *#* Revision 1.5 2004/06/07 15:56:55 aleph + *#* Some tabs cleanup and add timer strobe macros + *#* + *#* Revision 1.4 2004/06/06 18:25:44 bernie + *#* Rename event macros to look like regular functions. + *#* + *#* Revision 1.3 2004/06/06 17:18:42 bernie + *#* Fix \!CONFIG_KERN_SIGNALS code paths. + *#* + *#* Revision 1.2 2004/06/03 11:27:09 bernie + *#* Add dual-license information. + *#* + *#* Revision 1.1 2004/05/23 18:23:30 bernie + *#* Import drv/timer module. + *#* + *#*/ -#include "hw.h" -#include "kdebug.h" #include "timer.h" +#include #include CPU_HEADER(timer) +#include #if defined(CONFIG_KERN_SIGNALS) && CONFIG_KERN_SIGNALS #include @@ -133,6 +144,11 @@ Timer *timer_abort(Timer *timer) */ void timer_delay(time_t time) { +#if defined(IRQ_GETSTATE) + /* We shouldn't sleep with interrupts disabled */ + ASSERT(IRQ_GETSTATE()); +#endif + #if defined(CONFIG_KERN_SIGNALS) && CONFIG_KERN_SIGNALS Timer t;