339cd6dec7630b6836bbd349eb5b2cfb7e3d8f11
[bertos.git] / drv / timer_i196.h
1 #error This code must be revised for the new timer API
2 /*!
3  * \file
4  * <!--
5  * Copyright 2003,2004 Develer S.r.l. (http://www.develer.com/)
6  * Copyright 2000 Bernardo Innocenti
7  * This file is part of DevLib - See README.devlib for information.
8  * -->
9  *
10  * \version $Id$
11  *
12  * \author Bernardo Innocenti <bernie@develer.com>
13  *
14  * \brief Low-level timer module for AVR
15  */
16
17 /*#*
18  *#* $Log$
19  *#* Revision 1.6  2006/02/21 21:28:02  bernie
20  *#* New time handling based on TIMER_TICKS_PER_SEC to support slow timers with ticks longer than 1ms.
21  *#*
22  *#* Revision 1.5  2005/11/04 16:20:02  bernie
23  *#* Fix reference to README.devlib in header.
24  *#*
25  *#* Revision 1.4  2004/12/13 11:51:08  bernie
26  *#* DISABLE_INTS/ENABLE_INTS: Convert to IRQ_DISABLE/IRQ_ENABLE.
27  *#*
28  *#* Revision 1.3  2004/08/25 14:12:08  rasky
29  *#* Aggiornato il comment block dei log RCS
30  *#*
31  *#* Revision 1.2  2004/06/03 11:27:09  bernie
32  *#* Add dual-license information.
33  *#*
34  *#* Revision 1.1  2004/05/23 18:23:30  bernie
35  *#* Import drv/timer module.
36  *#*
37  *#*/
38
39 #ifndef TIMER_I196_H
40 #define TIMER_I196_H
41
42 /*!
43  * Retrigger TIMER2, adjusting the time to account for
44  * the interrupt prologue latency.
45  */
46 #define TIMER_RETRIGGER (TIMER2 -= TICKS_RATE)
47
48 #define TIMER_INIT \
49         TIMER2 = (65535 - TICKS_RATE); \
50         INT_MASK1 |= INT1F_T2OVF; \
51         ATOMIC( \
52                 WSR = 1; \
53                 IOC3 |= IOC3F_T2_ENA; \
54                 WSR = 0; \
55         )
56
57 #define DEFINE_TIMER_ISR \
58         INTERRUPT(0x38) void TM2_OVFL_interrupt(void);  \
59         INTERRUPT(0x38) void TM2_OVFL_interrupt(void)
60
61 #endif /* DRV_TIMER_I196_H */