source: ssp_rpi3/trunk/arch/arm64_gcc/bcm283x/chip_serial.h@ 386

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

modify svn:mimetype of files

  • Property svn:keywords set to Id
  • 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,2019 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_CHIP_SERIAL_H
46#define TOPPERS_CHIP_SERIAL_H
47
48/*
49 * SIOの割込み設定
50 */
51#define INTNO_SIO TINTNO_UART // 割込み番号
52
53#ifndef INTATR_SIO
54 #define INTATR_SIO TA_NULL // 割込み属性
55#endif
56
57#ifndef INTPRI_SIO
58 #define INTPRI_SIO (-2) // 割込み優先度
59#endif
60
61/*
62 * コールバックルーチンの識別番号
63 */
64#define SIO_RDY_SND 1U /* 送信可能コールバック */
65#define SIO_RDY_RCV 2U /* 受信通知コールバック */
66
67#ifndef TOPPERS_MACRO_ONLY
68
69/*
70 * シリアルポートの初期化ブロック
71 */
72typedef const struct tag_SIOPINIB {
73 uintptr_t baseAddress;
74 uint8_t ibrd;
75 uint8_t fbrd;
76 uint8_t lcr_h;
77} SIOPINIB;
78
79/*
80 * シリアルポートの管理ブロック
81 */
82typedef struct sio_port_control_block {
83 SIOPINIB *inib;
84 intptr_t exinf;
85} SIOPCB;
86
87/*
88 * SIO初期化
89 */
90extern void sio_initialize(intptr_t exinf);
91
92/*
93 * シリアルオープン
94 */
95extern SIOPCB *sio_opn_por(ID siopid, intptr_t exinf);
96
97/*
98 * シリアルクローズ
99 */
100extern void sio_cls_por(SIOPCB *p_siopcb);
101
102/*
103 * 割込みハンドラ
104 */
105extern void sio_isr(intptr_t exinf);
106
107/*
108 * 1文字送信
109 */
110extern bool_t sio_snd_chr(SIOPCB *siopcb, char c);
111
112/*
113 * 1文字受信
114 */
115extern int_t sio_rcv_chr(SIOPCB *siopcb);
116
117/*
118 * コールバックの許可
119 */
120extern void sio_ena_cbr(SIOPCB *siopcb, uint_t cbrtn);
121
122/*
123 * コールバックの禁止
124 */
125extern void sio_dis_cbr(SIOPCB *siopcb, uint_t cbrtn);
126
127/*
128 * 送信可能コールバック
129 */
130extern void sio_irdy_snd(intptr_t exinf);
131
132/*
133 * 受信通知コールバック
134 */
135extern void sio_irdy_rcv(intptr_t exinf);
136
137/*
138 * 1文字送信(ポーリングでの出力)
139 */
140extern void sio_pol_snd_chr(char c, ID siopid);
141
142/*
143 * 低レベル出力初期化
144 */
145extern void target_low_output_init(ID siopid);
146
147#endif /* TOPPERS_MACRO_ONLY */
148#endif /* TOPPERS_TARGET_SERIAL_H */
Note: See TracBrowser for help on using the repository browser.