source: atk2-sc3-1.4.0-ntisr/kernel/interrupt.c@ 172

Last change on this file since 172 was 172, checked in by ertl-ishikawa, 8 years ago

ATK2-SC3 1.4.0 RH850依存部 非信頼C2ISR対応を追加

File size: 9.4 KB
Line 
1/*
2 * TOPPERS ATK2
3 * Toyohashi Open Platform for Embedded Real-Time Systems
4 * Automotive Kernel Version 2
5 *
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2004-2015 by Center for Embedded Computing Systems
9 * Graduate School of Information Science, Nagoya Univ., JAPAN
10 * Copyright (C) 2011-2015 by FUJI SOFT INCORPORATED, JAPAN
11 * Copyright (C) 2011-2013 by Spansion LLC, USA
12 * Copyright (C) 2011-2015 by NEC Communication Systems, Ltd., JAPAN
13 * Copyright (C) 2011-2015 by Panasonic Advanced Technology Development Co., Ltd., JAPAN
14 * Copyright (C) 2011-2014 by Renesas Electronics Corporation, JAPAN
15 * Copyright (C) 2011-2015 by Sunny Giken Inc., JAPAN
16 * Copyright (C) 2011-2015 by TOSHIBA CORPORATION, JAPAN
17 * Copyright (C) 2004-2015 by Witz Corporation
18 * Copyright (C) 2014-2015 by AISIN COMCRUISE Co., Ltd., JAPAN
19 * Copyright (C) 2014-2015 by eSOL Co.,Ltd., JAPAN
20 * Copyright (C) 2014-2015 by SCSK Corporation, JAPAN
21 * Copyright (C) 2015 by SUZUKI MOTOR CORPORATION
22 *
23 * 上記著作権者
24は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
25 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
26 * 変・再é…
27å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
28 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
29 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
30 * スコード中に含まれていること.
31 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
32 * 用できる形で再é…
33å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
34å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
35 * 者
36マニュアルなど)に,上記の著作権表示,この利用条件および下記
37 * の無保証規定を掲載すること.
38 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
39 * 用できない形で再é…
40å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
41 * と.
42 * (a) 再é…
43å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
44マニュアルなど)に,上記の著
45 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
46 * (b) 再é…
47å¸ƒã®å½¢æ…
48‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
49 * 報告すること.
50 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
51 * 害からも,上記著作権者
52およびTOPPERSプロジェクトをå…
53è²¬ã™ã‚‹ã“と.
54 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
55 * 由に基づく請求からも,上記著作権者
56およびTOPPERSプロジェクトを
57 * å…
58è²¬ã™ã‚‹ã“と.
59 *
60 * 本ソフトウェアは,AUTOSAR(AUTomotive Open System ARchitecture)仕
61 * 様に基づいている.上記の許諾は,AUTOSARの知的財産権を許諾するもので
62 * はない.AUTOSARは,AUTOSAR仕様に基づいたソフトウェアを商用目的で利
63 * 用する者
64に対して,AUTOSARパートナーになることを求めている.
65 *
66 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
67お
68 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
69 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
70 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
71 * の責任を負わない.
72 *
73 * $Id: interrupt.c 425 2015-12-07 08:06:19Z witz-itoyo $
74 */
75
76/*
77 * 割込み制御モジュール
78 */
79
80#include "kernel_impl.h"
81#include "interrupt.h"
82
83#ifdef TOPPERS_interrupt_initialize
84/*
85 * 実行中のC2ISR
86 */
87ISRCB *p_runisr;
88#ifdef NTC2ISR
89QUEUE isr_ready_queue;
90#endif /* NTC2ISR */
91
92/*
93 * 割込み管理機能内
94部で使用する変数の定義
95 */
96
97/*
98 * SuspendAllInterrupts のネスト回数
99 */
100uint8 sus_all_cnt = 0U;
101
102/*
103 * SuspendOSInterrupts のネスト回数
104 */
105uint8 sus_os_cnt = 0U;
106
107/*
108 * 割込み管理機能の初期化
109 */
110#ifndef OMIT_INITIALIZE_INTERRUPT
111
112void
113interrupt_initialize(void)
114{
115 ISRType i;
116 InterruptNumberType j;
117 ISRCB *p_isrcb;
118 const INTINIB *p_intinib;
119
120 p_runisr = NULL;
121
122 sus_all_cnt = 0U;
123 sus_os_cnt = 0U;
124
125 for (i = 0U; i < tnum_isr2; i++) {
126 p_isrcb = &(isrcb_table[i]);
127 p_isrcb->p_isrinib = &(isrinib_table[i]);
128 p_isrcb->p_lastrescb = NULL;
129 p_isrcb->p_lastcntcb = NULL;
130#ifdef CFG_USE_PROTECTIONHOOK
131 p_isrcb->calltfn = FALSE;
132#endif /* CFG_USE_PROTECTIONHOOK */
133#ifdef NTC2ISR
134 queue_initialize(&(p_isrcb->isr_queue));
135#endif /* NTC2ISR */
136 }
137
138 for (j = 0U; j < tnum_intno; j++) {
139 p_intinib = &(intinib_table[j]);
140 x_config_int(p_intinib->intno, p_intinib->intatr, p_intinib->intpri);
141 }
142
143#ifdef NTC2ISR
144 queue_initialize(&isr_ready_queue);
145#endif /* NTC2ISR */
146}
147
148#endif /* OMIT_INITIALIZE_INTERRUPT */
149#endif /* TOPPERS_interrupt_initialize */
150
151/*
152 * 割込み禁止の解除
153 */
154#ifdef TOPPERS_release_interrupts
155
156void
157release_interrupts(OSServiceIdType serviceId)
158{
159#ifdef CFG_USE_ERRORHOOK
160 boolean call_error_hook = FALSE;
161#endif /* CFG_USE_ERRORHOOK */
162
163 if (sus_os_cnt > 0U) {
164 sus_os_cnt = 0U;
165 LEAVE_CALLEVEL(TSYS_SUSOSINT);
166 x_nested_unlock_os_int();
167#ifdef CFG_USE_ERRORHOOK
168 call_error_hook = TRUE;
169#endif /* CFG_USE_ERRORHOOK */
170 }
171
172 if (sus_all_cnt > 0U) {
173 sus_all_cnt = 0U;
174 LEAVE_CALLEVEL(TSYS_SUSALLINT);
175 ASSERT((callevel_stat & TSYS_DISALLINT) == TSYS_NULL);
176 x_unlock_all_int();
177#ifdef CFG_USE_ERRORHOOK
178 call_error_hook = TRUE;
179#endif /* CFG_USE_ERRORHOOK */
180 }
181
182 /* C2ISRの場合のみDisAllを解除する */
183 if (serviceId == OSServiceId_ISRMissingEnd) {
184 if ((callevel_stat & TSYS_DISALLINT) != TSYS_NULL) {
185 LEAVE_CALLEVEL(TSYS_DISALLINT);
186 x_unlock_all_int();
187#ifdef CFG_USE_ERRORHOOK
188 call_error_hook = TRUE;
189#endif /* CFG_USE_ERRORHOOK */
190 }
191 }
192
193#ifdef CFG_USE_ERRORHOOK
194 if ((serviceId != OSServiceId_Invalid) && (call_error_hook != FALSE)) {
195 call_errorhook(E_OS_DISABLEDINT, serviceId);
196 }
197#endif /* CFG_USE_ERRORHOOK */
198}
199
200#endif /* TOPPERS_release_interrupts */
201
202/*
203 * C2ISR終了時のチェック関数
204 */
205#ifdef TOPPERS_exit_isr2
206
207/*
208 * C2ISRのå…
209¨ãƒªã‚½ãƒ¼ã‚¹è¿”却
210 */
211LOCAL_INLINE void
212release_isrresources(ISRCB *p_isrcb)
213{
214
215 /* OS割込み禁止状æ…
216‹ä»¥ä¸Šã§æ¥ã‚‹ã¯ãš */
217 if (p_isrcb->p_lastrescb != NULL) {
218 do {
219 x_set_ipm(p_isrcb->p_lastrescb->prevpri);
220 p_isrcb->p_lastrescb->lockflg = FALSE;
221 p_isrcb->p_lastrescb = p_isrcb->p_lastrescb->p_prevrescb;
222 } while (p_isrcb->p_lastrescb != NULL);
223
224#ifdef CFG_USE_ERRORHOOK
225 call_errorhook(E_OS_RESOURCE, OSServiceId_ISRMissingEnd);
226#endif /* CFG_USE_ERRORHOOK */
227 }
228}
229
230/*
231 * タスクのカウンタの状æ…
232‹ã‚’すべてCS_NULLに戻す
233 */
234void
235cancel_isrcounters(ISRCB *p_isrcb)
236{
237 if (p_isrcb->p_lastcntcb != NULL) {
238
239 /* OS割込み禁止状æ…
240‹ä»¥ä¸Šã§æ¥ã‚‹ */
241 do {
242 p_isrcb->p_lastcntcb->cstat = CS_NULL;
243 p_isrcb->p_lastcntcb = p_isrcb->p_lastcntcb->p_prevcntcb;
244 } while (p_isrcb->p_lastcntcb != NULL);
245 }
246}
247
248void
249exit_isr2(void)
250{
251 x_nested_lock_os_int();
252
253 release_interrupts(OSServiceId_ISRMissingEnd);
254
255 release_isrresources(p_runisr);
256
257 x_nested_unlock_os_int();
258}
259
260#endif /* TOPPERS_exit_isr2 */
261
262void
263force_term_osap_isr(OSAPCB *p_osapcb)
264{
265 ISRType i;
266 ISRCB *p_isrcb;
267 const INTINIB *p_intinib;
268
269 /* レディキューに繋がれているISRを強制終了 */
270 for (p_isrcb = (&isr_ready_queue)->p_next;
271 p_isrcb != &isr_ready_queue;
272 p_isrcb = p_isrcb->isr_queue.p_next) {
273 if (p_isrcb->p_isrinib->p_osapcb == p_osapcb) {
274#ifdef CFG_USE_PROTECTIONHOOK
275 p_isrcb->calltfn = FALSE;
276#endif /* CFG_USE_PROTECTIONHOOK */
277 /* リソース確保したままの場合,リソース解放 */
278 release_isrresources(p_isrcb);
279 /* カウンタの状æ…
280‹ã‚’初期化する */
281 cancel_isrcounters(p_isrcb);
282 /*レディキューから除外*/
283 queue_delete(p_isrcb);
284 }
285 }
286
287 if (p_runisr != NULL && p_runisr->p_isrinib->p_osapcb == p_osapcb) {
288#ifdef CFG_USE_PROTECTIONHOOK
289 p_runisr->calltfn = FALSE;
290#endif /* CFG_USE_PROTECTIONHOOK */
291 /* リソース確保したままの場合,リソース解放 */
292 release_isrresources(p_runisr);
293 /* カウンタの状æ…
294‹ã‚’初期化する */
295 cancel_isrcounters(p_runisr);
296 }
297
298 for (i = 0U; i < tnum_isr2; i++) {
299 p_isrcb = &(isrcb_table[i]);
300 if (p_isrcb->p_isrinib->p_osapcb == p_osapcb) {
301 p_intinib = &(intinib_table[i]);
302 x_disable_int(p_intinib->intno);
303 }
304 }
305}
306
307/*
308 * プロテクションフックの出口からここへ来る
309 * ここに来るパスは以下のとおり
310 * - ISR → プロテクションフック → PRO_TERMINATE_TASKISR
311 */
312void
313force_terminate_isr(ISRCB *p_isrcb)
314{
315 /*
316 * 割込み禁止を解除する
317 * エラーフックを呼ばないため,引数にOSServiceId_Invalidをする
318 */
319 release_interrupts(OSServiceId_Invalid);
320
321 /* リソース確保したままの場合,リソース解放 */
322 release_isrresources(p_isrcb);
323 /* カウンタの状æ…
324‹ã‚’初期化する */
325 cancel_isrcounters(p_isrcb);
326
327 exit_and_dispatch_isr();
328}
329
330
Note: See TracBrowser for help on using the repository browser.