OSDN Git Service

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