source: EcnlProtoTool/trunk/asp3_dcre/arch/arm_gcc/rza1/tSCIF.c@ 270

Last change on this file since 270 was 270, checked in by coas-nagasima, 7 years ago

mruby版ECNLプロトタイピング・ツールを追加

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-csrc
File size: 7.8 KB
Line 
1/*
2 * TOPPERS/ASP Kernel
3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Advanced Standard Profile Kernel
5 *
6 * Copyright (C) 2006-2016 by Embedded and Real-Time Systems Laboratory
7 * Graduate School of Information Science, Nagoya Univ., JAPAN
8 *
9 * 上記著作権者
10は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
11 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
12 * 変・再é…
13å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
14 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
15 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
16 * スコード中に含まれていること.
17 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
18 * 用できる形で再é…
19å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
20å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
21 * 者
22マニュアルなど)に,上記の著作権表示,この利用条件および下記
23 * の無保証規定を掲載すること.
24 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
25 * 用できない形で再é…
26å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
27 * と.
28 * (a) 再é…
29å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
30マニュアルなど)に,上記の著
31 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
32 * (b) 再é…
33å¸ƒã®å½¢æ…
34‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
35 * 報告すること.
36 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
37 * 害からも,上記著作権者
38およびTOPPERSプロジェクトをå…
39è²¬ã™ã‚‹ã“と.
40 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
41 * 由に基づく請求からも,上記著作権者
42およびTOPPERSプロジェクトを
43 * å…
44è²¬ã™ã‚‹ã“と.
45 *
46 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
47お
48 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
49 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
50 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
51 * の責任を負わない.
52 *
53 * $Id: tSCIF.c 270 2017-02-09 04:03:47Z coas-nagasima $
54 */
55
56/*
57 * FIFO内
58蔵シリアルコミュニケーションインタフェース用 簡易SIOドライバ
59 */
60
61#include <sil.h>
62#include "tSCIF_tecsgen.h"
63#include "scif.h"
64
65/*
66 * プリミティブな送信/受信関数
67 */
68
69/*
70 * 受信バッファに文字があるか?
71 */
72Inline bool_t
73scif_getready(CELLCB *p_cellcb)
74{
75 uint16_t fsr;
76 uint16_t lsr;
77
78 fsr = sil_reh_mem(SCIF_SCFSR(ATTR_baseAddress));
79 lsr = sil_reh_mem(SCIF_SCLSR(ATTR_baseAddress));
80 if ((fsr & (SCIF_SCFSR_ER|SCIF_SCFSR_BRK)) != 0U) {
81 fsr &= ~(SCIF_SCFSR_ER|SCIF_SCFSR_BRK);
82 sil_wrh_mem(SCIF_SCFSR(ATTR_baseAddress), fsr);
83 }
84 if ((lsr & SCIF_SCLSR_ORER) != 0U) {
85 lsr &= ~(SCIF_SCLSR_ORER);
86 sil_wrh_mem(SCIF_SCLSR(ATTR_baseAddress), lsr);
87 }
88 return((fsr & SCIF_SCFSR_RDF) != 0U);
89}
90
91/*
92 * 送信バッファに空きがあるか?
93 */
94Inline bool_t
95scif_putready(CELLCB *p_cellcb)
96{
97 uint16_t fsr;
98
99 fsr = sil_reh_mem(SCIF_SCFSR(ATTR_baseAddress));
100 return((fsr & SCIF_SCFSR_TDFE) != 0U);
101}
102
103/*
104 * 受信した文字の取出し
105 */
106Inline bool_t
107scif_getchar(CELLCB *p_cellcb, char *p_c)
108{
109 uint16_t fsr;
110 uint16_t lsr;
111
112 fsr = sil_reh_mem(SCIF_SCFSR(ATTR_baseAddress));
113 lsr = sil_reh_mem(SCIF_SCLSR(ATTR_baseAddress));
114 if ((fsr & (SCIF_SCFSR_ER|SCIF_SCFSR_BRK)) != 0U) {
115 fsr &= ~(SCIF_SCFSR_ER|SCIF_SCFSR_BRK);
116 sil_wrh_mem(SCIF_SCFSR(ATTR_baseAddress), fsr);
117 }
118 if ((lsr & SCIF_SCLSR_ORER) != 0U) {
119 lsr &= ~(SCIF_SCLSR_ORER);
120 sil_wrh_mem(SCIF_SCLSR(ATTR_baseAddress), lsr);
121 }
122 if ((fsr & SCIF_SCFSR_RDF) != 0U) {
123 *p_c = (char) sil_reb_mem(SCIF_SCFRDR(ATTR_baseAddress));
124 fsr &= ~(SCIF_SCFSR_RDF);
125 sil_wrh_mem(SCIF_SCFSR(ATTR_baseAddress), fsr);
126 return(true);
127 }
128 return(false);
129}
130
131/*
132 * 送信する文字の書込み
133 */
134Inline void
135scif_putchar(CELLCB *p_cellcb, char c)
136{
137 sil_wrb_mem(SCIF_SCFTDR(ATTR_baseAddress), c);
138 sil_wrh_mem(SCIF_SCFSR(ATTR_baseAddress),
139 (uint16_t) ~(SCIF_SCFSR_TEND|SCIF_SCFSR_TDFE));
140}
141
142/*
143 * シリアルI/Oポートのオープン
144 */
145void
146eSIOPort_open(CELLIDX idx)
147{
148 CELLCB *p_cellcb = GET_CELLCB(idx);
149 uint_t brr;
150
151 if (VAR_initialized) {
152 /*
153 * 既に初期化している場合は、二重に初期化しない.
154 */
155 return;
156 }
157
158 brr = SCIF_CLK / (32 * ATTR_baudRate) - 1;
159 assert(brr <= 255);
160
161 sil_wrh_mem(SCIF_SCSCR(ATTR_baseAddress), 0U);
162 sil_wrh_mem(SCIF_SCFCR(ATTR_baseAddress),
163 SCIF_SCFCR_TFRST|SCIF_SCFCR_RFRST);
164 (void) sil_reh_mem(SCIF_SCFSR(ATTR_baseAddress));
165 (void) sil_reh_mem(SCIF_SCLSR(ATTR_baseAddress));
166 sil_wrh_mem(SCIF_SCFSR(ATTR_baseAddress), 0U);
167 sil_wrh_mem(SCIF_SCLSR(ATTR_baseAddress), 0U);
168 sil_wrh_mem(SCIF_SCSCR(ATTR_baseAddress), SCIF_SCSCR_INTCLK);
169 sil_wrh_mem(SCIF_SCSMR(ATTR_baseAddress), SCIF_SCSMR_CKS1);
170 sil_wrh_mem(SCIF_SCEMR(ATTR_baseAddress), 0U);
171 sil_wrb_mem(SCIF_SCBRR(ATTR_baseAddress), (uint8_t) brr);
172 sil_wrh_mem(SCIF_SCFCR(ATTR_baseAddress),
173 SCIF_SCFCR_RSTRG_15|SCIF_SCFCR_RTRG_1|SCIF_SCFCR_TTRG_8);
174 sil_wrh_mem(SCIF_SCSCR(ATTR_baseAddress),
175 SCIF_SCSCR_TE|SCIF_SCSCR_RE|SCIF_SCSCR_INTCLK);
176
177 while ((sil_reh_mem(SCIF_SCFSR(ATTR_baseAddress)) & SCIF_SCFSR_RDF) != 0U) {
178 (void) sil_reb_mem(SCIF_SCFRDR(ATTR_baseAddress));
179 sil_wrh_mem(SCIF_SCFSR(ATTR_baseAddress), (uint16_t) ~(SCIF_SCFSR_RDF));
180 }
181 sil_wrh_mem(SCIF_SCFSR(ATTR_baseAddress), 0U);
182
183 VAR_initialized = true;
184}
185
186/*
187 * シリアルI/Oポートのクローズ
188 */
189void
190eSIOPort_close(CELLIDX idx)
191{
192 CELLCB *p_cellcb = GET_CELLCB(idx);
193
194 sil_wrh_mem(SCIF_SCSCR(ATTR_baseAddress), 0U);
195}
196
197/*
198 * シリアルI/Oポートへの文字送信
199 */
200bool_t
201eSIOPort_putChar(CELLIDX idx, char c)
202{
203 CELLCB *p_cellcb = GET_CELLCB(idx);
204
205 if (scif_putready(p_cellcb)){
206 scif_putchar(p_cellcb, c);
207 return(true);
208 }
209 return(false);
210}
211
212/*
213 * シリアルI/Oポートからの文字受信
214 */
215int_t
216eSIOPort_getChar(CELLIDX idx)
217{
218 CELLCB *p_cellcb = GET_CELLCB(idx);
219 char c;
220
221 if (scif_getready(p_cellcb)) {
222 if (scif_getchar(p_cellcb, &c)) {
223 return((int_t) c);
224 }
225 }
226 return(-1);
227}
228
229/*
230 * シリアルI/Oポートからのコールバックの許可
231 */
232void
233eSIOPort_enableCBR(CELLIDX idx, uint_t cbrtn)
234{
235 CELLCB *p_cellcb = GET_CELLCB(idx);
236 uint16_t scr;
237
238 scr = sil_reh_mem(SCIF_SCSCR(ATTR_baseAddress));
239 switch (cbrtn) {
240 case SIOSendReady:
241 scr |= SCIF_SCSCR_TIE;
242 break;
243 case SIOReceiveReady:
244 scr |= SCIF_SCSCR_RIE;
245 break;
246 }
247 sil_wrh_mem(SCIF_SCSCR(ATTR_baseAddress), scr);
248}
249
250/*
251 * シリアルI/Oポートからのコールバックの禁止
252 */
253void
254eSIOPort_disableCBR(CELLIDX idx, uint_t cbrtn)
255{
256 CELLCB *p_cellcb = GET_CELLCB(idx);
257 uint16_t scr;
258
259 scr = sil_reh_mem(SCIF_SCSCR(ATTR_baseAddress));
260 switch (cbrtn) {
261 case SIOSendReady:
262 scr &= ~(SCIF_SCSCR_TIE);
263 break;
264 case SIOReceiveReady:
265 scr &= ~(SCIF_SCSCR_RIE);
266 break;
267 }
268 sil_wrh_mem(SCIF_SCSCR(ATTR_baseAddress), scr);
269}
270
271/*
272 * シリアルI/Oポートに対する受信割込み処理
273 */
274void
275eiRxISR_main(CELLIDX idx)
276{
277 CELLCB *p_cellcb = GET_CELLCB(idx);
278
279 if (scif_getready(p_cellcb)) {
280 /*
281 * 受信通知コールバックルーチンを呼び出す.
282 */
283 ciSIOCBR_readyReceive();
284 }
285}
286
287/*
288 * シリアルI/Oポートに対する送信割込み処理
289 */
290void
291eiTxISR_main(CELLIDX idx)
292{
293 CELLCB *p_cellcb = GET_CELLCB(idx);
294
295 if (scif_putready(p_cellcb)) {
296 /*
297 * 送信可能コールバックルーチンを呼び出す.
298 */
299 ciSIOCBR_readySend();
300 }
301}
Note: See TracBrowser for help on using the repository browser.