📄 eventflag.c
字号:
/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2000 by Embedded and Real-Time Systems Laboratory * Toyohashi Univ. of Technology, JAPAN * * 惧淡螟侯涪荚は·Free Software Foundation によって给山されている * GNU General Public License の Version 2 に淡揭されている掘凤か·笆 * 布の(1)×(4)の掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェ * アを猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· * 网脱と钙ぶ∷することを痰浸で钓满するˉ * (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 * スコ〖ド面に崔まれていることˉ * (2) 塑ソフトウェアを浩网脱材墙なバイナリコ〖ド∈リロケ〖タブルオブ * ジェクトファイルやライブラリなど∷の妨で网脱する眷圭には·网脱 * に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟侯涪山绩· * この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (3) 塑ソフトウェアを浩网脱稍材墙なバイナリコ〖ドの妨または怠达に寥 * み哈んだ妨で网脱する眷圭には·肌のいずれかの掘凤を塔たすことˉ * (a) 网脱に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (b) 网脱の妨轮を·侍に年める数恕によって·惧淡螟侯涪荚に鼠桂する * ことˉ * (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 * 巢からも·惧淡螟侯涪荚を倘勒することˉ * * 塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚は· * 塑ソフトウェアに簇して·その努脱材墙拉も崔めて·いかなる瘦沮も乖わ * ないˉまた·塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じたい * かなる禄巢に簇しても·その勒扦を砷わないˉ * * @(#) $Id: eventflag.c,v 1.5 2002/03/26 08:19:38 hiro Exp $ *//* * イベントフラグ怠墙 */#include "jsp_kernel.h"#include "check.h"#include "task.h"#include "wait.h"#include "eventflag.h"/* * イベントフラグIDの呵络猛∈kernel_cfg.c∷ */extern const ID tmax_flgid;/* * イベントフラグ介袋步ブロックのエリア∈kernel_cfg.c∷ */extern const FLGINIB flginib_table[];/* * イベントフラグ瓷妄ブロックのエリア∈kernel_cfg.c∷ */extern FLGCB flgcb_table[];/* * イベントフラグIDからイベントフラグ瓷妄ブロックを艰り叫すためのマクロ */#define INDEX_FLG(flgid) ((flgid) - TMIN_FLGID)#define get_flgcb(flgid) (&(flgcb_table[INDEX_FLG(flgid)]))/* * イベントフラグ略ち攫鼠ブロックの年盗 * * flgptn は·waiptn および wfmode と票箕に蝗うことはないため·union * を蝗えばメモリを泪腆することが材墙であるˉ */typedef struct eventflag_waiting_information { WINFO winfo; /* 筛洁の略ち攫鼠ブロック */ WOBJCB *wobjcb; /* 略ちオブジェクトのコントロ〖ルブロック */ FLGPTN waiptn; /* 略ちパタ〖ン */ MODE wfmode; /* 略ちモ〖ド */ FLGPTN flgptn; /* 略ち豺近箕のパタ〖ン */} WINFO_FLG;/* * イベントフラグ怠墙の介袋步 */voideventflag_initialize(void){ INT i; FLGCB *flgcb; for (flgcb = flgcb_table, i = 0; i < tmax_flgid; flgcb++, i++) { queue_initialize(&(flgcb->wait_queue)); flgcb->flginib = &(flginib_table[i]); flgcb->flgptn = flgcb->flginib->iflgptn; }}/* * イベントフラグ略ち豺近掘凤のチェック */static BOOLeventflag_cond(FLGCB *flgcb, FLGPTN waiptn, MODE wfmode, FLGPTN *p_flgptn){ if ((wfmode & TWF_ORW) != 0 ? (flgcb->flgptn & waiptn) != 0 : (flgcb->flgptn & waiptn) == waiptn) { *p_flgptn = flgcb->flgptn; if ((flgcb->flginib->flgatr & TA_CLR) != 0) { flgcb->flgptn = 0; } return(TRUE); } return(FALSE);}/* * イベントフラグのセット */SYSCALL ERset_flg(ID flgid, FLGPTN setptn){ FLGCB *flgcb; TCB *tcb; WINFO_FLG *winfo; CHECK_TSKCTX_UNL(); CHECK_FLGID(flgid); flgcb = get_flgcb(flgid); t_lock_cpu(); flgcb->flgptn |= setptn; if (!(queue_empty(&(flgcb->wait_queue)))) { tcb = (TCB *)(flgcb->wait_queue.next); winfo = (WINFO_FLG *)(tcb->winfo); if (eventflag_cond(flgcb, winfo->waiptn, winfo->wfmode, &(winfo->flgptn))) { queue_delete(&(tcb->task_queue)); if (wait_complete(tcb)) { dispatch(); } } } t_unlock_cpu(); return(E_OK);}/* * イベントフラグのセット∈润タスクコンテキスト脱∷ */SYSCALL ERiset_flg(ID flgid, FLGPTN setptn){ FLGCB *flgcb; TCB *tcb; WINFO_FLG *winfo; CHECK_INTCTX_UNL(); CHECK_FLGID(flgid); flgcb = get_flgcb(flgid); i_lock_cpu(); flgcb->flgptn |= setptn; if (!(queue_empty(&(flgcb->wait_queue)))) { tcb = (TCB *)(flgcb->wait_queue.next); winfo = (WINFO_FLG *)(tcb->winfo); if (eventflag_cond(flgcb, winfo->waiptn, winfo->wfmode, &(winfo->flgptn))) { queue_delete(&(tcb->task_queue)); if (wait_complete(tcb)) { reqflg = TRUE; } } } i_unlock_cpu(); return(E_OK);}/* * イベントフラグのクリア */SYSCALL ERclr_flg(ID flgid, FLGPTN clrptn){ FLGCB *flgcb; CHECK_TSKCTX_UNL(); CHECK_FLGID(flgid); flgcb = get_flgcb(flgid); t_lock_cpu(); flgcb->flgptn &= clrptn; t_unlock_cpu(); return(E_OK);}/* * イベントフラグ略ち */SYSCALL ERwai_flg(ID flgid, FLGPTN waiptn, MODE wfmode, FLGPTN *p_flgptn){ FLGCB *flgcb; WINFO_FLG winfo; ER ercd; CHECK_DISPATCH(); CHECK_FLGID(flgid); CHECK_PAR(waiptn != 0); CHECK_PAR((wfmode & ~TWF_ORW) == 0); flgcb = get_flgcb(flgid); t_lock_cpu(); if (!(queue_empty(&(flgcb->wait_queue)))) { ercd = E_ILUSE; } else if (eventflag_cond(flgcb, waiptn, wfmode, p_flgptn)) { ercd = E_OK; } else { winfo.waiptn = waiptn; winfo.wfmode = wfmode; wobj_make_wait((WOBJCB *) flgcb, (WINFO_WOBJ *) &winfo); dispatch(); ercd = winfo.winfo.wercd; if (ercd == E_OK) { *p_flgptn = winfo.flgptn; } } t_unlock_cpu(); return(ercd);}/* * イベントフラグ略ち∈ポ〖リング∷ */SYSCALL ERpol_flg(ID flgid, FLGPTN waiptn, MODE wfmode, FLGPTN *p_flgptn){ FLGCB *flgcb; ER ercd; CHECK_TSKCTX_UNL(); CHECK_FLGID(flgid); CHECK_PAR(waiptn != 0); CHECK_PAR((wfmode & ~TWF_ORW) == 0); flgcb = get_flgcb(flgid); t_lock_cpu(); if (!(queue_empty(&(flgcb->wait_queue)))) { ercd = E_ILUSE; } else if (eventflag_cond(flgcb, waiptn, wfmode, p_flgptn)) { ercd = E_OK; } else { ercd = E_TMOUT; } t_unlock_cpu(); return(ercd);}/* * イベントフラグ略ち∈タイムアウトあり∷ */SYSCALL ERtwai_flg(ID flgid, FLGPTN waiptn, MODE wfmode, FLGPTN *p_flgptn, TMO tmout){ FLGCB *flgcb; WINFO_FLG winfo; TMEVTB tmevtb; ER ercd; CHECK_DISPATCH(); CHECK_FLGID(flgid); CHECK_PAR(waiptn != 0); CHECK_PAR((wfmode & ~TWF_ORW) == 0); CHECK_TMOUT(tmout); flgcb = get_flgcb(flgid); t_lock_cpu(); if (!(queue_empty(&(flgcb->wait_queue)))) { ercd = E_ILUSE; } else if (eventflag_cond(flgcb, waiptn, wfmode, p_flgptn)) { ercd = E_OK; } else if (tmout == TMO_POL) { ercd = E_TMOUT; } else { winfo.waiptn = waiptn; winfo.wfmode = wfmode; wobj_make_wait_tmout((WOBJCB *) flgcb, (WINFO_WOBJ *) &winfo, &tmevtb, tmout); dispatch(); ercd = winfo.winfo.wercd; if (ercd == E_OK) { *p_flgptn = winfo.flgptn; } } t_unlock_cpu(); return(ercd);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -