source: atk2-sc3_fl850f1l/kernel/resource.c@ 165

Last change on this file since 165 was 117, checked in by ertl-ishikawa, 9 years ago

ATK2-SC3 1.3.2 FL850F1L(RH850F1L)依存部(GCC/GHS/CCRH)を追加

File size: 6.9 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 *
22 * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
23 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
24 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
25 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
26 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
27 * スコード中に含まれていること.
28 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
29 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
30 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
31 * の無保証規定を掲載すること.
32 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
33 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
34 * と.
35 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
36 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
37 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
38 * 報告すること.
39 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
40 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
41 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
42 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
43 * 免責すること.
44 *
45 * 本ソフトウェアは,AUTOSAR(AUTomotive Open System ARchitecture)仕
46 * 様に基づいている.上記の許諾は,AUTOSARの知的財産権を許諾するもので
47 * はない.AUTOSARは,AUTOSAR仕様に基づいたソフトウェアを商用目的で利
48 * 用する者に対して,AUTOSARパートナーになることを求めている.
49 *
50 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
51 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
52 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
53 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
54 * の責任を負わない.
55 *
56 * $Id: resource.c 187 2015-06-25 03:39:04Z t_ishikawa $
57 */
58
59/*
60 * リソース管理モジュール
61 */
62
63#include "kernel_impl.h"
64#include "check.h"
65#include "task.h"
66#include "interrupt.h"
67#include "resource.h"
68
69/*
70 * トレースログマクロのデフォルト定義
71 */
72#ifndef LOG_GETRES_ENTER
73#define LOG_GETRES_ENTER(resid)
74#endif /* LOG_GETRES_ENTER */
75
76#ifndef LOG_GETRES_LEAVE
77#define LOG_GETRES_LEAVE(ercd)
78#endif /* LOG_GETRES_LEAVE */
79
80#ifndef LOG_RELRES_ENTER
81#define LOG_RELRES_ENTER(resid)
82#endif /* LOG_RELRES_ENTER */
83
84#ifndef LOG_RELRES_LEAVE
85#define LOG_RELRES_LEAVE(ercd)
86#endif /* LOG_RELRES_LEAVE */
87
88/*
89 * リソース管理機能の初期化
90 */
91#ifdef TOPPERS_resource_initialize
92
93void
94resource_initialize(void)
95{
96 ResourceType i;
97 RESCB *p_rescb;
98
99 for (i = 0U; i < tnum_stdresource; i++) {
100 p_rescb = &(rescb_table[i]);
101 p_rescb->p_resinib = &(resinib_table[i]);
102 p_rescb->lockflg = FALSE;
103 }
104}
105
106#endif /* TOPPERS_resource_initialize */
107
108/*
109 * リソースの獲得
110 */
111#ifdef TOPPERS_GetResource
112
113StatusType
114GetResource(ResourceType ResID)
115{
116 StatusType ercd = E_OK;
117 PriorityType ceilpri, curpri;
118 RESCB *p_rescb;
119
120 LOG_GETRES_ENTER(ResID);
121 CHECK_DISABLEDINT();
122 CHECK_CALLEVEL(CALLEVEL_GETRESOURCE);
123 CHECK_ID(ResID < tnum_stdresource);
124 p_rescb = get_rescb(ResID);
125 CHECK_RIGHT(p_rescb->p_resinib->acsbtmp);
126
127 ceilpri = p_rescb->p_resinib->ceilpri;
128 if (callevel_stat == TCL_TASK) {
129 CHECK_ACCESS(p_runtsk->p_tinib->inipri >= ceilpri);
130
131 x_nested_lock_os_int();
132 D_CHECK_ACCESS(p_rescb->lockflg == FALSE);
133 curpri = p_runtsk->curpri;
134 p_rescb->prevpri = curpri;
135 p_rescb->lockflg = TRUE;
136 p_rescb->p_prevrescb = p_runtsk->p_lastrescb;
137 p_runtsk->p_lastrescb = p_rescb;
138 if (ceilpri < curpri) {
139 p_runtsk->curpri = ceilpri;
140 if (ceilpri <= TPRI_MINISR) {
141 x_set_ipm(ceilpri);
142 }
143 }
144 }
145 else {
146 CHECK_ACCESS(GET_INTPRI(p_runisr) >= ceilpri);
147
148 x_nested_lock_os_int();
149 D_CHECK_ACCESS(p_rescb->lockflg == FALSE);
150 curpri = x_get_ipm();
151 p_rescb->prevpri = curpri;
152 p_rescb->lockflg = TRUE;
153 p_rescb->p_prevrescb = p_runisr->p_lastrescb;
154 p_runisr->p_lastrescb = p_rescb;
155 if (ceilpri < curpri) {
156 x_set_ipm(ceilpri);
157 }
158 }
159
160 d_exit_no_errorhook:
161 x_nested_unlock_os_int();
162 exit_no_errorhook:
163 LOG_GETRES_LEAVE(ercd);
164 return(ercd);
165
166#ifdef CFG_USE_ERRORHOOK
167 exit_errorhook:
168 x_nested_lock_os_int();
169 d_exit_errorhook:
170#ifdef CFG_USE_PARAMETERACCESS
171 _errorhook_par1.resid = ResID;
172#endif /* CFG_USE_PARAMETERACCESS */
173 call_errorhook(ercd, OSServiceId_GetResource);
174 goto d_exit_no_errorhook;
175#endif /* CFG_USE_ERRORHOOK */
176}
177
178#endif /* TOPPERS_GetResource */
179
180/*
181 * リソースの返却
182 */
183#ifdef TOPPERS_ReleaseResource
184
185StatusType
186ReleaseResource(ResourceType ResID)
187{
188 StatusType ercd = E_OK;
189 RESCB *p_rescb;
190
191 LOG_RELRES_ENTER(ResID);
192 CHECK_DISABLEDINT();
193 CHECK_CALLEVEL(CALLEVEL_RELEASERESOURCE);
194 CHECK_ID(ResID < tnum_stdresource);
195 p_rescb = get_rescb(ResID);
196 CHECK_RIGHT(p_rescb->p_resinib->acsbtmp);
197
198 if (callevel_stat == TCL_TASK) {
199 CHECK_NOFUNC(p_runtsk->p_lastrescb == p_rescb);
200
201 x_nested_lock_os_int();
202 if (p_rescb->prevpri <= TPRI_MINISR) {
203 x_set_ipm(p_rescb->prevpri);
204 }
205 else {
206 if (p_runtsk->curpri <= TPRI_MINISR) {
207 x_set_ipm((PriorityType) TIPM_ENAALL);
208 }
209 }
210 p_runtsk->curpri = p_rescb->prevpri;
211 p_runtsk->p_lastrescb = p_rescb->p_prevrescb;
212 p_rescb->lockflg = FALSE;
213 if (p_runtsk->curpri > nextpri) {
214 preempt();
215 dispatch();
216 }
217 }
218 else {
219 CHECK_NOFUNC(p_runisr->p_lastrescb == p_rescb);
220
221 x_nested_lock_os_int();
222 x_set_ipm(p_rescb->prevpri);
223 p_runisr->p_lastrescb = p_rescb->p_prevrescb;
224 p_rescb->lockflg = FALSE;
225 }
226
227 d_exit_no_errorhook:
228 x_nested_unlock_os_int();
229 exit_no_errorhook:
230 LOG_RELRES_LEAVE(ercd);
231 return(ercd);
232
233#ifdef CFG_USE_ERRORHOOK
234 exit_errorhook:
235 x_nested_lock_os_int();
236#ifdef CFG_USE_PARAMETERACCESS
237 _errorhook_par1.resid = ResID;
238#endif /* CFG_USE_PARAMETERACCESS */
239 call_errorhook(ercd, OSServiceId_ReleaseResource);
240 goto d_exit_no_errorhook;
241#endif /* CFG_USE_ERRORHOOK */
242}
243
244#endif /* TOPPERS_ReleaseResource */
Note: See TracBrowser for help on using the repository browser.