source: atk2-sc3_fl850f1l/arch/v850_gcc/uart_rlin.c@ 117

Last change on this file since 117 was 117, checked in by ertl-ishikawa, 9 years ago

ATK2-SC3 1.3.2 FL850F1L(RH850F1L)依存部(GCC/GHS/CCRH)を追加

File size: 3.7 KB
Line 
1/*
2 * TOPPERS ATK2
3 * Toyohashi Open Platform for Embedded Real-Time Systems
4 * Automotive Kernel Version 2
5 *
6 * Copyright (C) 2012-2014 by Center for Embedded Computing Systems
7 * Graduate School of Information Science, Nagoya Univ., JAPAN
8 *
9 * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
10 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
11 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
12 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
13 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
14 * スコード中に含まれていること.
15 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
16 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
17 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
18 * の無保証規定を掲載すること.
19 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
20 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
21 * と.
22 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
23 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
24 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
25 * 報告すること.
26 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
27 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
28 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
29 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
30 * 免責すること.
31 *
32 * 本ソフトウェアは,AUTOSAR(AUTomotive Open System ARchitecture)仕
33 * 様に基づいている.上記の許諾は,AUTOSARの知的財産権を許諾するもので
34 * はない.AUTOSARは,AUTOSAR仕様に基づいたソフトウェアを商用目的で利
35 * 用する者に対して,AUTOSARパートナーになることを求めている.
36 *
37 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
38 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
39 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
40 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
41 * の責任を負わない.
42 *
43 * $Id: uart_rlin.c 164 2015-06-03 01:22:29Z t_ishikawa $
44 */
45
46/*
47 * シリアルI/Oデバイス(SIO)ドライバ(RLIN用)
48 */
49
50#include "Os.h"
51#include "target_serial.h"
52#include "uart_rlin.h"
53#include "Os_Lcfg.h"
54
55
56/* 内部関数のプロトタイプ宣言 */
57LOCAL_INLINE uint8 uart_getchar(void);
58
59/*
60 * 受信した文字の取り出し
61 */
62LOCAL_INLINE uint8
63uart_getchar(void)
64{
65 return(sil_reb_mem((void *) (RLIN3x_BASE + RLIN3xLURDRL_B)));
66}
67
68/*
69 * 初期化処理
70 */
71void
72InitHwSerial(void)
73{
74
75 /* Uart Mode を有効(ノイズフィルタも有効) */
76 sil_wrb_mem((void *) (RLIN3x_BASE + RLIN3xLMD_B), 0x31);
77
78 /* ボーレート設定 */
79 sil_wrb_mem((void *) (RLIN3x_BASE + RLIN3xLWBR_B), RLIN3xLWBR_VAL);
80 sil_wrh_mem((void *) (RLIN3x_BASE + RLIN3xLBRP01_H), RLIN3xLBRP01_VAL);
81
82 /* エラー検出許可 */
83 sil_wrb_mem((void *) (RLIN3x_BASE + RLIN3xLEDE_B), 0x0d);
84
85 /* データ フォーマット */
86 sil_wrb_mem((void *) (RLIN3x_BASE + RLIN3xLBFC_B), 0x00);
87
88 /* リセット解除 */
89 sil_wrb_mem((void *) (RLIN3x_BASE + RLIN3xLCUC_B), 0x01);
90
91 /* リセット解除待ち */
92 while (sil_reb_mem((void *) (RLIN3x_BASE + RLIN3xLMST_B)) == 0x00) {
93 }
94
95 /* 送受信動作許可 */
96 sil_wrb_mem((void *) (RLIN3x_BASE + RLIN3xLUOER_B), 0x03);
97
98 /* 受信割込み許可 */
99 sil_wrb_mem((void *) (RLIN3x_BASE + RLIN3xLIE_B), 0x02);
100}
101
102/*
103 * シリアルI/Oポートのクローズ
104 */
105void
106TermHwSerial(void)
107{
108 /* 受信割込みの禁止 */
109 sil_wrb_mem((void *) (RLIN3x_BASE + RLIN3xLIE_B), 0x00);
110}
111
112/*
113 * SIOの割込みハンドラ
114 */
115ISR(RxHwSerialInt)
116{
117 /*
118 * 受信通知コールバックルーチンを呼び出す
119 */
120 RxSerialInt(uart_getchar());
121}
Note: See TracBrowser for help on using the repository browser.