source: atk2-sc3-1.4.0-ntisr/kernel/osctl_manage.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: 10.5 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: osctl_manage.c 464 2015-12-10 11:16:08Z witz-itoyo $
74 */
75
76/*
77 * OS管理モジュール
78 */
79
80#include "kernel_impl.h"
81#include "check.h"
82#include "interrupt.h"
83
84/*
85 * トレースログマクロのデフォルト定義
86 */
87#ifndef LOG_GETAAM_ENTER
88#define LOG_GETAAM_ENTER()
89#endif /* LOG_GETAAM_ENTER */
90
91#ifndef LOG_GETAAM_LEAVE
92#define LOG_GETAAM_LEAVE(mode)
93#endif /* LOG_GETAAM_LEAVE */
94
95#ifndef LOG_STAOS_ENTER
96#define LOG_STAOS_ENTER(mode)
97#endif /* LOG_STAOS_ENTER */
98
99#ifndef LOG_STAOS_LEAVE
100#define LOG_STAOS_LEAVE()
101#endif /* LOG_STAOS_LEAVE */
102
103#ifndef LOG_STAHOOK_ENTER
104#define LOG_STAHOOK_ENTER()
105#endif /* LOG_STAHOOK_ENTER */
106
107#ifndef LOG_STAHOOK_LEAVE
108#define LOG_STAHOOK_LEAVE()
109#endif /* LOG_STAHOOK_LEAVE */
110
111#ifdef TOPPERS_StartOS
112
113/*
114 * OS実行制御のための変数
115 */
116uint16 callevel_stat = 0U; /* 実行中のコンテキスト */
117AppModeType appmodeid; /* アプリケーションモードID */
118
119/*
120 * カーネル動作状æ…
121‹ãƒ•ãƒ©ã‚°
122 */
123boolean kerflg = FALSE;
124
125/*
126 * 特権モードで動作中かを示すフラグ
127 */
128boolean run_trusted;
129
130boolean pre_protection_supervised;
131
132#ifdef NTC2ISR
133StatusType saved_ostkpt;
134#endif /* NTC2ISR */
135
136/*
137 * ファイル名,行番号の参ç…
138§ç”¨ã®å¤‰æ•°
139 */
140const char8 *fatal_file_name = NULL; /* ファイル名 */
141sint32 fatal_line_num = 0; /* 行番号 */
142
143/*
144 * OSの起動
145 */
146
147void
148StartOS(AppModeType Mode)
149{
150
151 LOG_STAOS_ENTER(Mode);
152 if (kerflg != FALSE) {
153 /* OS起動中はエラーフックを呼ぶ */
154#ifdef CFG_USE_ERRORHOOK
155 x_nested_lock_os_int();
156#ifdef CFG_USE_PARAMETERACCESS
157 _errorhook_par1.mode = Mode;
158#endif /* CFG_USE_PARAMETERACCESS */
159 call_errorhook(E_OS_ACCESS, OSServiceId_StartOS);
160 x_nested_unlock_os_int();
161#endif /* CFG_USE_ERRORHOOK */
162 }
163 else {
164
165 /* å…
166¨å‰²è¾¼ã¿ç¦æ­¢çŠ¶æ…
167‹ã«ç§»è¡Œ */
168 x_lock_all_int();
169
170#ifdef CFG_USE_STACKMONITORING
171 /*
172 * スタックモニタリング機能の初期化
173 * スタックモニタリング機能のためのマジックナンバー領域の初期化
174 */
175 init_stack_magic_region();
176#endif /* CFG_USE_STACKMONITORING */
177
178 /* アプリケーションモードの設定 */
179 appmodeid = Mode;
180
181 /* ターゲット依存の初期化 */
182 target_initialize();
183
184 /* 各モジュールの初期化 */
185 object_initialize();
186
187 callevel_stat = TCL_NULL;
188
189 /* カーネル動作中 */
190 kerflg = TRUE;
191
192 run_trusted = TRUE;
193
194 /*
195 * Modeが不正であった場合,OSシャットダウンを行う
196 * この時,スタートアップフックは呼び出されない
197 */
198 if (Mode >= tnum_appmode) {
199 /*
200 * internal_shutdownosを呼ぶ前にOS割込み禁止状æ…
201‹ã¸
202 * å…
203¨å‰²è¾¼ã¿ç¦æ­¢çŠ¶æ…
204‹è§£é™¤
205 */
206 x_nested_lock_os_int();
207 x_unlock_all_int();
208 internal_shutdownos(E_OS_MODE);
209 }
210
211#ifdef CFG_USE_STARTUPHOOK
212 /* OS割込み禁止状æ…
213‹ã«ã—,å…
214¨å‰²è¾¼ã¿ç¦æ­¢çŠ¶æ…
215‹è§£é™¤ */
216 x_nested_lock_os_int();
217 x_unlock_all_int();
218
219 /*
220 * StartupHook の呼び出し
221 */
222 ENTER_CALLEVEL(TCL_STARTUP);
223 LOG_STAHOOK_ENTER();
224 StartupHook();
225 LOG_STAHOOK_LEAVE();
226 LEAVE_CALLEVEL(TCL_STARTUP);
227
228 /* å…
229ƒã®å‰²è¾¼ã¿ãƒžã‚¹ã‚¯å„ªå…
230ˆåº¦ã¨å…
231¨å‰²è¾¼ã¿ç¦æ­¢çŠ¶æ…
232‹ã« */
233 x_lock_all_int();
234 x_nested_unlock_os_int();
235#endif /* CFG_USE_STARTUPHOOK */
236
237
238 ENTER_CALLEVEL(TCL_TASK);
239 LOG_STAOS_LEAVE();
240 start_dispatch();
241 ASSERT_NO_REACHED;
242 }
243}
244
245#endif /* TOPPERS_StartOS */
246
247/*
248 * 現在のアプリケーションモードの取得
249 */
250#ifdef TOPPERS_GetActiveApplicationMode
251
252AppModeType
253GetActiveApplicationMode(void)
254{
255 AppModeType appmode;
256 StatusType ercd;
257
258 LOG_GETAAM_ENTER();
259 CHECK_DISABLEDINT();
260 CHECK_CALLEVEL(CALLEVEL_GETACTIVEAPPMODE);
261
262 appmode = appmodeid;
263
264 exit_finish:
265 LOG_GETAAM_LEAVE(appmode);
266 return(appmode);
267
268#ifdef CFG_USE_ERRORHOOK
269 exit_errorhook:
270 x_nested_lock_os_int();
271 /*
272 * エラー発生時はINVALID_APPMODETYPEが返るが,エラーが発生したのか実行中の
273 * C2ISRが存在しないのか区別するため,エラーフックを呼ぶ
274 */
275 call_errorhook(ercd, OSServiceId_GetActiveApplicationMode);
276 x_nested_unlock_os_int();
277#endif /* CFG_USE_ERRORHOOK */
278
279 exit_no_errorhook:
280 appmode = INVALID_APPMODETYPE;
281 goto exit_finish;
282}
283
284#endif /* TOPPERS_GetActiveApplicationMode */
285
286/*
287 * OSの終了
288 */
289#ifdef TOPPERS_ShutdownOS
290
291void
292ShutdownOS(StatusType Error)
293{
294 StatusType ercd = Error;
295
296 /*
297 * 呼出しå…
298ƒæ‰€å±ž OSアプリケーションの信頼/非信頼のチェック
299 * 呼出しå…
300ƒãŒä¿¡é ¼é–¢æ•°ï¼Œãƒ•ãƒƒã‚¯ã§ã‚る場合は
301 * ShutdownOS() を実行する
302 */
303 if (run_trusted == FALSE) {
304 /* 非信頼から呼ばれた場合はエラーフックを呼ぶ */
305#ifdef CFG_USE_ERRORHOOK
306 x_nested_lock_os_int();
307#ifdef CFG_USE_PARAMETERACCESS
308 _errorhook_par1.error = Error;
309#endif /* CFG_USE_PARAMETERACCESS */
310 call_errorhook(E_OS_ACCESS, OSServiceId_ShutdownOS);
311 x_nested_unlock_os_int();
312#endif /* CFG_USE_ERRORHOOK */
313 }
314 else {
315
316 /*
317 * 不正な処理単位から呼び出した場合も,ErrorをE_OS_SHUTDOWN_FATALとして
318 * ShutdownOSを呼び出したものとして,シャットダウン処理を行う
319 */
320 if (((callevel_stat & TCLMASK) | (CALLEVEL_SHUTDOWNOS)) != (CALLEVEL_SHUTDOWNOS)) {
321 ercd = E_OS_SHUTDOWN_FATAL;
322 }
323
324 /*
325 * OSで定義されていないエラーコードが指定された場合,ErrorをE_OS_SHUTDOWN_FATALとして
326 * ShutdownOSを呼び出したものとして,シャットダウン処理を行う
327 */
328 if (ercd > ERRCODE_NUM) {
329 ercd = E_OS_SHUTDOWN_FATAL;
330 }
331
332 internal_shutdownos(ercd);
333 }
334}
335#endif /* TOPPERS_ShutdownOS */
336
337/*
338 * 保護違反を起こした処理単位の取得
339 */
340#ifdef TOPPERS_GetFaultyContext
341
342FaultyContextType
343GetFaultyContext(void)
344{
345 FaultyContextType faultycontext = FC_INVALID;
346
347#ifdef CFG_USE_PROTECTIONHOOK
348 if ((callevel_stat & CALLEVEL_GETFAULTYCONTEXT) != 0U) {
349
350 /* C1ISR以外で発生 */
351 if ((callevel_stat & TSYS_ISR1) == 0U) {
352 if ((callevel_stat & (TCL_ERROR | TCL_PREPOST | TCL_STARTUP | TCL_SHUTDOWN)) != 0U) {
353 /* フック中に発生 */
354 faultycontext = FC_SYSTEM_HOOK;
355 }
356 else if ((callevel_stat & TCL_ISR2) != 0U) {
357 if (p_runisr->calltfn != FALSE) {
358 /* C2ISRから呼出した信頼関数中に発生 */
359 faultycontext = FC_TRUSTED_FUNC;
360 }
361 else {
362 faultycontext = FC_C2ISR;
363 }
364 }
365 else if ((callevel_stat & TCL_TASK) != 0U) {
366 if (p_runtsk->calltfn != FALSE) {
367 /* タスクから呼出した信頼関数中に発生 */
368 faultycontext = FC_TRUSTED_FUNC;
369 }
370 else {
371 faultycontext = FC_TASK;
372 }
373 }
374 else {
375 /* 上記以外の場合,処理は行わない(戻り値:FC_INVALID) */
376 }
377 }
378 }
379#endif /* CFG_USE_PROTECTIONHOOK */
380
381 return(faultycontext);
382}
383#endif /* TOPPERS_GetFaultyContext */
Note: See TracBrowser for help on using the repository browser.