source: asp3_wo_tecs/trunk/extension/messagebuf/kernel/wait.c@ 302

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

TECSレスのASP3の開発のため以下のtrunkからコピー
http://dev.toppers.jp/svn/asp3/branches/WO_TECS-3.C.0

File size: 6.1 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-2015 by Embedded and Real-Time Systems Laboratory
9 * Graduate School of Information Science, Nagoya Univ., JAPAN
10 *
11 * 上記著作権者
12は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
13 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
14 * 変・再é…
15å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
16 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
17 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
18 * スコード中に含まれていること.
19 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
20 * 用できる形で再é…
21å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
22å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
23 * 者
24マニュアルなど)に,上記の著作権表示,この利用条件および下記
25 * の無保証規定を掲載すること.
26 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
27 * 用できない形で再é…
28å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
29 * と.
30 * (a) 再é…
31å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
32マニュアルなど)に,上記の著
33 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
34 * (b) 再é…
35å¸ƒã®å½¢æ…
36‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
37 * 報告すること.
38 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
39 * 害からも,上記著作権者
40およびTOPPERSプロジェクトをå…
41è²¬ã™ã‚‹ã“と.
42 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
43 * 由に基づく請求からも,上記著作権者
44およびTOPPERSプロジェクトを
45 * å…
46è²¬ã™ã‚‹ã“と.
47 *
48 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
49お
50 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
51 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
52 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
53 * の責任を負わない.
54 *
55 * $Id: wait.c 470 2015-12-30 09:50:36Z ertl-hiro $
56 */
57
58/*
59 * 待
60ち状æ…
61‹ç®¡ç†ãƒ¢ã‚¸ãƒ¥ãƒ¼ãƒ«
62 */
63
64#include "kernel_impl.h"
65#include "taskhook.h"
66#include "wait.h"
67
68/*
69 * 待
70ち状æ…
71‹ã¸ã®é·ç§»ï¼ˆã‚¿ã‚¤ãƒ ã‚¢ã‚¦ãƒˆæŒ‡å®šï¼‰
72 */
73#ifdef TOPPERS_waimake
74
75void
76make_wait_tmout(WINFO *p_winfo, TMEVTB *p_tmevtb, TMO tmout)
77{
78 make_non_runnable(p_runtsk);
79 p_runtsk->p_winfo = p_winfo;
80 if (tmout == TMO_FEVR) {
81 p_winfo->p_tmevtb = NULL;
82 }
83 else {
84 assert(tmout <= TMAX_RELTIM);
85 p_winfo->p_tmevtb = p_tmevtb;
86 p_tmevtb->callback = (CBACK) wait_tmout;
87 p_tmevtb->arg = (void *) p_runtsk;
88 tmevtb_enqueue(p_tmevtb, (RELTIM) tmout);
89 }
90}
91
92#endif /* TOPPERS_waimake */
93
94/*
95 * オブジェクト待
96ちキューからの削除
97 */
98#ifdef TOPPERS_waiwobj
99
100void
101wait_dequeue_wobj(TCB *p_tcb)
102{
103 if (TSTAT_WAIT_WOBJ(p_tcb->tstat)) {
104 queue_delete(&(p_tcb->task_queue));
105 if (TSTAT_WAIT_SMBF(p_tcb->tstat)) {
106 (*mbfhook_dequeue_wobj)(p_tcb);
107 }
108 }
109}
110
111#endif /* TOPPERS_waiwobj */
112
113/*
114 * 待
115ち解除
116 */
117#ifdef TOPPERS_waicmp
118
119void
120wait_complete(TCB *p_tcb)
121{
122 wait_dequeue_tmevtb(p_tcb);
123 p_tcb->p_winfo->wercd = E_OK;
124 make_non_wait(p_tcb);
125}
126
127#endif /* TOPPERS_waicmp */
128
129/*
130 * タイムアウトに伴う待
131ち解除
132 */
133#ifdef TOPPERS_waitmo
134
135void
136wait_tmout(TCB *p_tcb)
137{
138 wait_dequeue_wobj(p_tcb);
139 p_tcb->p_winfo->wercd = E_TMOUT;
140 make_non_wait(p_tcb);
141 if (p_runtsk != p_schedtsk) {
142 request_dispatch();
143 }
144
145 /*
146 * ここで優å…
147ˆåº¦ã®é«˜ã„割込みを受け付ける.
148 */
149 unlock_cpu();
150 delay_for_interrupt();
151 lock_cpu();
152}
153
154#endif /* TOPPERS_waitmo */
155#ifdef TOPPERS_waitmook
156
157void
158wait_tmout_ok(TCB *p_tcb)
159{
160 p_tcb->p_winfo->wercd = E_OK;
161 make_non_wait(p_tcb);
162 if (p_runtsk != p_schedtsk) {
163 request_dispatch();
164 }
165
166 /*
167 * ここで優å…
168ˆåº¦ã®é«˜ã„割込みを受け付ける.
169 */
170 unlock_cpu();
171 delay_for_interrupt();
172 lock_cpu();
173}
174
175#endif /* TOPPERS_waitmook */
176
177/*
178 * 実行中のタスクの同期・通信オブジェクトの待
179ちキューへの挿å…
180¥
181 *
182 * 実行中のタスクを,同期・通信オブジェクトの待
183ちキューへ挿å…
184¥ã™ã‚‹ï¼Žã‚ª
185 * ブジェクトの属性に応じて,FIFO順またはタスク優å…
186ˆåº¦é †ã§æŒ¿å…
187¥ã™ã‚‹ï¼Ž
188 */
189Inline void
190wobj_queue_insert(WOBJCB *p_wobjcb)
191{
192 if ((p_wobjcb->p_wobjinib->wobjatr & TA_TPRI) != 0U) {
193 queue_insert_tpri(&(p_wobjcb->wait_queue), p_runtsk);
194 }
195 else {
196 queue_insert_prev(&(p_wobjcb->wait_queue), &(p_runtsk->task_queue));
197 }
198}
199
200/*
201 * 同期・通信オブジェクトに対する待
202ち状æ…
203‹ã¸ã®é·ç§»
204 */
205#ifdef TOPPERS_wobjwai
206
207void
208wobj_make_wait(WOBJCB *p_wobjcb, WINFO_WOBJ *p_winfo_wobj)
209{
210 make_wait(&(p_winfo_wobj->winfo));
211 wobj_queue_insert(p_wobjcb);
212 p_winfo_wobj->p_wobjcb = p_wobjcb;
213 LOG_TSKSTAT(p_runtsk);
214}
215
216#endif /* TOPPERS_wobjwai */
217#ifdef TOPPERS_wobjwaitmo
218
219void
220wobj_make_wait_tmout(WOBJCB *p_wobjcb, WINFO_WOBJ *p_winfo_wobj,
221 TMEVTB *p_tmevtb, TMO tmout)
222{
223 make_wait_tmout(&(p_winfo_wobj->winfo), p_tmevtb, tmout);
224 wobj_queue_insert(p_wobjcb);
225 p_winfo_wobj->p_wobjcb = p_wobjcb;
226 LOG_TSKSTAT(p_runtsk);
227}
228
229#endif /* TOPPERS_wobjwaitmo */
230
231/*
232 * 待
233ちキューの初期化
234 */
235#ifdef TOPPERS_iniwque
236
237void
238init_wait_queue(QUEUE *p_wait_queue)
239{
240 TCB *p_tcb;
241
242 while (!queue_empty(p_wait_queue)) {
243 p_tcb = (TCB *) queue_delete_next(p_wait_queue);
244 wait_dequeue_tmevtb(p_tcb);
245 p_tcb->p_winfo->wercd = E_DLT;
246 make_non_wait(p_tcb);
247 }
248}
249
250#endif /* TOPPERS_iniwque */
Note: See TracBrowser for help on using the repository browser.