source: anotherchoice/tags/jsp-1.4.4-full-UTF8/config/h8-renesas/h8_sil.h@ 26

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

initial

File size: 6.2 KB
RevLine 
[26]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-2007 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: h8_sil.h,v 1.7 2007/03/23 07:58:33 honda Exp $
53 */
54
55/*
56 * H8向けSILの拡張(ビット演算)
57 *
58 * h8.hに記述するのがエレガントだが、sil.hとのインクルードの
59 * 順番の関係で独立したファイルとする
60 * t_config.hを直接インクルードしたときにsil.hよりå…
61ˆã«ã“の
62 * ファイルがインクルードされる可能性がある。
63 *
64 * コンパイラの型チェック機能を有効にするため、ポインタ型は
65 * UB *、UH *、UW *を用いている。
66 *
67 */
68
69#ifndef _SIL_H8_H_
70#define _SIL_H8_H_
71
72#ifndef _MACRO_ONLY
73
74#include <sil.h>
75#include <cpu_insn.h> /* bitset(), bitclr() */
76
77/*
78 * 8ビットレジスタのAND演算
79 */
80Inline void
81h8_anb_reg(UB *mem, UB data)
82{
83 UB reg = sil_reb_mem((VP)mem);
84 reg &= data;
85 sil_wrb_mem((VP)mem, (VB)reg);
86}
87
88/*
89 * 8ビットレジスタのOR演算
90 */
91Inline void
92h8_orb_reg(UB *mem, UB data)
93{
94 UB reg = sil_reb_mem((VP)mem);
95 reg |= data;
96 sil_wrb_mem((VP)mem, (VB)reg);
97}
98
99
100/*
101 * 16ビットレジスタのAND演算
102 */
103Inline void
104h8_anh_reg(UH *mem, UH data)
105{
106 UH reg = sil_reh_mem((VP)mem);
107 reg &= data;
108 sil_wrh_mem((VP)mem, (VH)reg);
109}
110
111/*
112 * 16ビットレジスタのOR演算
113 */
114Inline void
115h8_orh_reg(UH *mem, UH data)
116{
117 UH reg = sil_reh_mem((VP)mem);
118 reg |= data;
119 sil_wrh_mem((VP)mem, (VH)reg);
120}
121
122/*
123 * 32ビットレジスタのAND演算
124 */
125Inline void
126h8_anw_reg(UW *mem, UW data)
127{
128 UW reg = sil_rew_mem((VP)mem);
129 reg &= data;
130 sil_wrw_mem((VP)mem, (VW)reg);
131}
132
133/*
134 * 32ビットレジスタのOR演算
135 */
136Inline void
137h8_orw_reg(UW *mem, UW data)
138{
139 UW reg = sil_rew_mem((VP)mem);
140 reg |= data;
141 sil_wrw_mem((VP)mem, (VW)reg);
142}
143
144/*
145 * 割込みレベルの設定
146 *
147 *  irc :IRCデータのå…
148ˆé ­ã‚¢ãƒ‰ãƒ¬ã‚¹
149 *
150 *   UB *ipr:設定するIPRレジスタの番地
151 *   UB bit :IPRレジスタの該当するビット番号
152 *   IPM ipm:設定する割込みレベル
153 *        IPM_LEVEL0,IPM_LEVEL1のいずれか
154 */
155Inline void
156define_int_plevel(const IRC *irc)
157{
158 UB *ipr = irc->ipr;
159 UB bit = irc->bit;
160 IPM ipm = irc->ipm;
161
162 switch(ipm) {
163 case IPM_LEVEL0: /* プライオリティレベル0に設定 */
164 bitclr(ipr, bit);
165 break;
166 case IPM_LEVEL1: /* プライオリティレベル1に設定 */
167 bitset(ipr, bit);
168 break;
169 default:
170 assert(FALSE);
171 }
172}
173
174/*
175 * I/Oポートのデータ・ディレクション・レジスタDDRへのアクセス
176 * 
177 *  H8のDDRは書き込み専用であり、そのままでは所望のビットだけを
178 *  変更することができない。(bset,bclr命令でも回避不可)
179 *  そのため、本実装
180では、メモリ上にテンポラリを用意して、DDRの
181 *  現在値を保持する方法を採っている。
182 */
183/*
184 * DDRの番号定義
185 * 
186 *  é…
187åˆ—のインデックスに用いる。
188 *  ポート7はå…
189¥åŠ›å°‚用のため、省略している。
190 */
191typedef enum {
192 IO_PORT1,
193 IO_PORT2,
194 IO_PORT3,
195 IO_PORT4,
196 IO_PORT5,
197 IO_PORT6,
198 IO_PORT8,
199 IO_PORT9,
200 IO_PORTA,
201 IO_PORTB
202} IO_PORT;
203
204extern UB sil_reb_ddr(IO_PORT port) throw();
205extern void sil_wrb_ddr(IO_PORT port, UB data) throw();
206extern void sil_anb_ddr(IO_PORT port, UB data) throw();
207extern void sil_orb_ddr(IO_PORT port, UB data) throw();
208
209#endif /* _MACRO_ONLY */
210#endif /* _SIL_H8_H_ */
Note: See TracBrowser for help on using the repository browser.