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 * シリアルI/Oデバイス(SIO)ドライバ(Blackfin UART用)
48 * このファイルは、TOPPERS/JSP 1.4.2の config/sh3/ms7727cp01/hw_serial.hを
49 * リネームし、内部の識別子を変更したものである。
51 * このファイルは下位のデバイス・アクセス・ルーチンを束ねて上位の層に渡す
52 * ためのものである。Blackfinの外部にあるシリアルをTOPPERS/JSPで管理しない
59 #include <s_services.h>
63 #ifdef __GNUC__ // gcc
64 #include "cdefBF506F.h"
65 #elif defined(__ECC__) // visualdsp
66 #include <cdefbf506F.h>
68 #error "Compiler is not supported"
75 #define sio_initialize uart_initialize
82 sio_opn_por(ID siopid, VP_INT exinf)
90 siopcb = uart_opn_por(siopid, exinf);
93 * Enable Corrensponding Interrupt at IMASK
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に割り振る
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に割り振る
117 sio_cls_por(SIOPCB *siopcb)
123 uart_cls_por(siopcb);
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
138 #define sio_snd_chr uart_snd_chr
143 #define sio_rcv_chr uart_rcv_chr
146 * シリアルI/Oポートからのコールバックの許可
148 #define sio_ena_cbr uart_ena_cbr
151 * シリアルI/Oポートからのコールバックの禁止
153 #define sio_dis_cbr uart_dis_cbr
156 * シリアルI/Oポートからの送信可能コールバック
158 #define sio_ierdy_snd uart_ierdy_snd
161 * シリアルI/Oポートからの受信通知コールバック
163 #define sio_ierdy_rcv uart_ierdy_rcv
165 #endif /* _MACRO_ONLY */
166 #endif /* _HW_SERIAL_H_ */