source: asp_ewarm/asp-1.7.0/kernel/cyclic.c@ 61

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

ASP for EWARM のコミット.

File size: 6.3 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) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2005-2008 by Embedded and Real-Time Systems Laboratory
9 * Graduate School of Information Science, Nagoya Univ., JAPAN
10 *
11 * ã‹L’˜ìŒ ŽÒ‚́CˆÈ‰º‚Ì(1)`(4)‚ÌðŒ‚ð–ž‚½‚·ê‡‚ÉŒÀ‚èC–{ƒ\ƒtƒgƒEƒF
12 * ƒAi–{ƒ\ƒtƒgƒEƒFƒA‚ð‰ü•Ï‚µ‚½‚à‚Ì‚ðŠÜ‚ށDˆÈ‰º“¯‚¶j‚ðŽg—pE•¡»E‰ü
13 * •ÏEÄ”z•ziˆÈ‰ºC—˜—p‚ƌĂԁj‚·‚邱‚Ƃ𖳏ž‚Å‹–‘ø‚·‚éD
14 * (1) –{ƒ\ƒtƒgƒEƒFƒA‚ðƒ\[ƒXƒR[ƒh‚ÌŒ`‚Å—˜—p‚·‚éê‡‚ɂ́Cã‹L‚Ì’˜ì
15 * Œ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L‚Ì–³•ÛØ‹K’肪C‚»‚Ì‚Ü‚Ü‚ÌŒ`‚Ń\[
16 * ƒXƒR[ƒh’†‚ÉŠÜ‚Ü‚ê‚Ä‚¢‚邱‚ƁD
17 * (2) –{ƒ\ƒtƒgƒEƒFƒA‚ðCƒ‰ƒCƒuƒ‰ƒŠŒ`Ž®‚ȂǁC‘¼‚̃\ƒtƒgƒEƒFƒAŠJ”­‚ÉŽg
18 * —p‚Å‚«‚éŒ`‚ōĔz•z‚·‚éê‡‚ɂ́CÄ”z•z‚É”º‚¤ƒhƒLƒ…
19ƒƒ“ƒgi—˜—p
20 * ŽÒƒ}ƒjƒ…
21ƒAƒ‹‚Ȃǁj‚ɁCã‹L‚Ì’˜ìŒ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L
22 * ‚Ì–³•ÛØ‹K’è‚ðŒfÚ‚·‚邱‚ƁD
23 * (3) –{ƒ\ƒtƒgƒEƒFƒA‚ðC‹@Ší‚É‘g‚ݍž‚ނȂǁC‘¼‚̃\ƒtƒgƒEƒFƒAŠJ”­‚ÉŽg
24 * —p‚Å‚«‚È‚¢Œ`‚ōĔz•z‚·‚éê‡‚ɂ́CŽŸ‚Ì‚¢‚¸‚ê‚©‚ÌðŒ‚ð–ž‚½‚·‚±
25 * ‚ƁD
26 * (a) Ä”z•z‚É”º‚¤ƒhƒLƒ…
27ƒƒ“ƒgi—˜—pŽÒƒ}ƒjƒ…
28ƒAƒ‹‚Ȃǁj‚ɁCã‹L‚Ì’˜
29 * ìŒ •\Ž¦C‚±‚Ì—˜—pðŒ‚¨‚æ‚щº‹L‚Ì–³•ÛØ‹K’è‚ðŒfÚ‚·‚邱‚ƁD
30 * (b) Ä”z•z‚ÌŒ`‘Ô‚ðC•Ê‚É’è‚ß‚é•û–@‚É‚æ‚Á‚āCTOPPERSƒvƒƒWƒFƒNƒg‚É
31 * •ñ‚·‚邱‚ƁD
32 * (4) –{ƒ\ƒtƒgƒEƒFƒA‚Ì—˜—p‚É‚æ‚è’¼Ú“I‚Ü‚½‚͊ԐړI‚ɐ¶‚¶‚é‚¢‚©‚Ȃ鑹
33 * ŠQ‚©‚ç‚àCã‹L’˜ìŒ ŽÒ‚¨‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚ð–Ɛӂ·‚邱‚ƁD
34 * ‚Ü‚½C–{ƒ\ƒtƒgƒEƒFƒA‚̃†[ƒU‚Ü‚½‚̓Gƒ“ƒhƒ†[ƒU‚©‚ç‚Ì‚¢‚©‚Ȃ闝
35 * —R‚ÉŠî‚­¿‹‚©‚ç‚àCã‹L’˜ìŒ ŽÒ‚¨‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚ð
36 * –Ɛӂ·‚邱‚ƁD
37 *
38 * –{ƒ\ƒtƒgƒEƒFƒA‚́C–³•ÛØ‚Å’ñ‹Ÿ‚³‚ê‚Ä‚¢‚é‚à‚Ì‚Å‚ ‚éDã‹L’˜ìŒ ŽÒ‚¨
39 * ‚æ‚ÑTOPPERSƒvƒƒWƒFƒNƒg‚́C–{ƒ\ƒtƒgƒEƒFƒA‚ÉŠÖ‚µ‚āC“Á’è‚ÌŽg—p–Ú“I
40 * ‚ɑ΂·‚é“K‡«‚àŠÜ‚߂āC‚¢‚©‚È‚é•ÛØ‚às‚í‚È‚¢D‚Ü‚½C–{ƒ\ƒtƒgƒEƒF
41 * ƒA‚Ì—˜—p‚É‚æ‚è’¼Ú“I‚Ü‚½‚͊ԐړI‚ɐ¶‚¶‚½‚¢‚©‚Ȃ鑹ŠQ‚ÉŠÖ‚µ‚Ä‚àC‚»
42 * ‚̐ӔC‚𕉂í‚È‚¢D
43 *
44 * @(#) $Id: cyclic.c 1358 2008-09-21 09:16:57Z ertl-hiro $
45 */
46
47/*
48 * ŽüŠúƒnƒ“ƒhƒ‰‹@”\
49 */
50
51#include "kernel_impl.h"
52#include "check.h"
53#include "cyclic.h"
54
55/*
56 * ƒgƒŒ[ƒXƒƒOƒ}ƒNƒ‚̃fƒtƒHƒ‹ƒg’è‹`
57 */
58#ifndef LOG_CYC_ENTER
59#define LOG_CYC_ENTER(p_cyccb)
60#endif /* LOG_CYC_ENTER */
61
62#ifndef LOG_CYC_LEAVE
63#define LOG_CYC_LEAVE(p_cyccb)
64#endif /* LOG_CYC_LEAVE */
65
66#ifndef LOG_STA_CYC_ENTER
67#define LOG_STA_CYC_ENTER(cycid)
68#endif /* LOG_STA_CYC_ENTER */
69
70#ifndef LOG_STA_CYC_LEAVE
71#define LOG_STA_CYC_LEAVE(ercd)
72#endif /* LOG_STA_CYC_LEAVE */
73
74#ifndef LOG_STP_CYC_ENTER
75#define LOG_STP_CYC_ENTER(cycid)
76#endif /* LOG_STP_CYC_ENTER */
77
78#ifndef LOG_STP_CYC_LEAVE
79#define LOG_STP_CYC_LEAVE(ercd)
80#endif /* LOG_STP_CYC_LEAVE */
81
82#ifndef LOG_REF_CYC_ENTER
83#define LOG_REF_CYC_ENTER(cycid, pk_rcyc)
84#endif /* LOG_REF_CYC_ENTER */
85
86#ifndef LOG_REF_CYC_LEAVE
87#define LOG_REF_CYC_LEAVE(ercd, pk_rcyc)
88#endif /* LOG_REF_CYC_LEAVE */
89
90/*
91 * ŽüŠúƒnƒ“ƒhƒ‰‚̐”
92 */
93#define tnum_cyc ((uint_t)(tmax_cycid - TMIN_CYCID + 1))
94
95/*
96 * ŽüŠúƒnƒ“ƒhƒ‰ID‚©‚çŽüŠúƒnƒ“ƒhƒ‰ŠÇ—ƒuƒƒbƒN‚ðŽæ‚èo‚·‚½‚߂̃}ƒNƒ
97 */
98#define INDEX_CYC(cycid) ((uint_t)((cycid) - TMIN_CYCID))
99#define get_cyccb(cycid) (&(cyccb_table[INDEX_CYC(cycid)]))
100
101/*
102 * ŽüŠúƒnƒ“ƒhƒ‰‹N“®‚Ì‚½‚߂̃^ƒCƒ€ƒCƒxƒ“ƒgƒuƒƒbƒN‚Ì“o˜^
103 */
104Inline void
105tmevtb_enqueue_cyc(CYCCB *p_cyccb, EVTTIM evttim)
106{
107 tmevtb_enqueue_evttim(&(p_cyccb->tmevtb), evttim,
108 (CBACK) call_cychdr, (void *) p_cyccb);
109 p_cyccb->evttim = evttim;
110}
111
112/*
113 * ŽüŠúƒnƒ“ƒhƒ‰‹@”\‚̏‰Šú‰»
114 */
115#ifdef TOPPERS_cycini
116
117void
118initialize_cyclic(void)
119{
120 uint_t i;
121 CYCCB *p_cyccb;
122
123 for (p_cyccb = cyccb_table, i = 0; i < tnum_cyc; p_cyccb++, i++) {
124 p_cyccb->p_cycinib = &(cycinib_table[i]);
125 if ((p_cyccb->p_cycinib->cycatr & TA_STA) != 0U) {
126 p_cyccb->cycsta = true;
127 tmevtb_enqueue_cyc(p_cyccb, (EVTTIM)(p_cyccb->p_cycinib->cycphs));
128 }
129 else {
130 p_cyccb->cycsta = false;
131 }
132 }
133}
134
135#endif /* TOPPERS_cycini */
136
137/*
138 * ŽüŠúƒnƒ“ƒhƒ‰‚Ì“®ìŠJŽn
139 */
140#ifdef TOPPERS_sta_cyc
141
142ER
143sta_cyc(ID cycid)
144{
145 CYCCB *p_cyccb;
146 ER ercd;
147
148 LOG_STA_CYC_ENTER(cycid);
149 CHECK_TSKCTX_UNL();
150 CHECK_CYCID(cycid);
151 p_cyccb = get_cyccb(cycid);
152
153 t_lock_cpu();
154 if (p_cyccb->cycsta) {
155 tmevtb_dequeue(&(p_cyccb->tmevtb));
156 }
157 else {
158 p_cyccb->cycsta = true;
159 }
160 tmevtb_enqueue_cyc(p_cyccb, base_time + p_cyccb->p_cycinib->cycphs);
161 ercd = E_OK;
162 t_unlock_cpu();
163
164 error_exit:
165 LOG_STA_CYC_LEAVE(ercd);
166 return(ercd);
167}
168
169#endif /* TOPPERS_sta_cyc */
170
171/*
172 * ŽüŠúƒnƒ“ƒhƒ‰‚Ì“®ì’âŽ~
173 */
174#ifdef TOPPERS_stp_cyc
175
176ER
177stp_cyc(ID cycid)
178{
179 CYCCB *p_cyccb;
180 ER ercd;
181
182 LOG_STP_CYC_ENTER(cycid);
183 CHECK_TSKCTX_UNL();
184 CHECK_CYCID(cycid);
185 p_cyccb = get_cyccb(cycid);
186
187 t_lock_cpu();
188 if (p_cyccb->cycsta) {
189 p_cyccb->cycsta = false;
190 tmevtb_dequeue(&(p_cyccb->tmevtb));
191 }
192 ercd = E_OK;
193 t_unlock_cpu();
194
195 error_exit:
196 LOG_STP_CYC_LEAVE(ercd);
197 return(ercd);
198}
199
200#endif /* TOPPERS_stp_cyc */
201
202/*
203 * ŽüŠúƒnƒ“ƒhƒ‰‚̏ó‘ÔŽQÆ
204 */
205#ifdef TOPPERS_ref_cyc
206
207ER
208ref_cyc(ID cycid, T_RCYC *pk_rcyc)
209{
210 CYCCB *p_cyccb;
211 ER ercd;
212
213 LOG_REF_CYC_ENTER(cycid, pk_rcyc);
214 CHECK_TSKCTX_UNL();
215 CHECK_CYCID(cycid);
216 p_cyccb = get_cyccb(cycid);
217
218 t_lock_cpu();
219 if (p_cyccb->cycsta) {
220 pk_rcyc->cycstat = TCYC_STA;
221 pk_rcyc->lefttim = tmevt_lefttim(&(p_cyccb->tmevtb));
222 }
223 else {
224 pk_rcyc->cycstat = TCYC_STP;
225 }
226 ercd = E_OK;
227 t_unlock_cpu();
228
229 error_exit:
230 LOG_REF_CYC_LEAVE(ercd, pk_rcyc);
231 return(ercd);
232}
233
234#endif /* TOPPERS_ref_cyc */
235
236/*
237 * ŽüŠúƒnƒ“ƒhƒ‰‹N“®ƒ‹[ƒ`ƒ“
238 */
239#ifdef TOPPERS_cyccal
240
241void
242call_cychdr(CYCCB *p_cyccb)
243{
244 PRI saved_ipm;
245
246 /*
247 * ŽŸ‰ñ‚Ì‹N“®‚Ì‚½‚߂̃^ƒCƒ€ƒCƒxƒ“ƒgƒuƒƒbƒN‚ð“o˜^‚·‚éD
248 *
249 * “¯‚¶ƒ^ƒCƒ€ƒeƒBƒbƒN‚ÅŽüŠúƒnƒ“ƒhƒ‰‚ðÄ“x‹N“®‚·‚ׂ«ê‡‚ɂ́C‚±‚Ì
250 * ŠÖ”‚©‚çsignal_time‚É–ß‚Á‚½Œã‚ɁCÄ“x‚±‚̊֐”‚ªŒÄ‚΂ê‚邱‚Æ‚É‚È
251 * ‚éD
252 */
253 tmevtb_enqueue_cyc(p_cyccb, p_cyccb->evttim + p_cyccb->p_cycinib->cyctim);
254
255 /*
256 * ŽüŠúƒnƒ“ƒhƒ‰‚ðCCPUƒƒbƒN‰ðœó‘ԂŌĂяo‚·D
257 */
258 saved_ipm = i_get_ipm();
259 i_unlock_cpu();
260
261 LOG_CYC_ENTER(p_cyccb);
262 (*((CYCHDR)(p_cyccb->p_cycinib->cychdr)))(p_cyccb->p_cycinib->exinf);
263 LOG_CYC_LEAVE(p_cyccb);
264
265 if (!i_sense_lock()) {
266 i_lock_cpu();
267 }
268 i_set_ipm(saved_ipm);
269}
270
271#endif /* TOPPERS_cyccal */
Note: See TracBrowser for help on using the repository browser.