OSDN Git Service

Sメーター周りを修正
[trx-305dsp/dsp.git] / trx305 / kernel / config / m68k / cpu_defs.h
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  *  Copyright (C) 2005 by Embedded and Real-Time Systems Laboratory
9  *              Graduate School of Information Science, Nagoya Univ., JAPAN
10  * 
11  *  上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation 
12  *  によって公表されている GNU General Public License の Version 2 に記
13  *  述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
14  *  を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
15  *  利用と呼ぶ)することを無償で許諾する.
16  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
17  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
18  *      スコード中に含まれていること.
19  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
20  *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
21  *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
22  *      の無保証規定を掲載すること.
23  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
24  *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
25  *      と.
26  *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
27  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
28  *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
29  *        報告すること.
30  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
31  *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
32  * 
33  *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
34  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
35  *  含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
36  *  接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
37  * 
38  *  @(#) $Id: cpu_defs.h,v 1.1 2009/01/31 05:27:37 suikan Exp $
39  */
40
41 /*
42  *  プロセッサに依存する定義(M68040用)
43  *
44  *  このインクルードファイルは,kernel.h と sil.h でインクルードされる.
45  *  他のファイルから直接インクルードすることはない.このファイルをイン
46  *  クルードする前に,t_stddef.h と itron.h がインクルードされるので,
47  *  それらに依存してもよい.
48  */
49
50 #ifndef _CPU_DEFS_H_
51 #define _CPU_DEFS_H_
52
53 #define M68K            /* プロセッサ略称 */
54
55 #ifndef _MACRO_ONLY
56
57 /*
58  *  割込み/CPU例外ハンドラ番号の型
59  */
60 typedef UINT    INHNO;      /* 割込みハンドラ番号 */
61 typedef UINT    EXCNO;      /* CPU例外ハンドラ番号 */
62
63 /*
64  *  割込みマスクの型と割込みマスクの変更/参照
65  */
66 typedef UINT    IPM;        /* 割込みマスク */
67
68 extern ER   chg_ipm(IPM ipm) throw();
69 extern ER   get_ipm(IPM *p_ipm) throw();
70
71 /*
72  *  微少時間待ち
73  */
74 Inline void
75 sil_dly_nse(UINT dlytim)
76 {
77     register VW d0 asm("d0") = (VW) dlytim;
78     Asm("jsr _sil_dly_nse" : "=g"(d0) : "0"(d0));
79 }
80
81 #endif /* _MACRO_ONLY */
82
83 /*
84  *  プロセッサのエンディアン
85  */
86 #define SIL_ENDIAN  SIL_ENDIAN_BIG  /* ビッグエンディアン */
87
88 #endif /* _CPU_DEFS_H_ */