source: anotherchoice/tags/jsp-1.4.4-full-UTF8/config/sh1/kz_sh1/sys_support.S@ 26

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

initial

File size: 5.0 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-2004 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2001-2004 by Industrial Technology Institute,
9 * Miyagi Prefectural Government, JAPAN
10 *
11 * 上記著作権者
12は,以下の (1)〜(4) の条件か,Free Software Foundation
13 * によってå…
14¬è¡¨ã•ã‚Œã¦ã„ã‚‹ GNU General Public License の Version 2 に記
15 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
16 * を改変したものを含む.以下同じ)を使用・複製・改変・再é…
17å¸ƒï¼ˆä»¥ä¸‹ï¼Œ
18 * 利用と呼ぶ)することを無償で許諾する.
19 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
20 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
21 * スコード中に含まれていること.
22 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
23 * 用できる形で再é…
24å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
25å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
26 * 者
27マニュアルなど)に,上記の著作権表示,この利用条件および下記
28 * の無保証規定を掲載すること.
29 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
30 * 用できない形で再é…
31å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
32 * と.
33 * (a) 再é…
34å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
35マニュアルなど)に,上記の著
36 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
37 * (b) 再é…
38å¸ƒã®å½¢æ…
39‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
40 * 報告すること.
41 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
42 * 害からも,上記著作権者
43およびTOPPERSプロジェクトをå…
44è²¬ã™ã‚‹ã“と.
45 *
46 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
47お
48 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
49 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
50 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
51 *
52 * @(#) $Id: sys_support.S,v 1.11 2004/09/22 08:47:52 honda Exp $
53 */
54
55/*
56 * ターゲットシステム依存モジュール アセンブリ言語部(KZ-SH1用)
57 */
58
59#define _MACRO_ONLY
60#include "jsp_kernel.h"
61
62#ifndef GDB_STUB
63/*
64 * バスステートコントローラ
65 */
66#define WCR1 0x5ffffa2 /* ウェイトコントロールレジスタ1 */
67#define WCR2 0x5ffffa4 /* ウェイトコントロールレジスタ2 */
68#define WCR3 0x5ffffa6 /* ウェイトコントロールレジスタ3 */
69
70 /* エリア7:リードサイクルでWAIT信号による */
71 /* ウェートステート挿å…
72¥ã‚ã‚Š */
73#define WCR1_RW7 0x8000
74 /* エリア3:リードサイクルでWAIT信号による */
75 /* ウェートステート挿å…
76¥ã‚ã‚Š */
77#define WCR1_RW3 0x800
78 /* エリア0:リードサイクルでWAIT信号による */
79 /* ウェートステート挿å…
80¥ã‚ã‚Š */
81#define WCR1_RW0 0x100
82 /* エリア0,2:1ステートロングウェイト */
83#define WCR3_A02LW 0x6000
84
85
86
87/*
88 * 低レベルのターゲットシステム依存の初期化 _hardware_init_hook
89 *
90 * スタートアップモジュールの中で,メモリの初期化の前に呼び出される.
91 */
92 .text
93 .align 2
94 .global _hardware_init_hook
95_hardware_init_hook:
96 /*
97 * バスステートコントローラの初期化
98 *
99 */
100
101 /*
102 * ウェイトステートコントロールレジスタWCR1
103 *  RW3 = 0
104 *    エリア3:リードサイクルは1ステートで終了
105 *
106 *  RW0 = 0
107 *    エリア0:リードサイクルでWAIT信号による
108 *    ウェートステート挿å…
109¥ãªã—
110 */
111
112 /* *WCR1 &= ~(WCR1_RW3 | WCR1_RW0); */
113 mov.l _hw_hook_wcr1, r0
114 mov.w @r0, r1 /* r1←WCR1 */
115 mov.w _hw_hook_wcr1_data, r2
116 and r2, r1
117 mov.w r1, @r0 /* WCR1←r1 */
118
119
120 /*
121 * ウェイトステートコントロールレジスタWCR3
122 *
123 *  A02LW = 00
124 *    エリア0,2:1ステートロングウェイト
125 */
126
127 mov.l _hw_hook_wcr3, r3
128 mov.w @r3, r4 /* r4←WCR3 */
129 mov.w _hw_hook_wcr3_a02lw, r5
130 and r5, r4
131 rts
132 mov.w r4, @r3 /* WCR3←r4 */
133
134 /* エリア0,2:1ステートロングウェイト */
135 /* *WCR3 &= WCR3_A02LW_MASK; */
136
137
138
139 .align 2
140_hw_hook_wcr1:
141 .long WCR1
142_hw_hook_wcr3:
143 .long WCR3
144_hw_hook_wcr1_data:
145 .word ~(WCR1_RW3 | WCR1_RW0) & 0xffff
146_hw_hook_wcr3_a02lw:
147 .word ~WCR3_A02LW & 0xffff
148
149#endif /* GDB_STUB */
Note: See TracBrowser for help on using the repository browser.