source: anotherchoice/tags/jsp-1.4.4-full-UTF8/config/h8s/h8s_sci.h@ 26

Last change on this file since 26 was 26, checked in by ykominami, 10 years ago

initial

File size: 6.9 KB
Line 
1/*
2 * TOPPERS/JSP Kernel
3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Just Standard Profile Kernel
5 *
6 * Copyright (C) 2000-2004 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2001-2004 by Dep. of Computer Science and Engineering
9 * Tomakomai National College of Technology, JAPAN
10 * Copyright (C) 2001-2004 by Industrial Technology Institute,
11 * Miyagi Prefectural Government, JAPAN
12 *
13 * 上記著作権者
14は,以下の (1)〜(4) の条件か,Free Software Foundation
15 * によってå…
16¬è¡¨ã•ã‚Œã¦ã„ã‚‹ GNU General Public License の Version 2 に記
17 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
18 * を改変したものを含む.以下同じ)を使用・複製・改変・再é…
19å¸ƒï¼ˆä»¥ä¸‹ï¼Œ
20 * 利用と呼ぶ)することを無償で許諾する.
21 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
22 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
23 * スコード中に含まれていること.
24 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
25 * 用できる形で再é…
26å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
27å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
28 * 者
29マニュアルなど)に,上記の著作権表示,この利用条件および下記
30 * の無保証規定を掲載すること.
31 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
32 * 用できない形で再é…
33å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
34 * と.
35 * (a) 再é…
36å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
37マニュアルなど)に,上記の著
38 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
39 * (b) 再é…
40å¸ƒã®å½¢æ…
41‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
42 * 報告すること.
43 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
44 * 害からも,上記著作権者
45およびTOPPERSプロジェクトをå…
46è²¬ã™ã‚‹ã“と.
47 *
48 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
49お
50 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
51 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
52 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
53 */
54
55#ifndef _H8S_SCI_H_
56#define _H8S_SCI_H_
57
58#include <s_services.h> /* デバイスドライバ用標準インクルードファイル */
59#include <h8s_sil.h>
60
61/*
62 * H8S 内
63蔵シリアルコミュニケーションインタフェース(SCI)関連の定義
64 */
65
66/* SCIレジスタのアドレス */
67/* ベースアドレス */
68#define SCI0_BASE_ADDR 0xff78 /* チャネル0 */
69#define SCI1_BASE_ADDR 0xff80 /* チャネル1 */
70/* レジスタオフセット */
71#define SMR 0 /* シリアルモードレジスタタ */
72#define BRR 1 /* ビットレートレジスタ */
73#define SCR 2 /* シリアルコントロールレジスタ */
74#define TDR 3 /* トランスミットデータレジスタ */
75#define SSR 4 /* シリアルステータスレジスタ */
76#define RDR 5 /* レシーブデータレジスタ */
77#define SCMR 6 /* スマートカードモードレジスタ */
78
79/* 各レジスタのビットパターン */
80
81/* RSR, RDR, TSR, TDR */
82/* 定義すべきものは、特に無い */
83
84/* SMR */
85#define CA BIT7
86#define CHR BIT6 /* 8bit = 0 / 7bit = 1 */
87#define PE BIT5 /* Parity OFF = 0 / Parity ON = 1 */
88#define OE BIT4 /* EVEN Parity = 0 / ODD Parity = 1 */
89#define STOP BIT3 /* 1 STOP BIT = 0 / 2 STOP BIT = 1 */
90#define MP BIT2
91#define CSK1 BIT1
92#define CSK0 BIT0
93
94/* SCR */
95#define TIE BIT7
96#define RIE BIT6
97#define TE BIT5
98#define RE BIT4
99#define MPIE BIT3
100#define TEIE BIT2
101#define CKE1 BIT1
102#define CKE0 BIT0
103
104/* SSR */
105#define TDRE BIT7
106#define RDRF BIT6
107#define ORER BIT5
108#define FER BIT4
109#define PER BIT3
110#define TEND BIT2
111#define MPB BIT1
112#define MPBT BIT0
113
114/*
115 * ボーレート関係の定義
116 * 動作周波数:20 [MHz] なので、マニュアルp567より決まる。
117 */
118#if BAUD_RATE == 9600 /* ビットレート: 9600 [bit/s] */
119 #define BRR_RATE 64 /* N = 64 */
120#elif BAUD_RATE == 38400 /* ビットレート:38400 [bit/s] */
121 #define BRR_RATE 15 /* N = 15 */
122#elif BAUD_RATE == 57600 /* ビットレート:57600 [bit/s] */
123 #define BRR_RATE 10 /* N = 10 */
124#endif
125
126#ifndef _MACRO_ONLY
127
128/*
129 * シリアルI/Oポート初期化ブロック
130 */
131typedef struct sio_port_control_block SIOPCB;
132
133#endif /* _MACRO_ONLY */
134
135/*
136 * SCI用システムインタフェースレイヤー
137 */
138/* x : ポートのベースアドレス(UW 型)
139 y : レジスタオフセット(UW 型)
140 z : レジスタ値 */
141#define h8s_sci_wrb( x, y, z ) h8s_wrb_mem( (VP)(x + y), z )
142#define h8s_sci_reb( x, y ) h8s_reb_mem( (VP)(x + y) )
143
144/*
145 * コールバックルーチンの識別番号
146 */
147#define SIO_ERDY_SND 1u /* 送信可能コールバック */
148#define SIO_ERDY_RCV 2u /* 受信通知コールバック */
149
150#ifndef _MACRO_ONLY
151
152/*
153 * SIOドライバの初期化ルーチン
154 */
155extern void h8s_sci_initialize(void);
156
157/*
158 * オープンしているポートがあるか?
159 */
160extern BOOL h8s_sci_openflag(void);
161
162/*
163 * シリアルI/Oポートのオープン
164 */
165extern SIOPCB *h8s_sci_opn_por(ID siopid, VP_INT exinf);
166
167/*
168 * シリアルI/Oポートのクローズ
169 */
170extern void h8s_sci_cls_por(SIOPCB *siopcb);
171
172/*
173 * シリアルI/Oポートへの文字送信
174 */
175extern BOOL h8s_sci_snd_chr(SIOPCB *siopcb, char c);
176
177/*
178 * シリアルI/Oポートからの文字受信
179 */
180extern INT h8s_sci_rcv_chr(SIOPCB *siopcb);
181
182/*
183 * シリアルI/Oポートからのコールバックの許可
184 */
185extern void h8s_sci_ena_cbr(SIOPCB *siopcb, UINT cbrtn);
186
187/*
188 * シリアルI/Oポートからのコールバックの禁止
189 */
190extern void h8s_sci_dis_cbr(SIOPCB *siopcb, UINT cbrtn);
191
192/*
193 * SIOの割込みサービスルーチン
194 */
195extern void h8s_sci_isr_in(void);
196extern void h8s_sci_isr_out(void);
197
198/*
199 * SIOの受信エラー割込みサービスルーチン
200 */
201extern void h8s_sci_isr_error(void);
202
203/*
204 * シリアルI/Oポートからの送信可能コールバック
205 */
206extern void h8s_sci_ierdy_snd(VP_INT exinf);
207
208/*
209 * シリアルI/Oポートからの受信通知コールバック
210 */
211extern void h8s_sci_ierdy_rcv(VP_INT exinf);
212
213/*
214 * カーネル起動時用の初期化 (sys_putcで利用)
215 */
216extern void h8s_sci_init(void);
217
218/*
219 * シリアルI/Oポートへの文字送信(ポーリング)
220 */
221extern void h8s_sci_putchar_pol(char c);
222
223#endif /* _MACRO_ONLY */
224
225#endif /* _H8S_sci_H_ */
Note: See TracBrowser for help on using the repository browser.