OSDN Git Service

Sメーター周りを修正
[trx-305dsp/dsp.git] / trx305 / kernel / config / blackfin / _common_bf537 / hw_serial.h
1 /*
2  *  TOPPERS/JSP Kernel
3  *      Toyohashi Open Platform for Embedded Real-Time Systems/
4  *      Just Standard Profile Kernel
5  *
6  *  Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7  *                              Toyohashi Univ. of Technology, JAPAN
8  *
9  *  上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation
10  *  によって公表されている GNU General Public License の Version 2 に記
11  *  述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
12  *  を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
13  *  利用と呼ぶ)することを無償で許諾する.
14  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
15  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
16  *      スコード中に含まれていること.
17  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
18  *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
19  *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
20  *      の無保証規定を掲載すること.
21  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
22  *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
23  *      と.
24  *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
25  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
26  *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
27  *        報告すること.
28  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
29  *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
30  *
31  *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
32  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
33  *  含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
34  *  接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
35  *
36  */
37
38 /*
39  *  シリアルI/Oデバイス(SIO)ドライバ(Blackfin UART用)
40  *
41  *   このファイルは、TOPPERS/JSP 1.4.2の config/sh3/ms7727cp01/hw_serial.hを
42  *   リネームし、内部の識別子を変更したものである。
43  *
44  *   このファイルは下位のデバイス・アクセス・ルーチンを束ねて上位の層に渡す
45  *   ためのものである。Blackfinの外部にあるシリアルをTOPPERS/JSPで管理しない
46  *   のなら、変更する必要はない。
47  */
48
49 #ifndef _HW_SERIAL_H_
50 #define _HW_SERIAL_H_
51
52 #include <s_services.h>
53 #include <sil.h>
54
55 #include "uart.h"
56
57
58 /*
59  *  SIOドライバの初期化ルーチン
60  */
61 #define sio_initialize  uart_initialize
62
63 #ifndef _MACRO_ONLY
64 /*
65  *  シリアルI/Oポートのオープン
66  */
67 Inline SIOPCB *
68 sio_opn_por(ID siopid, VP_INT exinf)
69 {
70     SIOPCB  *siopcb;
71     UW regBase;
72
73     /*
74      *  デバイス依存のオープン処理.
75      */
76     siopcb = uart_opn_por(siopid, exinf);
77
78     /*
79     * Enable Corrensponding Interrupt at IMASK
80     */
81     regBase = siopcb->siopinib->reg_base;
82     if ( regBase == UART0_ADDRESS ) {        // UART0の場合
83         ena_int( INTNO_UART0_TX );
84         ena_int( INTNO_UART0_RX );
85         *__pPORT_MUX  &= ~0x0008;   // 機能をUART0に割り振る
86         *__pPORTF_FER |=  0x0003;   // PF0,PF1をUART0に割り振る
87     }
88     else if ( regBase == UART1_ADDRESS ){    // uart1の場合
89         ena_int( INTNO_UART1_TX );
90         ena_int( INTNO_UART1_RX );
91         *__pPORT_MUX  &= ~0x0010;   // 機能をUART0に割り振る
92         *__pPORTF_FER |=  0x000C;   // PF2,PF3をUART0に割り振る
93     }
94
95     return(siopcb);
96 }
97
98 /*
99  *  シリアルI/Oポートのクローズ
100  */
101 Inline void
102 sio_cls_por(SIOPCB *siopcb)
103 {
104     /*
105      * ここではSIC_IMASKの対応ビットをクリアしない。SIC_IMASKのクリアは
106      * 危険である。UARTからの割り込みは uart_cls_por内部で禁止するので
107      * 充分である。
108      */
109
110     /*
111      *  デバイス依存のクローズ処理.
112      */
113     uart_cls_por(siopcb);
114 }
115
116
117 /*
118  *  SIOの割込みハンドラ
119  */
120 #define sio0_rx_handler uart0_rx_isr
121 #define sio0_tx_handler uart0_tx_isr
122 #define sio1_rx_handler uart1_rx_isr
123 #define sio1_tx_handler uart1_tx_isr
124
125 /*
126  *  シリアルI/Oポートへの文字送信
127  */
128 #define sio_snd_chr uart_snd_chr
129
130 /*
131  *  シリアルI/Oポートからの文字受信
132  */
133 #define sio_rcv_chr uart_rcv_chr
134
135 /*
136  *  シリアルI/Oポートからのコールバックの許可
137  */
138 #define sio_ena_cbr uart_ena_cbr
139
140 /*
141  *  シリアルI/Oポートからのコールバックの禁止
142  */
143 #define sio_dis_cbr uart_dis_cbr
144
145 /*
146  *  シリアルI/Oポートからの送信可能コールバック
147  */
148 #define sio_ierdy_snd   uart_ierdy_snd
149
150 /*
151  *  シリアルI/Oポートからの受信通知コールバック
152  */
153 #define sio_ierdy_rcv   uart_ierdy_rcv
154
155 #endif /* _MACRO_ONLY */
156 #endif /* _HW_SERIAL_H_ */