diff options
Diffstat (limited to 'firmware/target/arm/tcc77x/kernel-tcc77x.c')
-rw-r--r-- | firmware/target/arm/tcc77x/kernel-tcc77x.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/firmware/target/arm/tcc77x/kernel-tcc77x.c b/firmware/target/arm/tcc77x/kernel-tcc77x.c new file mode 100644 index 0000000000..17c6ff0734 --- /dev/null +++ b/firmware/target/arm/tcc77x/kernel-tcc77x.c | |||
@@ -0,0 +1,45 @@ | |||
1 | /*************************************************************************** | ||
2 | * __________ __ ___. | ||
3 | * Open \______ \ ____ ____ | | _\_ |__ _______ ___ | ||
4 | * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / | ||
5 | * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < | ||
6 | * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ | ||
7 | * \/ \/ \/ \/ \/ | ||
8 | * $Id$ | ||
9 | * | ||
10 | * Copyright (C) 2008 by Rob Purchase | ||
11 | * | ||
12 | * All files in this archive are subject to the GNU General Public License. | ||
13 | * See the file COPYING in the source tree root for full license agreement. | ||
14 | * | ||
15 | * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||
16 | * KIND, either express or implied. | ||
17 | * | ||
18 | ****************************************************************************/ | ||
19 | |||
20 | #include "config.h" | ||
21 | #include "system.h" | ||
22 | #include "kernel.h" | ||
23 | #include "timer.h" | ||
24 | #include "thread.h" | ||
25 | |||
26 | void tick_start(unsigned int interval_in_ms) | ||
27 | { | ||
28 | /* configure Timer T-Clock to 2Mhz (clock source 4 (Xin) divided by 6) */ | ||
29 | PCLKCFG4 = (1 << 31) | (4 << 28) | (5 << 16); | ||
30 | |||
31 | /* disable Timer0 */ | ||
32 | TCFG0 &= ~1; | ||
33 | |||
34 | /* set counter reference value based on 1Mhz tick */ | ||
35 | TREF0 = interval_in_ms * 1000; | ||
36 | |||
37 | /* Timer0 = reset to 0, divide=2, IRQ enable, enable (continuous) */ | ||
38 | TCFG0 = (1<<8) | (0<<4) | (1<<3) | 1; | ||
39 | |||
40 | /* Unmask timer IRQ */ | ||
41 | IEN |= TIMER0_IRQ_MASK; | ||
42 | } | ||
43 | |||
44 | /* NB: Since we are using a single timer IRQ, tick tasks are dispatched as | ||
45 | part of the central timer IRQ processing in timer-tcc77x.c */ | ||