OSDN Git Service

Change the directry name to hirado
[trx-305dsp/dsp.git] / hirado / kernel / pdic / simple_sio / st16c2550.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  *  @(#) $Id: st16c2550.h,v 1.1 2009/01/31 05:27:37 suikan Exp $
37  */
38
39 /*
40  *   ST16C2550 用 簡易SIOドライバ
41  */
42 #ifndef _ST16C2550_H_
43 #define _ST16C2550_H_
44
45 #include <t_config.h>
46
47 /*
48  *  シリアルI/Oポート初期化ブロック
49  */
50 typedef struct sio_port_initialization_block {
51     UW reg_base;    /* レジスタのベースアドレス */
52     UB lcr_val;     /* モードレジスタの設定値   */
53     UB dlm_val;     /* ボーレート上位の設定値   */
54     UB dll_val;     /* ボーレート下位の設定値   */
55     UW pinter_val;  /* 割込み許可ビット   */    
56 } SIOPINIB;
57
58 /*
59  *  シリアルI/Oポート管理ブロック
60  */
61 typedef struct sio_port_control_block {
62     const SIOPINIB  *siopinib; /* シリアルI/Oポート初期化ブロック */
63     VP_INT          exinf;     /* 拡張情報 */
64     BOOL    openflag;          /* オープン済みフラグ */
65     BOOL    sendflag;          /* 送信割込みイネーブルフラグ */
66     BOOL    getready;          /* 文字を受信した状態 */
67     BOOL    putready;          /* 文字を送信できる状態 */
68 }SIOPCB;
69
70
71 /*
72  *  コールバックルーチンの識別番号
73  */
74 #define SIO_ERDY_SND    1u      /* 送信可能コールバック */
75 #define SIO_ERDY_RCV    2u      /* 受信通知コールバック */
76
77
78 /*
79  * カーネル起動時用の初期化(sys_putcを使用するため)
80  */
81 extern void st16c2550_init(void);
82
83 /*
84  *  シリアルI/Oポートへのポーリングでの出力
85  */
86 extern void st16c2550_pol_putc(char c, ID siopid);
87
88
89 /*
90  *  SIOドライバの初期化ルーチン
91  */
92 extern void st16c2550_initialize(void);
93
94
95 /*
96  *  オープンしているポートがあるか?
97  */
98 extern BOOL st16c2550_openflag(void);
99
100
101 /*
102  *  シリアルI/Oポートのオープン
103  */
104 extern SIOPCB   *st16c2550_opn_por(ID siopid, VP_INT exinf);
105
106
107 /*
108  *  シリアルI/Oポートのクローズ
109  */
110 extern void st16c2550_cls_por(SIOPCB *siopcb);
111
112
113 /*
114  *  シリアルI/Oポートへの文字送信
115  */
116 extern BOOL st16c2550_snd_chr(SIOPCB *siopcb, char c);
117
118
119 /*
120  *  シリアルI/Oポートからの文字受信
121  */
122 extern INT  st16c2550_rcv_chr(SIOPCB *siopcb);
123
124
125 /*
126  *  シリアルI/Oポートからのコールバックの許可
127  */
128 extern void st16c2550_ena_cbr(SIOPCB *siopcb, UINT cbrtn);
129
130
131 /*
132  *  シリアルI/Oポートからのコールバックの禁止
133  */
134 extern void st16c2550_dis_cbr(SIOPCB *siopcb, UINT cbrtn);
135
136
137 /*
138  *  SIOの割込みサービスルーチン
139  */
140 extern void st16c2550_isr(void);
141
142
143 /*
144  *  シリアルI/Oポートからの送信可能コールバック
145  */
146 extern void st16c2550_ierdy_snd(VP_INT exinf);
147
148
149 /*
150  *  シリアルI/Oポートからの受信通知コールバック
151  */
152 extern void st16c2550_ierdy_rcv(VP_INT exinf);
153
154
155 #endif /* _FDC37C935A_H_ */