summaryrefslogtreecommitdiff
path: root/firmware/target/arm/tcc77x/kernel-tcc77x.c
diff options
context:
space:
mode:
Diffstat (limited to 'firmware/target/arm/tcc77x/kernel-tcc77x.c')
-rw-r--r--firmware/target/arm/tcc77x/kernel-tcc77x.c45
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
26void 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 */