3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Advanced Standard Profile Kernel
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2005-2007 by Embedded and Real-Time Systems Laboratory
9 * Graduate School of Information Science, Nagoya Univ., JAPAN
11 * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
12 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
13 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
14 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
15 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
17 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
18 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
19 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
21 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
22 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
24 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
25 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
26 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
28 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
29 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
30 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
31 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
34 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
35 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
36 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
37 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
40 * @(#) $Id: alarm.c 748 2008-03-07 17:18:06Z hiro $
47 #include "kernel_impl.h"
55 #define LOG_ALM_ENTER(p_almcb)
56 #endif /* LOG_ALM_ENTER */
59 #define LOG_ALM_LEAVE(p_almcb)
60 #endif /* LOG_ALM_LEAVE */
62 #ifndef LOG_STA_ALM_ENTER
63 #define LOG_STA_ALM_ENTER(almid, almtim)
64 #endif /* LOG_STA_ALM_ENTER */
66 #ifndef LOG_STA_ALM_LEAVE
67 #define LOG_STA_ALM_LEAVE(ercd)
68 #endif /* LOG_STA_ALM_LEAVE */
70 #ifndef LOG_ISTA_ALM_ENTER
71 #define LOG_ISTA_ALM_ENTER(almid, almtim)
72 #endif /* LOG_ISTA_ALM_ENTER */
74 #ifndef LOG_ISTA_ALM_LEAVE
75 #define LOG_ISTA_ALM_LEAVE(ercd)
76 #endif /* LOG_ISTA_ALM_LEAVE */
78 #ifndef LOG_STP_ALM_ENTER
79 #define LOG_STP_ALM_ENTER(almid)
80 #endif /* LOG_STP_ALM_ENTER */
82 #ifndef LOG_STP_ALM_LEAVE
83 #define LOG_STP_ALM_LEAVE(ercd)
84 #endif /* LOG_STP_ALM_LEAVE */
86 #ifndef LOG_ISTP_ALM_ENTER
87 #define LOG_ISTP_ALM_ENTER(almid)
88 #endif /* LOG_ISTP_ALM_ENTER */
90 #ifndef LOG_ISTP_ALM_LEAVE
91 #define LOG_ISTP_ALM_LEAVE(ercd)
92 #endif /* LOG_ISTP_ALM_LEAVE */
94 #ifndef LOG_REF_ALM_ENTER
95 #define LOG_REF_ALM_ENTER(almid, pk_ralm)
96 #endif /* LOG_REF_ALM_ENTER */
98 #ifndef LOG_REF_ALM_LEAVE
99 #define LOG_REF_ALM_LEAVE(ercd, pk_ralm)
100 #endif /* LOG_REF_ALM_LEAVE */
105 #define tnum_alm ((uint_t)(tmax_almid - TMIN_ALMID + 1))
108 * アラームハンドラIDからアラームハンドラ管理ブロックを取り出すためのマクロ
110 #define INDEX_ALM(almid) ((uint_t)((almid) - TMIN_ALMID))
111 #define get_almcb(almid) (&(almcb_table[INDEX_ALM(almid)]))
116 #ifdef TOPPERS_almini
119 initialize_alarm(void)
124 for (p_almcb = almcb_table, i = 0; i < tnum_alm; p_almcb++, i++) {
125 p_almcb->p_alminib = &(alminib_table[i]);
126 p_almcb->almsta = false;
130 #endif /* TOPPERS_almini */
135 #ifdef TOPPERS_sta_alm
138 sta_alm(ID almid, RELTIM almtim)
143 LOG_STA_ALM_ENTER(almid, almtim);
146 CHECK_PAR(almtim <= TMAX_RELTIM);
147 p_almcb = get_almcb(almid);
150 if (p_almcb->almsta) {
151 tmevtb_dequeue(&(p_almcb->tmevtb));
154 p_almcb->almsta = true;
156 tmevtb_enqueue(&(p_almcb->tmevtb), almtim,
157 (CBACK) call_almhdr, (void *) p_almcb);
162 LOG_STA_ALM_LEAVE(ercd);
166 #endif /* TOPPERS_sta_alm */
169 * アラームハンドラの動作開始(非タスクコンテキスト用)
171 #ifdef TOPPERS_ista_alm
174 ista_alm(ID almid, RELTIM almtim)
179 LOG_ISTA_ALM_ENTER(almid, almtim);
182 CHECK_PAR(almtim <= TMAX_RELTIM);
183 p_almcb = get_almcb(almid);
186 if (p_almcb->almsta) {
187 tmevtb_dequeue(&(p_almcb->tmevtb));
190 p_almcb->almsta = true;
192 tmevtb_enqueue(&(p_almcb->tmevtb), almtim,
193 (CBACK) call_almhdr, (void *) p_almcb);
198 LOG_ISTA_ALM_LEAVE(ercd);
202 #endif /* TOPPERS_ista_alm */
207 #ifdef TOPPERS_stp_alm
215 LOG_STP_ALM_ENTER(almid);
218 p_almcb = get_almcb(almid);
221 if (p_almcb->almsta) {
222 p_almcb->almsta = false;
223 tmevtb_dequeue(&(p_almcb->tmevtb));
229 LOG_STP_ALM_LEAVE(ercd);
233 #endif /* TOPPERS_stp_alm */
236 * アラームハンドラの動作停止(非タスクコンテキスト用)
238 #ifdef TOPPERS_istp_alm
246 LOG_ISTP_ALM_ENTER(almid);
249 p_almcb = get_almcb(almid);
252 if (p_almcb->almsta) {
253 p_almcb->almsta = false;
254 tmevtb_dequeue(&(p_almcb->tmevtb));
260 LOG_ISTP_ALM_LEAVE(ercd);
264 #endif /* TOPPERS_istp_alm */
269 #ifdef TOPPERS_ref_alm
272 ref_alm(ID almid, T_RALM *pk_ralm)
277 LOG_REF_ALM_ENTER(almid, pk_ralm);
280 p_almcb = get_almcb(almid);
283 if (p_almcb->almsta) {
284 pk_ralm->almstat = TALM_STA;
285 pk_ralm->lefttim = tmevt_lefttim(&(p_almcb->tmevtb));
288 pk_ralm->almstat = TALM_STP;
294 LOG_REF_ALM_LEAVE(ercd, pk_ralm);
298 #endif /* TOPPERS_ref_alm */
303 #ifdef TOPPERS_almcal
306 call_almhdr(ALMCB *p_almcb)
313 p_almcb->almsta = false;
316 * アラームハンドラを,CPUロック解除状態で呼び出す.
318 saved_ipm = i_get_ipm();
321 LOG_ALM_ENTER(p_almcb);
322 (*((ALMHDR)(p_almcb->p_alminib->almhdr)))(p_almcb->p_alminib->exinf);
323 LOG_ALM_LEAVE(p_almcb);
325 if (!i_sense_lock()) {
328 i_set_ipm(saved_ipm);
331 #endif /* TOPPERS_almcal */