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,2009 by Takemasa Nakamura
12 * Copyright (C) 2004 by Ujinosuke
13 * Copyright (C) 2010,2011 by Kaneko System Co., Ltd.
15 * 上記著作権者は,以下の (1)~(4) の条件か,Free Software Foundation
16 * によって公表されている GNU General Public License の Version 2 に記
17 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
18 * を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
20 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
21 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
23 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
24 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
25 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
27 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
28 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
30 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
31 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
32 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
34 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
35 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
37 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
38 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
39 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
40 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
46 * タイマドライバ(ADSP-BF548用)
53 #include <s_services.h>
58 #ifdef __GNUC__ // gcc
59 #include "cdefBF548.h"
60 #elif defined(__ECC__) // visualdsp
61 #include <cdefbf548.h>
63 #error "Compiler is not supported"
66 //#include <ccblkfn.h>
71 /**************************************************************
74 * タイマを初期化し,周期的なタイマ割込み要求を発生させる.
76 **************************************************************/
83 *pTCNTL = TMPWR; // power up timer;
84 *pTPERIOD = CORECLOCK/1000; // CORE CLOCK is defined in sys_config.h
85 *pTCNTL = TMPWR | TMREN | TAUTORLD;
87 // GPT7(General-purpose timer7)
89 *pTIMER7_CONFIG = PERIOD_CNT | OUT_DIS |IRQ_ENA | PWM_OUT; // PWM_OUT, Output Pad disable
90 *pTIMER7_PERIOD = SYSCLOCK/1000; // SYS CLOCK is defined in sys_config.h
91 *pTIMER7_WIDTH = 1; // 0 < width < period
92 *pTIMER_ENABLE0 = TIMEN7; // timer7 start
94 ena_int( INHNO_TIMER ); // enable Timer Interrupt
101 /**************************************************************
103 **************************************************************/
109 /* TINTはW1Cではないので、TINTのTINTビットは0を書き込む */
110 *pTCNTL = TMPWR | TMREN | TAUTORLD;
112 // GPT7(General-purpose timer7)
113 *pTIMER_STATUS0 = TIMIL7;
118 /**************************************************************
122 **************************************************************/
131 *pTCNTL = TMPWR | TAUTORLD; // 停止
132 *pTCNTL = 0; // パワーダウンモード
134 // GPT2(General-purpose timer7)
135 *pTIMER_DISABLE0 = TIMDIS7; // timer7 disable
141 #endif /* _MACRO_ONLY */
142 #endif /* _HW_TIMER_H_ */