/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory * Toyohashi Univ. of Technology, JAPAN * Copyright (C) 2000-2003 by Industrial Technology Institute, * Miyagi Prefectural Government, JAPAN * Copyright (C) 2002-2004 by Hokkaido Industrial Research Institute, JAPAN * Copyright (C) 2010 by Cronus Computer Works, JAPAN * * 上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation * によって公表されている GNU General Public License の Version 2 に記 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア * を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下, * 利用と呼ぶ)することを無償で許諾する. * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー * スコード中に含まれていること. * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記 * の無保証規定を掲載すること. * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ * と. * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著 * 作権表示,この利用条件および下記の無保証規定を掲載すること. * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに * 報告すること. * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること. * * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない. * * @(#) $Id: sh7615scif.h,v 1.1 2005/07/06 00:45:07 honda Exp $ */ /* * SH2内蔵シリアルコミュニケーションインタフェースSCI用 簡易ドライバ */ #ifndef _SH726xSCI_H_ #define _SH726xSCI_H_ #include /* * シリアルI/Oポート初期化ブロック */ typedef struct sio_port_initialization_block { UW reg_base; /* レジスタのベースアドレス */ UB brr; /* ボーレートの設定値 */ UB smr; /* モードレジスタの設定値 */ UB int_level; /* 割り込みレベルの設定値 */ } SIOPINIB; /* * シリアルI/Oポート管理ブロック */ typedef struct sio_port_control_block { const SIOPINIB *siopinib; /* シリアルI/Oポート初期化ブロック */ VP_INT exinf; /* 拡張情報 */ BOOL openflag; /* オープン済みフラグ */ BOOL sendflag; /* 送信割込みイネーブルフラグ */ BOOL getready; /* 文字を受信した状態 */ BOOL putready; /* 文字を送信できる状態 */ } SIOPCB; /* * コントロールレジスタのアドレスのオフセット */ #define SCIF_SCFSR 0x10 #define SCIF_SCLSR 0x24 #define SCIF_SCFRDR 0x14 #define SCIF_SCFTDR 0x0c #define SCIF_SCSCR 0x08 #define SCIF_SCFCR 0x18 #define SCIF_SCSMR 0x00 #define SCIF_SCBRR 0x04 /* * コントロールレジスタの設定値 */ /* FIFOコントロールレジスタSCFCRのビット */ #define SCFCR_TFRST 0x0004 /* トランスミットFIFOデータレジスタリセット */ #define SCFCR_RFRST 0x0002 /* レシーブFIFOデータレジスタリセット */ /* シリアルコントロールレジスタSCSCRのビット */ #define SCSCR_TIE 0x0080 /* トランスミットインタラプトイネーブル */ #define SCSCR_RIE 0x0040 /* レシーブインタラプトイネーブル */ #define SCSCR_TE 0x0020 /* トランスミットイネーブル */ #define SCSCR_RE 0x0010 /* レシーブイネーブル */ /* シリアルステータスレジスタSC1SSRのビット */ #define SCFSR_TEND 0x0040 #define SCFSR_TDFE 0x0020 /* トランスミットFIFOデータレジスタエンプティ */ #define SCFSR_ER 0x0080 /* レシーブエラー */ #define SCFSR_FER 0x0008 /* フレーミングエラー */ #define SCFSR_PER 0x0004 /* パリティエラー */ #define SCFSR_RDRF 0x0002 /* レシーブデータレジスタフル */ #define SCFSR_BRK 0x0010 /* ブレーク検出 */ /* シリアルステータスレジスタSC2SSRのビット */ #define SCLSR_ORER 0x01 /* オーバーランエラー */ #define sh2scif_DELAY 1000000 /* * SCIFの設定 */ #define SMR_CKS 0x0 /* 分周比 PΦクロック/1 [変更不可] */ /* BRR設定値の計算 */ #define BRR_VALUE(bps) (((PCLOCK / 32) / (bps)) - 1) /* * コールバックルーチンの識別番号 */ #define SIO_ERDY_SND 1u /* 送信可能コールバック */ #define SIO_ERDY_RCV 2u /* 受信通知コールバック */ /* * SIOドライバの初期化ルーチン */ extern void sh2scif_initialize (void); /* * オープンしているポートがあるか? */ extern BOOL sh2scif_openflag (ID siopid); /* * シリアルI/Oポートのオープン */ extern SIOPCB *sh2scif_opn_por (ID siopid, VP_INT exinf); /* * シリアルI/Oポートのクローズ */ extern void sh2scif_cls_por (SIOPCB * siopcb); /* * シリアルI/Oポートへの文字送信 */ extern BOOL sh2scif_snd_chr (SIOPCB * siopcb, char c); /* * シリアルI/Oポートからの文字受信 */ extern INT sh2scif_rcv_chr (SIOPCB * siopcb); /* * シリアルI/Oポートからのコールバックの許可 */ extern void sh2scif_ena_cbr (SIOPCB * siopcb, UINT cbrtn); /* * シリアルI/Oポートからのコールバックの禁止 */ extern void sh2scif_dis_cbr (SIOPCB * siopcb, UINT cbrtn); /* * SIOの割込みサービスルーチン */ extern void sh2scif_isr (void); /* * シリアルI/Oポートからの送信可能コールバック */ extern void sh2scif_ierdy_snd (VP_INT exinf); /* * シリアルI/Oポートからの受信通知コールバック */ extern void sh2scif_ierdy_rcv (VP_INT exinf); #endif /* _SH726xSCI_H_ */