source: anotherchoice/tags/jsp-1.4.4-full-UTF8/config/sh2/sh7145sci.h@ 26

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

initial

File size: 6.4 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-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2000-2003 by Industrial Technology Institute,
9 * Miyagi Prefectural Government, JAPAN
10 * Copyright (C) 2002-2004 by Hokkaido Industrial Research Institute, JAPAN
11 *
12 * 上記著作権者
13は,以下の (1)〜(4) の条件か,Free Software Foundation
14 * によってå…
15¬è¡¨ã•ã‚Œã¦ã„ã‚‹ GNU General Public License の Version 2 に記
16 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
17 * を改変したものを含む.以下同じ)を使用・複製・改変・再é…
18å¸ƒï¼ˆä»¥ä¸‹ï¼Œ
19 * 利用と呼ぶ)することを無償で許諾する.
20 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
21 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
22 * スコード中に含まれていること.
23 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
24 * 用できる形で再é…
25å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
26å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
27 * 者
28マニュアルなど)に,上記の著作権表示,この利用条件および下記
29 * の無保証規定を掲載すること.
30 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
31 * 用できない形で再é…
32å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
33 * と.
34 * (a) 再é…
35å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
36マニュアルなど)に,上記の著
37 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
38 * (b) 再é…
39å¸ƒã®å½¢æ…
40‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
41 * 報告すること.
42 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
43 * 害からも,上記著作権者
44およびTOPPERSプロジェクトをå…
45è²¬ã™ã‚‹ã“と.
46 *
47 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
48お
49 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
50 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
51 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
52 *
53 * @(#) $Id: sh7145sci.h,v 1.1 2005/07/06 00:45:07 honda Exp $
54 */
55
56/*
57 * SH2内
58蔵シリアルコミュニケーションインタフェースSCI用 簡易ドライバ
59 */
60
61#ifndef _sh7145sci_H_
62#define _sh7145sci_H_
63
64#include <t_config.h>
65
66/*
67 * シリアルI/Oポート初期化ブロック
68 */
69typedef struct sio_port_initialization_block
70{
71 UW reg_base; /* レジスタのベースアドレス */
72 UB brr; /* ボーレートの設定値 */
73 UB smr; /* モードレジスタの設定値 */
74 UB int_level; /* 割り込みレベルの設定値 */
75} SIOPINIB;
76
77/*
78 * シリアルI/Oポート管理ブロック
79 */
80typedef struct sio_port_control_block
81{
82 const SIOPINIB *siopinib; /* シリアルI/Oポート初期化ブロック */
83 VP_INT exinf; /* 拡張情
84å ± */
85 BOOL openflag; /* オープン済みフラグ */
86 BOOL sendflag; /* 送信割込みイネーブルフラグ */
87 BOOL getready; /* 文字を受信した状æ…
88‹ */
89 BOOL putready; /* 文字を送信できる状æ…
90‹ */
91} SIOPCB;
92
93/*
94 * コントロールレジスタのアドレスのオフセット
95 */
96#define SCI_SCR 0x2
97#define SCI_SSR 0x4
98#define SCI_BRR 0x1
99#define SCI_SMR 0x0
100#define SCI_TDR 0x3
101#define SCI_RDR 0x5
102#define SCI_SDCR 0x6
103
104
105/*
106 * コントロールレジスタの設定値
107 */
108#define SCI_TIE 0x80 /* トランスミットインタラプトイネーブル */
109#define SCI_RIE 0x40 /* レシーブインタラプトイネーブル */
110#define SCI_TE 0x20 /* トランスミットイネーブル */
111#define SCI_RE 0x10 /* レシーブイネーブル */
112#define SSR_ORER 0x20 /* オーバーランエラー */
113#define SSR_FER 0x10 /* フレーミングエラー */
114#define SSR_PER 0x08 /* パリティエラー */
115#define SSR_TDRE 0x80 /* トランスミットデータレジスタエンプティ */
116#define SSR_RDRF 0x40 /* レシーブデータレジスタフル */
117
118#define sh2sci_DELAY 105000
119
120#define PFC_TXD0 0x0004
121#define PFC_RXD0 0x0001
122#define PFC_TXD1 0x0100
123#define PFC_RXD1 0x0040
124#define PFC_TXD2 0x0020
125#define PFC_RXD2 0x8000
126
127/*
128 * SCIの設定
129 */
130#define SMR_CKS 0x0 /* 分周比 */
131#define BRR9600 79 /* 9600 ビットレート */
132#define BRR19200 39 /* 19200 ビットレート */
133#define BRR38400 19 /* 38400 ビットレート */
134
135/*
136 * コールバックルーチンの識別番号
137 */
138#define SIO_ERDY_SND 1u /* 送信可能コールバック */
139#define SIO_ERDY_RCV 2u /* 受信通知コールバック */
140
141/*
142 * SIOドライバの初期化ルーチン
143 */
144extern void sh2sci_initialize (void);
145
146/*
147 * オープンしているポートがあるか?
148 */
149extern BOOL sh2sci_openflag (ID siopid);
150
151/*
152 * シリアルI/Oポートのオープン
153 */
154extern SIOPCB *sh2sci_opn_por (ID siopid, VP_INT exinf);
155
156/*
157 * シリアルI/Oポートのクローズ
158 */
159extern void sh2sci_cls_por (SIOPCB * siopcb);
160
161/*
162 * シリアルI/Oポートへの文字送信
163 */
164extern BOOL sh2sci_snd_chr (SIOPCB * siopcb, char c);
165
166/*
167 * シリアルI/Oポートからの文字受信
168 */
169extern INT sh2sci_rcv_chr (SIOPCB * siopcb);
170
171/*
172 * シリアルI/Oポートからのコールバックの許可
173 */
174extern void sh2sci_ena_cbr (SIOPCB * siopcb, UINT cbrtn);
175
176/*
177 * シリアルI/Oポートからのコールバックの禁止
178 */
179extern void sh2sci_dis_cbr (SIOPCB * siopcb, UINT cbrtn);
180
181/*
182 * SIOの割込みサービスルーチン
183 */
184extern void sh2sci_isr (void);
185
186/*
187 * シリアルI/Oポートからの送信可能コールバック
188 */
189extern void sh2sci_ierdy_snd (VP_INT exinf);
190
191/*
192 * シリアルI/Oポートからの受信通知コールバック
193 */
194extern void sh2sci_ierdy_rcv (VP_INT exinf);
195
196#endif /* _sh7145sci_H_ */
Note: See TracBrowser for help on using the repository browser.