source: asp_ewarm/asp-1.7.0/extension/ovrhdr/kernel/overrun.c@ 61

Last change on this file since 61 was 61, checked in by ertl-honda, 11 years ago

ASP for EWARM のコミット.

File size: 7.6 KB
Line 
1/*
2 * TOPPERS/ASP Kernel
3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Advanced Standard Profile Kernel
5 *
6 * Copyright (C) 2005-2010 by Embedded and Real-Time Systems Laboratory
7 * Graduate School of Information Science, Nagoya Univ., JAPAN
8 *
9 * ã‹L’˜ìŒ ŽÒ‚́CˆÈ‰º‚Ì(1)`(4)‚ÌðŒ‚ð–ž‚½‚·ê‡‚ÉŒÀ‚èC–{ƒ\ƒtƒgƒEƒF
10 * ƒAi–{ƒ\ƒtƒgƒEƒFƒA‚ð‰ü•Ï‚µ‚½‚à‚Ì‚ðŠÜ‚ށDˆÈ‰º“¯‚¶j‚ðŽg—pE•¡»E‰ü
11 * •ÏEÄ”z•ziˆÈ‰ºC—˜—p‚ƌĂԁj‚·‚邱‚Ƃ𖳏ž‚Å‹–‘ø‚·‚éD
12 * (1) –{ƒ\ƒtƒgƒEƒFƒA‚ðƒ\[ƒXƒR[ƒh‚ÌŒ`‚Å—˜—p‚·‚éê‡‚ɂ́Cã‹L‚Ì’˜ì
13 * Œ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L‚Ì–³•ÛØ‹K’肪C‚»‚Ì‚Ü‚Ü‚ÌŒ`‚Ń\[
14 * ƒXƒR[ƒh’†‚ÉŠÜ‚Ü‚ê‚Ä‚¢‚邱‚ƁD
15 * (2) –{ƒ\ƒtƒgƒEƒFƒA‚ðCƒ‰ƒCƒuƒ‰ƒŠŒ`Ž®‚ȂǁC‘¼‚̃\ƒtƒgƒEƒFƒAŠJ”­‚ÉŽg
16 * —p‚Å‚«‚éŒ`‚ōĔz•z‚·‚éê‡‚ɂ́CÄ”z•z‚É”º‚¤ƒhƒLƒ…
17ƒƒ“ƒgi—˜—p
18 * ŽÒƒ}ƒjƒ…
19ƒAƒ‹‚Ȃǁj‚ɁCã‹L‚Ì’˜ìŒ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L
20 * ‚Ì–³•ÛØ‹K’è‚ðŒfÚ‚·‚邱‚ƁD
21 * (3) –{ƒ\ƒtƒgƒEƒFƒA‚ðC‹@Ší‚É‘g‚ݍž‚ނȂǁC‘¼‚̃\ƒtƒgƒEƒFƒAŠJ”­‚ÉŽg
22 * —p‚Å‚«‚È‚¢Œ`‚ōĔz•z‚·‚éê‡‚ɂ́CŽŸ‚Ì‚¢‚¸‚ê‚©‚ÌðŒ‚ð–ž‚½‚·‚±
23 * ‚ƁD
24 * (a) Ä”z•z‚É”º‚¤ƒhƒLƒ…
25ƒƒ“ƒgi—˜—pŽÒƒ}ƒjƒ…
26ƒAƒ‹‚Ȃǁj‚ɁCã‹L‚Ì’˜
27 * ìŒ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L‚Ì–³•ÛØ‹K’è‚ðŒfÚ‚·‚邱‚ƁD
28 * (b) Ä”z•z‚ÌŒ`‘Ô‚ðC•Ê‚É’è‚ß‚é•û–@‚É‚æ‚Á‚āCTOPPERSƒvƒƒWƒFƒNƒg‚É
29 * •ñ‚·‚邱‚ƁD
30 * (4) –{ƒ\ƒtƒgƒEƒFƒA‚Ì—˜—p‚É‚æ‚è’¼Ú“I‚Ü‚½‚͊ԐړI‚ɐ¶‚¶‚é‚¢‚©‚Ȃ鑹
31 * ŠQ‚©‚ç‚àCã‹L’˜ìŒ ŽÒ‚¨‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚ð–Ɛӂ·‚邱‚ƁD
32 * ‚Ü‚½C–{ƒ\ƒtƒgƒEƒFƒA‚̃†[ƒU‚Ü‚½‚̓Gƒ“ƒhƒ†[ƒU‚©‚ç‚Ì‚¢‚©‚Ȃ闝
33 * —R‚ÉŠî‚­¿‹‚©‚ç‚àCã‹L’˜ìŒ ŽÒ‚¨‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚ð
34 * –Ɛӂ·‚邱‚ƁD
35 *
36 * –{ƒ\ƒtƒgƒEƒFƒA‚́C–³•ÛØ‚Å’ñ‹Ÿ‚³‚ê‚Ä‚¢‚é‚à‚Ì‚Å‚ ‚éDã‹L’˜ìŒ ŽÒ‚¨
37 * ‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚́C–{ƒ\ƒtƒgƒEƒFƒA‚ÉŠÖ‚µ‚āC“Á’è‚ÌŽg—p–Ú“I
38 * ‚ɑ΂·‚é“K‡«‚àŠÜ‚߂āC‚¢‚©‚È‚é•ÛØ‚às‚í‚È‚¢D‚Ü‚½C–{ƒ\ƒtƒgƒEƒF
39 * ƒA‚Ì—˜—p‚É‚æ‚è’¼Ú“I‚Ü‚½‚͊ԐړI‚ɐ¶‚¶‚½‚¢‚©‚Ȃ鑹ŠQ‚ÉŠÖ‚µ‚Ä‚àC‚»
40 * ‚̐ӔC‚𕉂í‚È‚¢D
41 *
42 * @(#) $Id: overrun.c 1902 2010-08-17 22:38:52Z ertl-hiro $
43 */
44
45/*
46 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰‹@”\
47 */
48
49#include "kernel_impl.h"
50#include "check.h"
51#include "task.h"
52#include "overrun.h"
53
54#ifdef TOPPERS_SUPPORT_OVRHDR
55#include "target_timer.h"
56
57/*
58 * ƒgƒŒ[ƒXƒƒOƒ}ƒNƒ‚̃fƒtƒHƒ‹ƒg’è‹`
59 */
60#ifndef LOG_OVR_ENTER
61#define LOG_OVR_ENTER(p_runtsk)
62#endif /* LOG_OVR_ENTER */
63
64#ifndef LOG_OVR_LEAVE
65#define LOG_OVR_LEAVE(p_runtsk)
66#endif /* LOG_OVR_LEAVE */
67
68#ifndef LOG_STA_OVR_ENTER
69#define LOG_STA_OVR_ENTER(tskid, ovrtim)
70#endif /* LOG_STA_OVR_ENTER */
71
72#ifndef LOG_STA_OVR_LEAVE
73#define LOG_STA_OVR_LEAVE(ercd)
74#endif /* LOG_STA_OVR_LEAVE */
75
76#ifndef LOG_ISTA_OVR_ENTER
77#define LOG_ISTA_OVR_ENTER(tskid, ovrtim)
78#endif /* LOG_ISTA_OVR_ENTER */
79
80#ifndef LOG_ISTA_OVR_LEAVE
81#define LOG_ISTA_OVR_LEAVE(ercd)
82#endif /* LOG_ISTA_OVR_LEAVE */
83
84#ifndef LOG_ISTP_OVR_ENTER
85#define LOG_ISTP_OVR_ENTER(tskid)
86#endif /* LOG_ISTP_OVR_ENTER */
87
88#ifndef LOG_ISTP_OVR_LEAVE
89#define LOG_ISTP_OVR_LEAVE(ercd)
90#endif /* LOG_ISTP_OVR_LEAVE */
91
92#ifndef LOG_STP_OVR_ENTER
93#define LOG_STP_OVR_ENTER(tskid)
94#endif /* LOG_STP_OVR_ENTER */
95
96#ifndef LOG_STP_OVR_LEAVE
97#define LOG_STP_OVR_LEAVE(ercd)
98#endif /* LOG_STP_OVR_LEAVE */
99
100#ifndef LOG_REF_OVR_ENTER
101#define LOG_REF_OVR_ENTER(tskid, pk_rovr)
102#endif /* LOG_REF_OVR_ENTER */
103
104#ifndef LOG_REF_OVR_LEAVE
105#define LOG_REF_OVR_LEAVE(ercd, pk_rovr)
106#endif /* LOG_REF_OVR_LEAVE */
107
108#ifdef TOPPERS_ovrini
109
110/*
111 * ƒI[ƒoƒ‰ƒ“ƒ^ƒCƒ}‚ª“®ì’†‚©‚ðŽ¦‚·ƒtƒ‰ƒO
112 */
113bool_t ovrtimer_flag;
114
115/*
116 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰‹@”\‚̏‰Šú‰»
117 */
118void
119initialize_overrun(void)
120{
121 ovrtimer_flag = false;
122}
123
124#endif /* TOPPERS_ovrini */
125
126/*
127 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰—pƒ^ƒCƒ}‚Ì“®ìŠJŽn
128 */
129#ifdef TOPPERS_ovrsta
130#ifndef OMIT_OVRTIMER_START
131
132void
133ovrtimer_start(void)
134{
135 if (p_runtsk->leftotm > 0U) {
136 target_ovrtimer_start(p_runtsk->leftotm);
137 ovrtimer_flag = true;
138 }
139}
140
141#endif /* OMIT_OVRTIMER_START */
142#endif /* TOPPERS_ovrsta */
143
144/*
145 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰—pƒ^ƒCƒ}‚Ì’âŽ~
146 */
147#ifdef TOPPERS_ovrstp
148#ifndef OMIT_OVRTIMER_STOP
149
150void
151ovrtimer_stop(void)
152{
153 if (ovrtimer_flag) {
154 assert(p_runtsk->leftotm > 0U);
155 p_runtsk->leftotm = target_ovrtimer_stop();
156 ovrtimer_flag = false;
157 }
158}
159
160#endif /* OMIT_OVRTIMER_STOP */
161#endif /* TOPPERS_ovrstp */
162
163/*
164 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰‚Ì“®ìŠJŽn
165 */
166#ifdef TOPPERS_sta_ovr
167
168ER
169sta_ovr(ID tskid, OVRTIM ovrtim)
170{
171 TCB *p_tcb;
172 ER ercd;
173
174 LOG_STA_OVR_ENTER(tskid, ovrtim);
175 CHECK_TSKCTX_UNL();
176 CHECK_OBJ(ovrinib.ovrhdr != NULL);
177 CHECK_TSKID_SELF(tskid);
178 CHECK_PAR(0U < ovrtim && ovrtim <= TMAX_OVRTIM);
179 p_tcb = get_tcb_self(tskid);
180
181 t_lock_cpu();
182 if (p_tcb == p_runtsk) {
183 if (p_tcb->leftotm > 0U) {
184 (void) target_ovrtimer_stop();
185 }
186 target_ovrtimer_start(ovrtim);
187 ovrtimer_flag = true;
188 }
189 p_tcb->leftotm = ovrtim;
190 ercd = E_OK;
191 t_unlock_cpu();
192
193 error_exit:
194 LOG_STA_OVR_LEAVE(ercd);
195 return(ercd);
196}
197
198#endif /* TOPPERS_sta_ovr */
199
200/*
201 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰‚Ì“®ìŠJŽni”ñƒ^ƒXƒNƒRƒ“ƒeƒLƒXƒg—pj
202 */
203#ifdef TOPPERS_ista_ovr
204
205ER
206ista_ovr(ID tskid, OVRTIM ovrtim)
207{
208 TCB *p_tcb;
209 ER ercd;
210
211 LOG_ISTA_OVR_ENTER(tskid, ovrtim);
212 CHECK_INTCTX_UNL();
213 CHECK_OBJ(ovrinib.ovrhdr != NULL);
214 CHECK_TSKID(tskid);
215 CHECK_PAR(0U < ovrtim && ovrtim <= TMAX_OVRTIM);
216 p_tcb = get_tcb(tskid);
217
218 i_lock_cpu();
219 p_tcb->leftotm = ovrtim;
220 ercd = E_OK;
221 i_unlock_cpu();
222
223 error_exit:
224 LOG_ISTA_OVR_LEAVE(ercd);
225 return(ercd);
226}
227
228#endif /* TOPPERS_ista_ovr */
229
230/*
231 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰‚Ì“®ì’âŽ~
232 */
233#ifdef TOPPERS_stp_ovr
234
235ER
236stp_ovr(ID tskid)
237{
238 TCB *p_tcb;
239 ER ercd;
240
241 LOG_STP_OVR_ENTER(tskid);
242 CHECK_TSKCTX_UNL();
243 CHECK_OBJ(ovrinib.ovrhdr != NULL);
244 CHECK_TSKID_SELF(tskid);
245 p_tcb = get_tcb_self(tskid);
246
247 t_lock_cpu();
248 if (p_tcb->leftotm > 0U) {
249 if (p_tcb == p_runtsk) {
250 (void) target_ovrtimer_stop();
251 ovrtimer_flag = false;
252 }
253 p_tcb->leftotm = 0U;
254 }
255 ercd = E_OK;
256 t_unlock_cpu();
257
258 error_exit:
259 LOG_STP_OVR_LEAVE(ercd);
260 return(ercd);
261}
262
263#endif /* TOPPERS_stp_ovr */
264
265/*
266 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰‚Ì“®ì’âŽ~i”ñƒ^ƒXƒNƒRƒ“ƒeƒLƒXƒg—pj
267 */
268#ifdef TOPPERS_istp_ovr
269
270ER
271istp_ovr(ID tskid)
272{
273 TCB *p_tcb;
274 ER ercd;
275
276 LOG_ISTP_OVR_ENTER(tskid);
277 CHECK_INTCTX_UNL();
278 CHECK_OBJ(ovrinib.ovrhdr != NULL);
279 CHECK_TSKID(tskid);
280 p_tcb = get_tcb(tskid);
281
282 i_lock_cpu();
283 p_tcb->leftotm = 0U;
284 ercd = E_OK;
285 i_unlock_cpu();
286
287 error_exit:
288 LOG_ISTP_OVR_LEAVE(ercd);
289 return(ercd);
290}
291
292#endif /* TOPPERS_istp_ovr */
293
294/*
295 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰‚̏ó‘ÔŽQÆ
296 */
297#ifdef TOPPERS_ref_ovr
298
299ER
300ref_ovr(ID tskid, T_ROVR *pk_rovr)
301{
302 TCB *p_tcb;
303 ER ercd;
304
305 LOG_REF_OVR_ENTER(tskid, pk_rovr);
306 CHECK_TSKCTX_UNL();
307 CHECK_OBJ(ovrinib.ovrhdr != NULL);
308 CHECK_TSKID_SELF(tskid);
309 p_tcb = get_tcb_self(tskid);
310
311 t_lock_cpu();
312 if (p_tcb->leftotm > 0U) {
313 pk_rovr->ovrstat = TOVR_STA;
314 if (p_tcb == p_runtsk) {
315 pk_rovr->leftotm = target_ovrtimer_get_current();
316 }
317 else {
318 pk_rovr->leftotm = p_tcb->leftotm;
319 }
320 }
321 else {
322 pk_rovr->ovrstat = TOVR_STP;
323 }
324 ercd = E_OK;
325 t_unlock_cpu();
326
327 error_exit:
328 LOG_REF_OVR_LEAVE(ercd, pk_rovr);
329 return(ercd);
330}
331
332#endif /* TOPPERS_ref_ovr */
333
334/*
335 * ƒI[ƒoƒ‰ƒ“ƒnƒ“ƒhƒ‰‹N“®ƒ‹[ƒ`ƒ“
336 */
337#ifdef TOPPERS_ovrcal
338
339void
340call_ovrhdr(void)
341{
342 PRI saved_ipm;
343
344 assert(sense_context());
345 assert(!i_sense_lock());
346 assert(ovrinib.ovrhdr != NULL);
347
348 p_runtsk->leftotm = 0U;
349 saved_ipm = i_get_ipm();
350
351 LOG_OVR_ENTER(p_runtsk);
352 (*((OVRHDR)(ovrinib.ovrhdr)))(TSKID(p_runtsk), p_runtsk->p_tinib->exinf);
353 LOG_OVR_LEAVE(p_runtsk);
354
355 if (i_sense_lock()) {
356 i_unlock_cpu();
357 }
358 i_set_ipm(saved_ipm);
359}
360
361#endif /* TOPPERS_ovrcal */
362#endif /* TOPPERS_SUPPORT_OVRHDR */
Note: See TracBrowser for help on using the repository browser.