source: EcnlProtoTool/trunk/asp3_dcre/arch/arm_gcc/common/gic_support.S@ 321

Last change on this file since 321 was 321, checked in by coas-nagasima, 7 years ago

文字コードを設定

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/plain;charset=UTF-8
File size: 6.2 KB
Line 
1/*
2 * TOPPERS Software
3 * Toyohashi Open Platform for Embedded Real-Time Systems
4 *
5 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
6 * Toyohashi Univ. of Technology, JAPAN
7 * Copyright (C) 2006-2017 by Embedded and Real-Time Systems Laboratory
8 * Graduate School of Information Science, Nagoya Univ., JAPAN
9 *
10 * 上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
11 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
12 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
13 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
14 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
15 * スコード中に含まれていること.
16 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
17 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
18 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
19 * の無保証規定を掲載すること.
20 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
21 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
22 * と.
23 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
24 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
25 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
26 * 報告すること.
27 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
28 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
29 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
30 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
31 * 免責すること.
32 *
33 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
34 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
35 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
36 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
37 * の責任を負わない.
38 *
39 * $Id$
40 */
41
42/*
43 * カーネルの割込みコントローラ依存部のアセンブリ言語部(GIC用)
44 */
45
46#define TOPPERS_MACRO_ONLY
47#define TOPPERS_ASM_MACRO
48#define UINT_C(val) (val) /* uint_t型の定数を作るマクロ */
49#define ULONG_C(val) (val) /* ulong_t型の定数を作るマクロ */
50#define CAST(type, val) (val) /* 型キャストを行うマクロ */
51#define GIC_REG(base, offset) ((base) + (offset))
52#include "kernel_impl.h"
53#include "core_asm.inc"
54
55#if __TARGET_ARCH_ARM < 6
56#error gic_suport.S supports ARMv6 or later.
57#endif /* __TARGET_ARCH_ARM < 6 */
58
59/*
60 * 割込みハンドラ呼出し前の割込みコントローラ操作
61 *
62 * r4に割込み番号を返す.irc_end_intで用いる情報(割込み発生前の割込み
63 * 優先度マスク)を,スタックの先頭に保存する.
64 */
65 ATEXT
66 AALIGN(2)
67 AGLOBAL(irc_begin_int)
68ALABEL(irc_begin_int)
69 /*
70 * 割込み要因を取得する.
71 */
72 ldr r1, =GICC_IAR
73 ldr r3, [r1]
74
75 /*
76 * 割込み番号を求める.
77 */
78 lsl r4, r3, #22 /* 下位10ビットを取り出す */
79 lsr r4, r4, #22
80
81 /*
82 * 割込み要求をクリアする.
83 */
84 and r0, r4, #31
85 mov r2, #1
86 lsl r0, r2, r0
87 ldr r2, =GICD_ICPENDR(0)
88 lsr r1, r4, #5
89 str r0, [r2,r1,lsl #2]
90
91 /*
92 * 割込み要因の割込み優先度を求め,割込み優先度マスクに設定する.
93 */
94 ldr r1, =GICC_RPR /* 受け付けた割込みの割込み優先度を取得 */
95 ldr r0, [r1]
96 ldr r1, =GICC_PMR /* 割込み発生前の割込み優先度を取得 */
97 ldr r2, [r1]
98 str r0, [r1] /* 新しい割込み優先度マスクをセットする */
99 asm_data_sync_barrier r0 /* 割込み優先度マスクがセットされるのを待つ */
100 str r2, [sp] /* irc_end_intで用いる情報を保存 */
101
102 /*
103 * EOIを発行する.
104 */
105 ldr r1, =GICC_EOIR /* EOIレジスタへの書込み */
106 str r3, [r1]
107
108 /*
109 * 割込み番号を返値としてリターンする.
110 */
111 bx lr
112
113/*
114 * 割込みハンドラ呼出し後の割込みコントローラ操作
115 */
116 ATEXT
117 AALIGN(2)
118 AGLOBAL(irc_end_int)
119ALABEL(irc_end_int)
120 /*
121 * 割込み優先度マスクを元に戻す.
122 */
123 ldr r2, [sp] /* irc_begin_intで保存した情報を復帰 */
124 ldr r1, =GICC_PMR /* 割込み優先度マスクを元に戻す */
125 str r2, [r1]
126 bx lr
127
128/*
129 * CPU例外発生前の割込み優先度の取得
130 *
131 * CPU例外の発生で割込み優先度が変わることはないため,現在の割込み優先
132 * 度を返す.
133 */
134 ATEXT
135 AALIGN(2)
136 AGLOBAL(irc_get_intpri)
137ALABEL(irc_get_intpri)
138 /*
139 * 割込み優先度マスクを外部表現に変換して返す.
140 */
141 ldr r1, =GICC_PMR
142 ldr r0, [r1]
143 asr r0, r0, #GIC_PRI_SHIFT
144 sub r0, r0, #GIC_PRI_MASK
145 bx lr
146
147/*
148 * CPU例外ハンドラ呼出し前の割込みコントローラ操作
149 *
150 * irc_end_excで用いる情報(CPU例外発生前の割込み優先度マスク)を,スタッ
151 * クの先頭に保存する.
152 */
153 ATEXT
154 AALIGN(2)
155 AGLOBAL(irc_begin_exc)
156ALABEL(irc_begin_exc)
157 /*
158 * 割込み優先度マスクを保存する.
159 */
160 ldr r1, =GICC_PMR /* 現在の割込み優先度を取得 */
161 ldr r2, [r1]
162 str r2, [sp] /* irc_end_excで用いる情報を保存 */
163 bx lr
164
165/*
166 * CPU例外ハンドラ呼出し後の割込みコントローラ操作
167 */
168 ATEXT
169 AALIGN(2)
170 AGLOBAL(irc_end_exc)
171ALABEL(irc_end_exc)
172 /*
173 * 割込み優先度マスクを元に戻す.
174 */
175 ldr r2, [sp] /* irc_begin_excで保存した情報を復帰 */
176 ldr r1, =GICC_PMR /* 割込み優先度マスクを元に戻す */
177 str r2, [r1]
178 bx lr
Note: See TracBrowser for help on using the repository browser.