OSDN Git Service

Sメーター周りを修正
[trx-305dsp/dsp.git] / trx305 / kernel / kernel / wait.h
1 /*
2  *  TOPPERS/JSP Kernel
3  *      Toyohashi Open Platform for Embedded Real-Time Systems/
4  *      Just Standard Profile Kernel
5  * 
6  *  Copyright (C) 2000 by Embedded and Real-Time Systems Laboratory
7  *                              Toyohashi Univ. of Technology, JAPAN
8  * 
9  *  上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation 
10  *  によって公表されている GNU General Public License の Version 2 に記
11  *  述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
12  *  を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
13  *  利用と呼ぶ)することを無償で許諾する.
14  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
15  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
16  *      スコード中に含まれていること.
17  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
18  *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
19  *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
20  *      の無保証規定を掲載すること.
21  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
22  *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
23  *      と.
24  *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
25  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
26  *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
27  *        報告すること.
28  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
29  *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
30  * 
31  *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
32  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
33  *  含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
34  *  接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
35  * 
36  *  @(#) $Id: wait.h,v 1.1 2009/01/31 05:27:37 suikan Exp $
37  */
38
39 /*
40  *  待ち状態管理モジュール
41  */
42
43 #ifndef _WAIT_H_
44 #define _WAIT_H_
45
46 #include "task.h"
47 #include "time_event.h"
48
49 /*
50  *  待ち状態への移行
51  *
52  *  実行中のタスクを待ち状態に移行させる.具体的には,実行中のタスクを
53  *  レディキューから削除し,TCB の winfoフィールド,WINFO の tmevtbフ
54  *  ィールドを設定する.
55  */
56 Inline void
57 make_wait(WINFO *winfo)
58 {
59     make_non_runnable(runtsk);
60     runtsk->winfo = winfo;
61     winfo->tmevtb = NULL;
62 }
63
64 /*
65  *  待ち状態への移行(タイムアウト指定)
66  *
67  *  実行中のタスクを,タイムアウト指定付きで待ち状態に移行させる.具体
68  *  的には,実行中のタスクをレディキューから削除し,TCB の winfoフィー
69  *  ルド,WINFO の tmevtbフィールドを設定する.また,タイムイベントブ
70  *  ロックを登録する.
71  */
72 extern void make_wait_tmout(WINFO *winfo, TMEVTB *tmevtb, TMO tmout);
73
74 /*
75  *  待ち解除
76  *
77  *  tcb で指定されるタスクの待ち状態を解除する.具体的には,タイムイベ
78  *  ントブロックが登録されていれば,それを登録解除する.また,タスク状
79  *  態を更新し,待ち解除したタスクからの返値を E_OK とする.待ちキュー
80  *  からの削除は行わない.待ち解除したタスクへのディスパッチが必要な場
81  *  合には TRUE を返す.
82  */
83 extern BOOL wait_complete(TCB *tcb);
84
85 /*
86  *  タイムアウトに伴う待ち解除
87  *
88  *  tcb で指定されるタスクが,待ちキューにつながれていれば待ちキューか
89  *  ら削除し,タスク状態を更新する.また,待ち解除したタスクからの返値
90  *  を,wait_tmoutでは E_TMOUT,wait_tmout_ok では E_OK とする.待ち解
91  *  除したタスクへのディスパッチが必要な時は,reqflg を TRUE にする.
92  *  wait_tmout_ok は,dly_tsk で使うためのもので,待ちキューから削除す
93  *  る処理を行わない.
94  *  いずれの関数も,タイムイベントのコールバック関数として用いるための
95  *  もので,割込みハンドラから呼び出されることを想定している.
96  */
97 extern void wait_tmout(TCB *tcb);
98 extern void wait_tmout_ok(TCB *tcb);
99
100 /*
101  *  待ち状態の強制解除
102  *
103  *  tcb で指定されるタスクの待ち状態を強制的に解除する.具体的には,タ
104  *  スクが待ちキューにつながれていれば待ちキューから削除し,タイムイベ
105  *  ントブロックが登録されていればそれを登録解除する.
106  *  wait_cancel は,タスクの状態は更新しない.
107  *  wait_release は,タスクの状態を更新し,待ち解除したタスクからの返
108  *  値を E_RLWAI とする.また,待ち解除したタスクへのディスパッチが必
109  *  要な場合には TRUE を返す.
110  */
111 extern void wait_cancel(TCB *tcb);
112 extern BOOL wait_release(TCB *tcb);
113
114 /*
115  *  同期・通信オブジェクトの管理ブロックの共通部分操作ルーチン
116  *
117  *  同期・通信オブジェクトの初期化ブロックと管理ブロックの先頭部分は共
118  *  通になっている.以下は,その共通部分を扱うための型およびルーチン群
119  *  である.
120  *  複数の待ちキューを持つ同期・通信オブジェクトの場合,先頭以外の待ち
121  *  キューを操作する場合には,これらのルーチンは使えない.また,オブジェ
122  *  クト属性の TA_TPRI ビットを参照するので,このビットを他の目的に使っ
123  *  ている場合も,これらのルーチンは使えない.
124  */
125
126 /*
127  *  同期・通信オブジェクトの初期化ブロックの共通部分
128  */
129 typedef struct wait_object_initialization_block {
130     ATR wobjatr;    /* オブジェクト属性 */
131 } WOBJINIB;
132
133 /*
134  *  同期・通信オブジェクトの管理ブロックの共通部分
135  */
136 typedef struct wait_object_control_block {
137     QUEUE       wait_queue; /* 待ちキュー */
138     const WOBJINIB  *wobjinib;  /* 初期化ブロックへのポインタ */
139 } WOBJCB;
140
141 /*
142  *  同期・通信オブジェクト待ち情報ブロックの定義
143  */
144 typedef struct wait_object_waiting_information {
145     WINFO   winfo;      /* 標準の待ち情報ブロック */
146     WOBJCB  *wobjcb;    /* 待ちオブジェクトの管理ブロック */
147 } WINFO_WOBJ;
148
149 /*
150  *  同期・通信オブジェクトに対する待ち状態への移行
151  *  
152  *  実行中のタスクを待ち状態に移行させ,同期・通信オブジェクトの待ちキュー
153  *  につなぐ.また,待ち情報ブロック(WINFO)の wobjcb を設定する.
154  *  wobj_make_wait_tmout は,タイムイベントブロックの登録も行う.
155  */
156 extern void wobj_make_wait(WOBJCB *wobjcb, WINFO_WOBJ *winfo);
157 extern void wobj_make_wait_tmout(WOBJCB *wobjcb, WINFO_WOBJ *winfo,
158                     TMEVTB *tmevtb, TMO tmout);
159
160 /*
161  *  タスク優先度変更時の処理
162  *
163  *  同期・通信オブジェクトに対する待ち状態にあるタスクの優先度が変更さ
164  *  れた場合に,待ちキューの中でのタスクの位置を修正する.
165  */
166 extern void wobj_change_priority(WOBJCB *wobjcb, TCB *tcb);
167
168 #endif /* _WAIT_H_ */