source: rubycfg_asp/trunk/asp_dcre/target/gr_sakura_gcc/target_config.c@ 313

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

ソースを追加

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-csrc
File size: 6.2 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) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2005-2007 by Embedded and Real-Time Systems Laboratory
9 * Graduate School of Information Science, Nagoya Univ., JAPAN
10 * Copyright (C) 2008-2010 by Witz Corporation, JAPAN
11 * Copyright (C) 2013 by Mitsuhiro Matsuura
12 *
13 * 上記著作権者
14は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
15 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
16 * 変・再é…
17å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
18 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
19 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
20 * スコード中に含まれていること.
21 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
22 * 用できる形で再é…
23å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
24å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
25 * 者
26マニュアルなど)に,上記の著作権表示,この利用条件および下記
27 * の無保証規定を掲載すること.
28 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
29 * 用できない形で再é…
30å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
31 * と.
32 * (a) 再é…
33å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
34マニュアルなど)に,上記の著
35 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
36 * (b) 再é…
37å¸ƒã®å½¢æ…
38‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
39 * 報告すること.
40 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
41 * 害からも,上記著作権者
42およびTOPPERSプロジェクトをå…
43è²¬ã™ã‚‹ã“と.
44 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
45 * 由に基づく請求からも,上記著作権者
46およびTOPPERSプロジェクトを
47 * å…
48è²¬ã™ã‚‹ã“と.
49 *
50 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
51お
52 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
53 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
54 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
55 * の責任を負わない.
56 *
57 * @(#) $Id: target_config.c 313 2017-07-23 04:50:32Z coas-nagasima $
58 */
59
60/*
61 * ターゲットシステム依存モジュール(GR-SAKURA用)
62 */
63
64#include "kernel_impl.h"
65#include <sil.h>
66#include "gr_sakura.h"
67#include "rx600/rx630_uart.h"
68
69/*
70 * ターゲットシステム依存 初期化ルーチン
71 */
72void
73target_initialize( void )
74{
75 /*
76 * プロセッサ依存の初期化
77 */
78 prc_initialize();
79
80 /* IOポート初期化 */
81 /* P25を出力ポートにする */
82 sil_wrb_mem(PORT2_PDR_ADDR,
83 sil_reb_mem(PORT2_PDR_ADDR) | PORT_PDR_B5_BIT);
84 /* PA0, PA1, PA2, PA6を出力ポートにする */
85 sil_wrb_mem(PORTA_PDR_ADDR,
86 sil_reb_mem(PORTA_PDR_ADDR) | PORT_PDR_B0_BIT | PORT_PDR_B1_BIT | PORT_PDR_B2_BIT | PORT_PDR_B6_BIT);
87 /* PA7をå…
88¥åŠ›ãƒãƒ¼ãƒˆã«ã™ã‚‹ */
89 sil_wrb_mem(PORTA_PDR_ADDR,
90 sil_reb_mem(PORTA_PDR_ADDR) & ~PORT_PDR_B7_BIT);
91
92 /*
93 * シリアルポートの設定
94 */
95 rx630_uart_init(TARGET_PUTC_PORTID, UART_BAUDRATE, UART_CLKSRC);
96
97 /* ポートP20をTxD0, ポートP21をRxD0に */
98 sil_wrb_mem(PORT2_PMR_ADDR, 0x03);
99
100 /* データディレクションレジスタ(PDR)の設定 P21(RxD0)をå…
101¥åŠ›ãƒãƒ¼ãƒˆã«ã™ã‚‹ */
102 sil_wrb_mem(PORT2_PDR_ADDR,
103 sil_reb_mem(PORT2_PDR_ADDR) & ~PORT_PDR_B1_BIT);
104
105 /* データディレクションレジスタ(PDR)の設定 P20(TxD0)を出力ポートにする */
106 sil_wrb_mem(PORT2_PDR_ADDR,
107 sil_reb_mem(PORT2_PDR_ADDR) | PORT_PDR_B0_BIT);
108
109 /* ポートP40~P47を周辺機器に */
110 sil_wrb_mem(PORT4_PMR_ADDR, 0xFF);
111
112 /* ポートP40~P47をå…
113¥åŠ›ãƒãƒ¼ãƒˆã«ã™ã‚‹ */
114 sil_wrb_mem(PORT4_PDR_ADDR, 0x00);
115
116 /* 書き込みプロテクトレジスタの設定 PFSWEビットへの書き込みを許可 */
117 sil_wrb_mem(MPC_PWPR_ADDR, 0x00);
118 /* 書き込みプロテクトレジスタの設定 PxxFSレジスタへの書き込みを許可 */
119 sil_wrb_mem(MPC_PWPR_ADDR, 0x40);
120
121 /* P21端子機能制御レジスタ RXD0とする */
122 sil_wrb_mem(MPC_P21PFS_ADDR, 0x0a);
123 /* P20端子機能制御レジスタ TXD0とする */
124 sil_wrb_mem(MPC_P20PFS_ADDR, 0x0a);
125
126 /* P40端子機能制御レジスタ アナログå…
127¥åŠ›AN000とする */
128 sil_wrb_mem(MPC_P40PFS_ADDR, 0x80);
129 /* P41端子機能制御レジスタ アナログå…
130¥åŠ›AN001とする */
131 sil_wrb_mem(MPC_P41PFS_ADDR, 0x80);
132 /* P42端子機能制御レジスタ アナログå…
133¥åŠ›AN002とする */
134 sil_wrb_mem(MPC_P42PFS_ADDR, 0x80);
135 /* P43端子機能制御レジスタ アナログå…
136¥åŠ›AN003とする */
137 sil_wrb_mem(MPC_P43PFS_ADDR, 0x80);
138 /* P44端子機能制御レジスタ アナログå…
139¥åŠ›AN004とする */
140 sil_wrb_mem(MPC_P44PFS_ADDR, 0x80);
141 /* P45端子機能制御レジスタ アナログå…
142¥åŠ›AN005とする */
143 sil_wrb_mem(MPC_P45PFS_ADDR, 0x80);
144 /* P46端子機能制御レジスタ アナログå…
145¥åŠ›AN006とする */
146 sil_wrb_mem(MPC_P46PFS_ADDR, 0x80);
147 /* P47端子機能制御レジスタ アナログå…
148¥åŠ›AN007とする */
149 sil_wrb_mem(MPC_P47PFS_ADDR, 0x80);
150
151 /* 書き込みプロテクトレジスタの設定 書き込みを禁止 */
152 sil_wrb_mem(MPC_PWPR_ADDR, 0x80);
153}
154
155
156/*
157 * ターゲットシステムの終了ルーチン
158 */
159void
160target_exit( void )
161{
162 /*
163 * プロセッサ依存の終了処理
164 */
165 prc_terminate();
166
167 while ( 1 );
168}
169
170
171/*
172 * システムログの低レベル出力のための文字出力
173 */
174void
175target_fput_log( char c )
176{
177 if( c == '\n' ){
178 rx630_uart_pol_putc( '\r' , TARGET_PUTC_PORTID );
179 }
180
181 rx630_uart_pol_putc( c , TARGET_PUTC_PORTID );
182}
Note: See TracBrowser for help on using the repository browser.