time_event.h

説明を見る。
00001 /*
00002  *  TOPPERS/ASP Kernel
00003  *      Toyohashi Open Platform for Embedded Real-Time Systems/
00004  *      Advanced Standard Profile Kernel
00005  * 
00006  *  Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
00007  *                              Toyohashi Univ. of Technology, JAPAN
00008  *  Copyright (C) 2005-2008 by Embedded and Real-Time Systems Laboratory
00009  *              Graduate School of Information Science, Nagoya Univ., JAPAN
00010  * 
00011  *  上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
00012  *  ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
00013  *  変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
00014  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
00015  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
00016  *      スコード中に含まれていること.
00017  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
00018  *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
00019  *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
00020  *      の無保証規定を掲載すること.
00021  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
00022  *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
00023  *      と.
00024  *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
00025  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
00026  *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
00027  *        報告すること.
00028  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
00029  *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
00030  *      また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
00031  *      由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
00032  *      免責すること.
00033  * 
00034  *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
00035  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
00036  *  に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
00037  *  アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
00038  *  の責任を負わない.
00039  * 
00040  *  @(#) $Id: time_event.h 907 2008-04-11 12:09:13Z hiro $
00041  */
00042 
00043 /*
00044  *      タイムイベント管理モジュール
00045  */
00046 
00047 #ifndef TOPPERS_TIME_EVENT_H
00048 #define TOPPERS_TIME_EVENT_H
00049 
00050 /*
00051  *  イベント発生時刻のデータ型の定義
00052  *
00053  *  EVTTIMは,RELTIMとして指定できる範囲よりも広い範囲を表現できる必要
00054  *  がある.μITRON4.0仕様のスタンダードプロファイルでは,RELTIMが16ビッ
00055  *  ト以上でなければならないため,EVTTIMは17ビット以上であることが必要
00056  *  である.そのため,16ビットになる場合があるuint_tではなく,ulong_tに
00057  *  定義している.
00058  */
00059 typedef ulong_t EVTTIM;
00060 
00061 /*
00062  *  相対時間(RELTIM)に指定できる最大値
00063  */
00064 #if UINT_MAX < LONG_MAX
00065 #define TMAX_RELTIM     UINT_MAX
00066 #else /* UINT_MAX < LONG_MAX */
00067 #define TMAX_RELTIM     ((RELTIM) LONG_MAX)
00068 #endif /* UINT_MAX < LONG_MAX */
00069 
00070 /* 
00071  *  タイムイベントブロックのデータ型の定義
00072  */
00073 typedef void    (*CBACK)(void *);   /* コールバック関数の型 */
00074 
00075 typedef struct time_event_block {
00076     uint_t  index;          /* タイムイベントヒープ中での位置 */
00077     CBACK   callback;       /* コールバック関数 */
00078     void    *arg;           /* コールバック関数へ渡す引数 */
00079 } TMEVTB;
00080 
00081 /*
00082  *  タイムイベントヒープ中のノードのデータ型の定義
00083  */
00084 typedef struct time_event_node {
00085     EVTTIM  time;           /* イベント発生時刻 */
00086     TMEVTB  *p_tmevtb;      /* 対応するタイムイベントブロック */
00087 } TMEVTN;
00088 
00089 /*
00090  *  タイムイベントヒープ(kernel_cfg.c)
00091  */
00092 extern TMEVTN   tmevt_heap[];
00093 
00094 /*
00095  *  現在のシステム時刻(単位: ミリ秒)
00096  *
00097  *  システム起動時に0に初期化され,以降,タイムティックが供給される度に
00098  *  単調に増加する.
00099  */
00100 extern EVTTIM   current_time;
00101 
00102 /*
00103  *  次のタイムティックのシステム時刻(単位: 1ミリ秒)
00104  */
00105 extern EVTTIM   next_time;
00106 
00107 /*
00108  *  システム時刻積算用変数(単位: 1/TIM_DENOミリ秒)
00109  *
00110  *  次のタイムティックのシステム時刻の下位桁を示す(上位桁はnext_time).
00111  *  TIC_DENOが1の時は,下位桁は常に0であるため,この変数は必要ない.
00112  */
00113 #if TIC_DENO != 1U
00114 extern uint_t   next_subtime;
00115 #endif /* TIC_DENO != 1U */
00116 
00117 /*
00118  *  相対時間のベース時刻(単位: 1ミリ秒)
00119  *
00120  *  次のタイムティックのシステム時刻を切り上げた時刻.TIC_DENOが1の時
00121  *  は,next_timeに一致する.
00122  */
00123 #if TIC_DENO == 1U
00124 #define base_time   (next_time)
00125 #else /* TIC_DENO == 1U */
00126 #define base_time   (next_time + (next_subtime > 0U ? 1U : 0U))
00127 #endif /* TIC_DENO == 1U */
00128 
00129 /*
00130  *  タイムイベントヒープの最後の使用領域のインデックス
00131  *
00132  *  タイムイベントヒープに登録されているタイムイベントの数に一致する.
00133  */
00134 extern uint_t   last_index;
00135 
00136 /*
00137  *  タイムイベント管理モジュールの初期化
00138  */
00139 extern void initialize_tmevt(void);
00140 
00141 /*
00142  *  タイムイベントの挿入位置の探索
00143  */
00144 extern uint_t   tmevt_up(uint_t index, EVTTIM time);
00145 extern uint_t   tmevt_down(uint_t index, EVTTIM time);
00146 
00147 /*
00148  *  タイムイベントヒープへの登録と削除
00149  */
00150 extern void tmevtb_insert(TMEVTB *p_tmevtb, EVTTIM time);
00151 extern void tmevtb_delete(TMEVTB *p_tmevtb);
00152 
00153 /*
00154  *  タイムイベントブロックの登録(相対時間指定)
00155  *
00156  *  timeで指定した相対時間が経過した後に,argを引数としてcallbackが呼
00157  *  び出されるように,p_tmevtbで指定したタイムイベントブロックを登録す
00158  *  る.
00159  *  
00160  */
00161 Inline void
00162 tmevtb_enqueue(TMEVTB *p_tmevtb, RELTIM time, CBACK callback, void *arg)
00163 {
00164     assert(time <= TMAX_RELTIM);
00165 
00166     p_tmevtb->callback = callback;
00167     p_tmevtb->arg = arg;
00168     tmevtb_insert(p_tmevtb, base_time + time);
00169 }
00170 
00171 /*
00172  *  タイムイベントブロックの登録(イベント発生時刻指定)
00173  *
00174  *  timeで指定したイベント発生時刻に,argを引数としてcallbackが呼び出
00175  *  されるように,p_tmevtbで指定したタイムイベントブロックを登録する.
00176  */
00177 Inline void
00178 tmevtb_enqueue_evttim(TMEVTB *p_tmevtb, EVTTIM time, CBACK callback, void *arg)
00179 {
00180     p_tmevtb->callback = callback;
00181     p_tmevtb->arg = arg;
00182     tmevtb_insert(p_tmevtb, time);
00183 }
00184 
00185 /*
00186  *  タイムイベントブロックの登録解除
00187  */
00188 Inline void
00189 tmevtb_dequeue(TMEVTB *p_tmevtb)
00190 {
00191     tmevtb_delete(p_tmevtb);
00192 }
00193 
00194 /*
00195  *  タイムイベントまでの残り時間の計算
00196  */
00197 extern RELTIM   tmevt_lefttim(TMEVTB *p_tmevtb);
00198 
00199 /*
00200  *  タイムティックの供給
00201  */
00202 extern void signal_time(void);
00203 
00204 #endif /* TOPPERS_TIME_EVENT_H */

Copyright © 2008 by Kijineko Inc.

ホームページ制作