source: ssp_aarch64/trunk/qemu_virt_gcc/target_serial.h@ 356

Last change on this file since 356 was 356, checked in by nmir-saito, 6 years ago

set svn:mime-type to files

  • Property svn:mime-type set to text/plain; charset=utf-8
File size: 4.6 KB
Line 
1/*
2 * TOPPERS/SSP Kernel
3 * Smallest Set Profile Kernel
4 *
5 * Copyright (C) 2007 by Embedded and Real-Time Systems Laboratory
6 * Graduate School of Information Science, Nagoya Univ., JAPAN
7 * Copyright (C) 2015,2018 by Naoki Saito
8 * Nagoya Municipal Industrial Research Institute, JAPAN
9 *
10 * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
11 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
12 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
13 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
14 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
15 * スコード中に含まれていること.
16 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
17 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
18 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
19 * の無保証規定を掲載すること.
20 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
21 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
22 * と.
23 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
24 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
25 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
26 * 報告すること.
27 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
28 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
29 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
30 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
31 * 免責すること.
32 *
33 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
34 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
35 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
36 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
37 * の責任を負わない.
38 *
39 */
40
41/*
42 * シリアルI/Oデバイス(SIO)ドライバ
43 */
44
45#ifndef TOPPERS_TARGET_SERIAL_H
46#define TOPPERS_TARGET_SERIAL_H
47
48/*
49 * SIOの割込み設定
50 */
51#define INTNO_SIO TINTNO_UART0 // 割込み番号
52#define INTATR_SIO TA_NULL // 割込み属性
53#define INTPRI_SIO (-2) // 割込み優先度
54
55/*
56 * コールバックルーチンの識別番号
57 */
58#define SIO_RDY_SND 1U /* 送信可能コールバック */
59#define SIO_RDY_RCV 2U /* 受信通知コールバック */
60
61#ifndef TOPPERS_MACRO_ONLY
62
63/*
64 * シリアルポートの初期化ブロック
65 */
66typedef const struct tag_SIOPINIB {
67 uintptr_t baseAddress;
68 uint8_t ibrd;
69 uint8_t fbrd;
70 uint8_t lcr_h;
71} SIOPINIB;
72
73/*
74 * シリアルポートの管理ブロック
75 */
76typedef struct sio_port_control_block {
77 SIOPINIB *inib;
78 intptr_t exinf;
79} SIOPCB;
80
81/*
82 * SIO初期化
83 */
84extern void sio_initialize(intptr_t exinf);
85
86/*
87 * シリアルオープン
88 */
89extern SIOPCB *sio_opn_por(ID siopid, intptr_t exinf);
90
91/*
92 * シリアルクローズ
93 */
94extern void sio_cls_por(SIOPCB *p_siopcb);
95
96/*
97 * 割込みハンドラ
98 */
99extern void sio_isr(intptr_t exinf);
100
101/*
102 * 1文字送信
103 */
104extern bool_t sio_snd_chr(SIOPCB *siopcb, char c);
105
106/*
107 * 1文字受信
108 */
109extern int_t sio_rcv_chr(SIOPCB *siopcb);
110
111/*
112 * コールバックの許可
113 */
114extern void sio_ena_cbr(SIOPCB *siopcb, uint_t cbrtn);
115
116/*
117 * コールバックの禁止
118 */
119extern void sio_dis_cbr(SIOPCB *siopcb, uint_t cbrtn);
120
121/*
122 * 送信可能コールバック
123 */
124extern void sio_irdy_snd(intptr_t exinf);
125
126/*
127 * 受信通知コールバック
128 */
129extern void sio_irdy_rcv(intptr_t exinf);
130
131/*
132 * 1文字送信(ポーリングでの出力)
133 */
134extern void sio_pol_snd_chr(char c, ID siopid);
135
136/*
137 * 低レベル出力初期化
138 */
139extern void target_low_output_init(ID siopid);
140
141#endif /* TOPPERS_MACRO_ONLY */
142#endif /* TOPPERS_TARGET_SERIAL_H */
Note: See TracBrowser for help on using the repository browser.