OSDN Git Service

Change the directry name to hirado
[trx-305dsp/dsp.git] / hirado / kernel / config / blackfin / cpu_defs.c
1 /*
2  *  TOPPERS/JSP for Blackfin
3  *
4  *  Copyright (C) 2004,2006,2006 by Takemasa Nakamura
5  *
6  *  上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation 
7  *  によって公表されている GNU General Public License の Version 2 に記
8  *  述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
9  *  を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
10  *  利用と呼ぶ)することを無償で許諾する.
11  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
12  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
13  *      スコード中に含まれていること.
14  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
15  *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
16  *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
17  *      の無保証規定を掲載すること.
18  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
19  *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
20  *      と.
21  *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
22  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
23  *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
24  *        報告すること.
25  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
26  *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
27  * 
28  *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
29  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
30  *  含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
31  *  接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
32  * 
33  *  
34  */
35 // DESTRUCTIVE_READはsys_defs.hで定義する。 
36
37 // 破壊性読み出しレジスタにアクセスする場合は
38 // 割り込みロックをかける
39
40 #include <s_services.h>
41
42 #define __SIL_LOCK_INTERRUPT( x ) \
43     if (DESTRUCTIVE_READ(iop)){\
44         SIL_PRE_LOC;\
45         SIL_LOC_INT();\
46         x;\
47         SIL_UNL_INT();\
48     }\
49     else\
50         x;
51
52  VB sil_reb_iop(VP iop)
53 {
54     VH temp;
55 //  PROLOGUE
56     
57     __SIL_LOCK_INTERRUPT( temp = sil_reh_mem((VP)iop) );
58
59 //  EPILOGUE;
60     return temp;
61 }
62
63  VH sil_reh_iop(VP iop)
64 {
65     VH temp;
66
67     __SIL_LOCK_INTERRUPT( temp = sil_reh_mem((VP)iop) );
68
69     return temp;
70 }
71
72  VW sil_rew_iop(VP iop)
73 {
74     VW temp;
75
76     __SIL_LOCK_INTERRUPT( temp = sil_rew_mem((VP)iop) );
77
78     return temp;
79 }
80
81
82  VH sil_reh_lep(VP iop)
83 {
84     VH temp;
85     
86     __SIL_LOCK_INTERRUPT( temp = sil_reh_lem((VP)iop) );
87
88     return temp;
89 }
90
91
92  VW sil_rew_lep(VP iop)
93 {
94     VW temp;
95     
96     __SIL_LOCK_INTERRUPT( temp = sil_rew_lem((VP)iop) );
97
98     return temp;
99 }
100
101  VH sil_reh_bep(VP iop)
102 {
103     VH temp;
104     
105     __SIL_LOCK_INTERRUPT( temp = sil_reh_bem((VP)iop) );
106
107     return temp;
108 }
109
110  VW sil_rew_bep(VP iop)
111 {
112     VW temp;
113     
114     __SIL_LOCK_INTERRUPT( temp = sil_rew_bem((VP)iop) );
115
116     return temp;
117 }
118