blob: e5d96d288ac85d63b0ca4ccac7b12240963e263e [file] [log] [blame]
Rob Purchase47ea0302008-01-14 22:04:48 +00001/***************************************************************************
2* __________ __ ___.
3* Open \______ \ ____ ____ | | _\_ |__ _______ ___
4* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7* \/ \/ \/ \/ \/
8* $Id$
9*
10* Copyright (C) 2008 by Rob Purchase
11*
Daniel Stenberg2acc0ac2008-06-28 18:10:04 +000012* This program is free software; you can redistribute it and/or
13* modify it under the terms of the GNU General Public License
14* as published by the Free Software Foundation; either version 2
15* of the License, or (at your option) any later version.
Rob Purchase47ea0302008-01-14 22:04:48 +000016*
17* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18* KIND, either express or implied.
19*
20****************************************************************************/
21
22#include "config.h"
23#include "system.h"
24#include "kernel.h"
25#include "timer.h"
26#include "thread.h"
27
28/* NB: PCK_TCT must previously have been set to 2Mhz by calling clock_init() */
29void tick_start(unsigned int interval_in_ms)
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 */
Rob Purchase4dc2d8d2008-03-22 19:41:51 +000041 IEN |= TIMER0_IRQ_MASK;
Rob Purchase47ea0302008-01-14 22:04:48 +000042}
43
Rob Purchase4dc2d8d2008-03-22 19:41:51 +000044/* NB: Since we are using a single timer IRQ, tick tasks are dispatched as
45 part of the central timer IRQ processing in timer-tcc780x.c */