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.