source: atk2-sc3-1.4.0-ntisr/kernel/resource.c

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

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

  • Property svn:executable set to *
File size: 7.8 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: resource.c 425 2015-12-07 08:06:19Z witz-itoyo $
74 */
75
76/*
77 * リソース管理モジュール
78 */
79
80#include "kernel_impl.h"
81#include "check.h"
82#include "task.h"
83#include "interrupt.h"
84#include "resource.h"
85
86/*
87 * トレースログマクロのデフォルト定義
88 */
89#ifndef LOG_GETRES_ENTER
90#define LOG_GETRES_ENTER(resid)
91#endif /* LOG_GETRES_ENTER */
92
93#ifndef LOG_GETRES_LEAVE
94#define LOG_GETRES_LEAVE(ercd)
95#endif /* LOG_GETRES_LEAVE */
96
97#ifndef LOG_RELRES_ENTER
98#define LOG_RELRES_ENTER(resid)
99#endif /* LOG_RELRES_ENTER */
100
101#ifndef LOG_RELRES_LEAVE
102#define LOG_RELRES_LEAVE(ercd)
103#endif /* LOG_RELRES_LEAVE */
104
105/*
106 * リソース管理機能の初期化
107 */
108#ifdef TOPPERS_resource_initialize
109
110void
111resource_initialize(void)
112{
113 ResourceType i;
114 RESCB *p_rescb;
115
116 for (i = 0U; i < tnum_stdresource; i++) {
117 p_rescb = &(rescb_table[i]);
118 p_rescb->p_resinib = &(resinib_table[i]);
119 p_rescb->lockflg = FALSE;
120 }
121}
122
123#endif /* TOPPERS_resource_initialize */
124
125/*
126 * リソースの獲得
127 */
128#ifdef TOPPERS_GetResource
129
130StatusType
131GetResource(ResourceType ResID)
132{
133 StatusType ercd = E_OK;
134 PriorityType ceilpri, curpri;
135 RESCB *p_rescb;
136
137 LOG_GETRES_ENTER(ResID);
138 CHECK_DISABLEDINT();
139 CHECK_CALLEVEL(CALLEVEL_GETRESOURCE);
140 CHECK_ID(ResID < tnum_stdresource);
141 p_rescb = get_rescb(ResID);
142 CHECK_RIGHT(p_rescb->p_resinib->acsbtmp);
143
144 ceilpri = p_rescb->p_resinib->ceilpri;
145 if (callevel_stat == TCL_TASK) {
146 CHECK_ACCESS(p_runtsk->p_tinib->inipri >= ceilpri);
147
148 x_nested_lock_os_int();
149 D_CHECK_ACCESS(p_rescb->lockflg == FALSE);
150 curpri = p_runtsk->curpri;
151 p_rescb->prevpri = curpri;
152 p_rescb->lockflg = TRUE;
153 p_rescb->p_prevrescb = p_runtsk->p_lastrescb;
154 p_runtsk->p_lastrescb = p_rescb;
155 if (ceilpri < curpri) {
156 p_runtsk->curpri = ceilpri;
157 if (ceilpri <= TPRI_MINISR) {
158 x_set_ipm(ceilpri);
159 }
160 }
161 }
162 else {
163 CHECK_ACCESS(GET_INTPRI(p_runisr) >= ceilpri);
164
165 x_nested_lock_os_int();
166 D_CHECK_ACCESS(p_rescb->lockflg == FALSE);
167 curpri = x_get_ipm();
168 p_rescb->prevpri = curpri;
169 p_rescb->lockflg = TRUE;
170 p_rescb->p_prevrescb = p_runisr->p_lastrescb;
171 p_runisr->p_lastrescb = p_rescb;
172 if (ceilpri < curpri) {
173 x_set_ipm(ceilpri);
174 }
175 }
176
177 d_exit_no_errorhook:
178 x_nested_unlock_os_int();
179 exit_no_errorhook:
180 LOG_GETRES_LEAVE(ercd);
181 return(ercd);
182
183#ifdef CFG_USE_ERRORHOOK
184 exit_errorhook:
185 x_nested_lock_os_int();
186 d_exit_errorhook:
187#ifdef CFG_USE_PARAMETERACCESS
188 _errorhook_par1.resid = ResID;
189#endif /* CFG_USE_PARAMETERACCESS */
190 call_errorhook(ercd, OSServiceId_GetResource);
191 goto d_exit_no_errorhook;
192#endif /* CFG_USE_ERRORHOOK */
193}
194
195#endif /* TOPPERS_GetResource */
196
197/*
198 * リソースの返却
199 */
200#ifdef TOPPERS_ReleaseResource
201
202StatusType
203ReleaseResource(ResourceType ResID)
204{
205 StatusType ercd = E_OK;
206 RESCB *p_rescb;
207
208 LOG_RELRES_ENTER(ResID);
209 CHECK_DISABLEDINT();
210 CHECK_CALLEVEL(CALLEVEL_RELEASERESOURCE);
211 CHECK_ID(ResID < tnum_stdresource);
212 p_rescb = get_rescb(ResID);
213 CHECK_RIGHT(p_rescb->p_resinib->acsbtmp);
214
215 if (callevel_stat == TCL_TASK) {
216 CHECK_NOFUNC(p_runtsk->p_lastrescb == p_rescb);
217
218 x_nested_lock_os_int();
219 if (p_rescb->prevpri <= TPRI_MINISR) {
220 x_set_ipm(p_rescb->prevpri);
221 }
222 else {
223 if (p_runtsk->curpri <= TPRI_MINISR) {
224 x_set_ipm((PriorityType) TIPM_ENAALL);
225 }
226 }
227 p_runtsk->curpri = p_rescb->prevpri;
228 p_runtsk->p_lastrescb = p_rescb->p_prevrescb;
229 p_rescb->lockflg = FALSE;
230 if (p_runtsk->curpri > nextpri) {
231 preempt();
232 dispatch();
233 }
234 }
235 else {
236 CHECK_NOFUNC(p_runisr->p_lastrescb == p_rescb);
237
238 x_nested_lock_os_int();
239 x_set_ipm(p_rescb->prevpri);
240 p_runisr->p_lastrescb = p_rescb->p_prevrescb;
241 p_rescb->lockflg = FALSE;
242 }
243
244 d_exit_no_errorhook:
245 x_nested_unlock_os_int();
246 exit_no_errorhook:
247 LOG_RELRES_LEAVE(ercd);
248 return(ercd);
249
250#ifdef CFG_USE_ERRORHOOK
251 exit_errorhook:
252 x_nested_lock_os_int();
253#ifdef CFG_USE_PARAMETERACCESS
254 _errorhook_par1.resid = ResID;
255#endif /* CFG_USE_PARAMETERACCESS */
256 call_errorhook(ercd, OSServiceId_ReleaseResource);
257 goto d_exit_no_errorhook;
258#endif /* CFG_USE_ERRORHOOK */
259}
260
261#endif /* TOPPERS_ReleaseResource */
Note: See TracBrowser for help on using the repository browser.