source: asp_ewarm/asp-1.7.0/extension/mutex/kernel/task_refer.c@ 61

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

ASP for EWARM のコミット.

File size: 5.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-2008 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: task_refer.c 1016 2008-05-10 08:42:16Z ertl-hiro $
43 */
44
45/*
46 * ƒ^ƒXƒN‚̏ó‘ÔŽQÆ‹@”\
47 */
48
49#include "kernel_impl.h"
50#include "check.h"
51#include "task.h"
52#include "wait.h"
53#include "semaphore.h"
54#include "eventflag.h"
55#include "dataqueue.h"
56#include "pridataq.h"
57#include "mailbox.h"
58#include "mempfix.h"
59#include "time_event.h"
60
61/*
62 * ƒgƒŒ[ƒXƒƒOƒ}ƒNƒ‚̃fƒtƒHƒ‹ƒg’è‹`
63 */
64#ifndef LOG_REF_TSK_ENTER
65#define LOG_REF_TSK_ENTER(tskid, pk_rtsk)
66#endif /* LOG_REF_TSK_ENTER */
67
68#ifndef LOG_REF_TSK_LEAVE
69#define LOG_REF_TSK_LEAVE(ercd, pk_rtsk)
70#endif /* LOG_REF_TSK_LEAVE */
71
72/*
73 * ƒ^ƒXƒN‚̏ó‘ÔŽQÆ
74 */
75#ifdef TOPPERS_ref_tsk
76
77ER
78ref_tsk(ID tskid, T_RTSK *pk_rtsk)
79{
80 TCB *p_tcb;
81 uint_t tstat;
82 ER ercd;
83
84 LOG_REF_TSK_ENTER(tskid, pk_rtsk);
85 CHECK_TSKCTX_UNL();
86 CHECK_TSKID_SELF(tskid);
87 p_tcb = get_tcb_self(tskid);
88
89 t_lock_cpu();
90 tstat = p_tcb->tstat;
91 if (TSTAT_DORMANT(tstat)) {
92 /*
93 * ‘Ώۃ^ƒXƒN‚ª‹xŽ~ó‘Ԃ̏ꍇ
94 */
95 pk_rtsk->tskstat = TTS_DMT;
96 }
97 else {
98 /*
99 * ƒ^ƒXƒNó‘Ô‚ÌŽæo‚µ
100 */
101 if (TSTAT_SUSPENDED(tstat)) {
102 if (TSTAT_WAITING(tstat)) {
103 pk_rtsk->tskstat = TTS_WAS;
104 }
105 else {
106 pk_rtsk->tskstat = TTS_SUS;
107 }
108 }
109 else if (TSTAT_WAITING(tstat)) {
110 pk_rtsk->tskstat = TTS_WAI;
111 }
112 else if (p_tcb == p_runtsk) {
113 pk_rtsk->tskstat = TTS_RUN;
114 }
115 else {
116 pk_rtsk->tskstat = TTS_RDY;
117 }
118
119 /*
120 * Œ»Ý—Dæ“x‚ƃx[ƒX—Dæ“x‚ÌŽæo‚µ
121 */
122 pk_rtsk->tskpri = EXT_TSKPRI(p_tcb->priority);
123 pk_rtsk->tskbpri = EXT_TSKPRI(p_tcb->bpriority);
124
125 if (TSTAT_WAITING(tstat)) {
126 /*
127 * ‘Ò‚¿—vˆö‚Æ‘Ò‚¿‘Ώۂ̃IƒuƒWƒFƒNƒg‚ÌID‚ÌŽæo‚µ
128 */
129 switch (tstat & TS_WAIT_MASK) {
130 case TS_WAIT_SLP:
131 pk_rtsk->tskwait = TTW_SLP;
132 break;
133 case TS_WAIT_DLY:
134 pk_rtsk->tskwait = TTW_DLY;
135 break;
136 case TS_WAIT_SEM:
137 pk_rtsk->tskwait = TTW_SEM;
138 pk_rtsk->wobjid = SEMID(((WINFO_SEM *)(p_tcb->p_winfo))
139 ->p_semcb);
140 break;
141 case TS_WAIT_FLG:
142 pk_rtsk->tskwait = TTW_FLG;
143 pk_rtsk->wobjid = FLGID(((WINFO_FLG *)(p_tcb->p_winfo))
144 ->p_flgcb);
145 break;
146 case TS_WAIT_SDTQ:
147 pk_rtsk->tskwait = TTW_SDTQ;
148 pk_rtsk->wobjid = DTQID(((WINFO_DTQ *)(p_tcb->p_winfo))
149 ->p_dtqcb);
150 break;
151 case TS_WAIT_RDTQ:
152 pk_rtsk->tskwait = TTW_RDTQ;
153 pk_rtsk->wobjid = DTQID(((WINFO_DTQ *)(p_tcb->p_winfo))
154 ->p_dtqcb);
155 break;
156 case TS_WAIT_SPDQ:
157 pk_rtsk->tskwait = TTW_SPDQ;
158 pk_rtsk->wobjid = PDQID(((WINFO_PDQ *)(p_tcb->p_winfo))
159 ->p_pdqcb);
160 break;
161 case TS_WAIT_RPDQ:
162 pk_rtsk->tskwait = TTW_RPDQ;
163 pk_rtsk->wobjid = PDQID(((WINFO_PDQ *)(p_tcb->p_winfo))
164 ->p_pdqcb);
165 break;
166 case TS_WAIT_MBX:
167 pk_rtsk->tskwait = TTW_MBX;
168 pk_rtsk->wobjid = MBXID(((WINFO_MBX *)(p_tcb->p_winfo))
169 ->p_mbxcb);
170 break;
171 case TS_WAIT_MPF:
172 pk_rtsk->tskwait = TTW_MPF;
173 pk_rtsk->wobjid = MPFID(((WINFO_MPF *)(p_tcb->p_winfo))
174 ->p_mpfcb);
175 break;
176 }
177
178 /*
179 * ƒ^ƒCƒ€ƒAƒEƒg‚·‚é‚Ü‚Å‚ÌŽžŠÔ‚ÌŽæo‚µ
180 */
181 if (p_tcb->p_winfo->p_tmevtb != NULL) {
182 pk_rtsk->lefttmo
183 = (TMO) tmevt_lefttim(p_tcb->p_winfo->p_tmevtb);
184 }
185 else {
186 pk_rtsk->lefttmo = TMO_FEVR;
187 }
188 }
189
190 /*
191 * ‹N°—v‹ƒLƒ…
192[ƒCƒ“ƒO”‚ÌŽæo‚µ
193 */
194 pk_rtsk->wupcnt = p_tcb->wupque ? 1U : 0U;
195 }
196
197 /*
198 * ‹N“®—v‹ƒLƒ…
199[ƒCƒ“ƒO”‚ÌŽæo‚µ
200 */
201 pk_rtsk->actcnt = p_tcb->actque ? 1U : 0U;
202 ercd = E_OK;
203 t_unlock_cpu();
204
205 error_exit:
206 LOG_REF_TSK_LEAVE(ercd, pk_rtsk);
207 return(ercd);
208}
209
210#endif /* TOPPERS_ref_tsk */
Note: See TracBrowser for help on using the repository browser.