3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Just Standard Profile Kernel
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
9 * TOPPERS/JSP for Blackfin
11 * Copyright (C) 2004,2006,2006 by Takemasa Nakamura
12 * Copyright (C) 2004 by Ujinosuke
14 * 上記著作権者は,以下の (1)縲鰀(4) の条件か,Free Software Foundation
15 * によって公表されている GNU General Public License の Version 2 に記
16 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
17 * を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
19 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
20 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
22 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
23 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
24 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
26 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
27 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
29 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
30 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
31 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
33 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
34 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
36 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
37 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
38 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
39 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
45 * タイマドライバ(ADSP-BF533用)
52 #include <s_services.h>
60 /**************************************************************
63 * タイマを初期化し,周期的なタイマ割込み要求を発生させる.
65 **************************************************************/
71 // TCNTL bit assignement
74 // TAUTORLD 0x00000004
76 *__pTCNTL = 0x00000001; // TMPWR : power up timer;
77 *__pTPERIOD = CORECLOCK/1000; // CORE CLOCK is defined in sys_config.h
78 *__pTCNTL = 0x00000007; // TMPWR | TMREN | TAUTORLD;
80 // GPT2(General-purpose timer2)
83 /* TIMERx_CONFIG Registers */
96 *__pTIMER2_CONFIG = 0x0059; // PERIOD_CNT | OUT_DIS |IRQ_ENA | PWM_OUT ( PWM_OUT, Output Pad disable)
97 *__pTIMER2_PERIOD = SYSCLOCK/1000; // SYS CLOCK is defined in sys_config.h
98 *__pTIMER2_WIDTH = 1; // 0 < width < period
103 *__pTIMER_ENABLE = 0x004; // TIMEN2 timer2 start
105 ena_int( INHNO_TIMER ); // enable Timer Interrupt
111 /**************************************************************
113 **************************************************************/
119 // TCNTL bit assignement
122 // TAUTORLD 0x00000004
125 /* TINTはW1Cではないので、TINTのTINTビットは0を書き込む */
126 *__pTCNTL = 0x00000007; // TMPWR | TMREN | TAUTORLD;
128 // GPT2(General-purpose timer2)
133 *__pTIMER_STATUS = 0x004; // TIMIL2, Clear interrupt
138 /**************************************************************
142 **************************************************************/
151 // TCNTL bit assignement
154 // TAUTORLD 0x00000004
156 *__pTCNTL = 0x00000005; //TMPWR | TAUTORLD | TINT; // 停止
157 *__pTCNTL = 0; // パワーダウンモード
159 // GPT2(General-purpose timer2)
163 *__pTIMER_DISABLE = 0x004; // TIMDIS2, timer2 disable
169 #endif /* _MACRO_ONLY */
170 #endif /* _HW_TIMER_H_ */