source: anotherchoice/tags/jsp-1.4.4-full-UTF8/config/sh3/start.S@ 26

Last change on this file since 26 was 26, checked in by ykominami, 10 years ago

initial

File size: 5.4 KB
Line 
1/*
2 * TOPPERS/JSP Kernel
3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Just Standard Profile Kernel
5 *
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 *
9 * 上記著作権者
10は,以下の (1)〜(4) の条件か,Free Software Foundation
11 * によってå…
12¬è¡¨ã•ã‚Œã¦ã„ã‚‹ GNU General Public License の Version 2 に記
13 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
14 * を改変したものを含む.以下同じ)を使用・複製・改変・再é…
15å¸ƒï¼ˆä»¥ä¸‹ï¼Œ
16 * 利用と呼ぶ)することを無償で許諾する.
17 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
18 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
19 * スコード中に含まれていること.
20 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
21 * 用できる形で再é…
22å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
23å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
24 * 者
25マニュアルなど)に,上記の著作権表示,この利用条件および下記
26 * の無保証規定を掲載すること.
27 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
28 * 用できない形で再é…
29å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
30 * と.
31 * (a) 再é…
32å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
33マニュアルなど)に,上記の著
34 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
35 * (b) 再é…
36å¸ƒã®å½¢æ…
37‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
38 * 報告すること.
39 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
40 * 害からも,上記著作権者
41およびTOPPERSプロジェクトをå…
42è²¬ã™ã‚‹ã“と.
43 *
44 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
45お
46 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
47 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
48 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
49 *
50 * @(#) $Id: start.S,v 1.10 2003/12/11 00:52:12 honda Exp $
51 */
52
53/*
54 * カーネル用のスタートアップモジュール
55 */
56#define _MACRO_ONLY
57#include <t_config.h>
58#include <sys_defs.h>
59
60/*
61 * SH3用スタートアップモジュール
62 * カーネルはアプリケーションとリンクして使用する
63 * だけなのでJSPカーネルのみ使用する。
64 */
65 .global _start
66 .align 2
67_start:
68 /*
69 * キャッシュの初期化
70 */
71 mov.l _ccr_addr,r1
72 mov.l _ccr_disable,r2
73 mov.l r2,@r1
74 mov.l _ccr_mode,r2
75 mov.l r2,@r1
76
77 /*
78 * SRを初期化する。
79 * MD=1, RB=0, BL=0, I3〜I0=e fはstubのみ
80 */
81 mov.l _init_sr,r0
82 ldc r0,sr
83 mov #0x01,r0
84 ldc r0,r7_bank
85 /*
86 * タスク独立のスタックをSTACKTOPに初期化する
87 * STACKTOPは、sys_config.hで定義
88 */
89 mov.l _stack_k, r15
90
91 /*
92 * _hardware_init_hook を呼び出す。(0でない場合)
93 *
94 * ハードウェア依存に必
95要な初期化処理がある場合は,
96 * hardware_init_hook という関数を用意すればよい.
97 * å…
98·ä½“的にはROM化の際、RAMを使用可能にするための
99 * バスコントローラの初期化等を行う。
100 * sys_support.S 内
101で _hardware_init_hook を定義してい
102 * る.
103 */
104
105start_0:
106 mov.l _hardware_init_hook_k, r0
107 tst r0,r0
108 bt start_1
109 jsr @r0
110 or r0,r0
111
112
113 /*
114 * bssセクションをクリア
115 */
116start_1:
117 mov.l _bss_start_k,r0
118 mov.l _end_k,r1
119 cmp/eq r0,r1
120 bt start_3
121 mov #0,r2
122start_2:
123 mov.l r2,@r0
124 add #4,r0
125 cmp/hi r0,r1
126 bt start_2
127
128 /*
129 * dataセクションを初期化する(ROM化対応).
130 *
131 * __idata_start から __idata_end までを,__data_start 以降に
132 * コピーする.
133 */
134start_3:
135 mov.l __idata_start_k,r1
136 mov.l __idata_end_k,r2
137 cmp/eq r1,r2
138 bt start_5
139 mov.l __data_start_k,r0
140start_4:
141 mov.l @r1+,r4
142 mov.l r4,@r0
143 cmp/hi r1,r2
144 add #4,r0
145 bt start_4
146
147
148 /*
149 * _software_init_hook を呼び出す(0 でない場合).
150 *
151 * ソフトウェア環境(特にライブラリ)に依存して必
152要な初期化処
153 * 理がある場合は,software_init_hook という関数を用意すれば
154 * よい.
155 */
156start_5:
157 mov.l _software_init_hook_k, r0
158 tst r0,r0
159 bt start_6
160 jsr @r0
161 or r0,r0
162
163
164start_6:
165 /*
166 * カーネルを起動する
167 */
168 ! call the mainline
169 mov.l _kernel_start_k,r0
170 jsr @r0
171 or r0,r0
172
173
174 .align 4
175_ccr_addr:
176 .long CCR
177_ccr_disable:
178 .long CCR_DISABLE
179_ccr_mode:
180 .long CCR_MODE
181_init_sr:
182 .long 0x40000000 + MAX_IPM << 4
183_stack_k:
184 .long STACKTOP
185_bss_start_k:
186 .long __bss_start
187_end_k:
188 .long _end
189__idata_start_k:
190 .long __idata_start
191__idata_end_k:
192 .long __idata_end
193__data_start_k:
194 .long __data_start
195_kernel_start_k:
196 .long _kernel_start
197_hardware_init_hook_k:
198 .long _hardware_init_hook
199_software_init_hook_k:
200 .long _software_init_hook
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
Note: See TracBrowser for help on using the repository browser.