mailbox.c
来自「嵌入式系统开发 TOPPERS and JSP Kernel Release 」· C语言 代码 · 共 257 行
C
257 行
/* * 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: mailbox.c,v 1.4 2002/03/26 08:19:38 hiro Exp $ *//* * メ〖ルボックス怠墙 */#include "jsp_kernel.h"#include "check.h"#include "task.h"#include "wait.h"#include "mailbox.h"/* * メ〖ルボックスIDの呵络猛∈kernel_cfg.c∷ */extern const ID tmax_mbxid;/* * メ〖ルボックス介袋步ブロックのエリア∈kernel_cfg.c∷ */extern const MBXINIB mbxinib_table[];/* * メ〖ルボックス瓷妄ブロックのエリア∈kernel_cfg.c∷ */extern MBXCB mbxcb_table[];/* * メ〖ルボックスIDからメ〖ルボックス瓷妄ブロックを艰り叫すためのマクロ */#define INDEX_MBX(mbxid) ((mbxid) - TMIN_MBXID)#define get_mbxcb(mbxid) (&(mbxcb_table[INDEX_MBX(mbxid)]))/* * メ〖ルボックス略ち攫鼠ブロックの年盗 */typedef struct mailbox_waiting_information { WINFO winfo; /* 筛洁の略ち攫鼠ブロック */ WOBJCB *wobjcb; /* 略ちオブジェクトのコントロ〖ルブロック */ T_MSG *pk_msg; /* 减慨したメッセ〖ジ */} WINFO_MBX;/* * メ〖ルボックス怠墙の介袋步 */voidmailbox_initialize(){ INT i; MBXCB *mbxcb; for (mbxcb = mbxcb_table, i = 0; i < tmax_mbxid; mbxcb++, i++) { queue_initialize(&(mbxcb->wait_queue)); mbxcb->mbxinib = &(mbxinib_table[i]); mbxcb->head = NULL; }}/* * メッセ〖ジ庭黎刨の艰叫し */#define MSGPRI(pk_msg) (((T_MSG_PRI *) pk_msg)->msgpri)/* * 庭黎刨界メッセ〖ジキュ〖への赁掐 */Inline voidenqueue_msg_pri(T_MSG **p_prevmsg_next, T_MSG *pk_msg){ T_MSG *pk_nextmsg; while ((pk_nextmsg = *p_prevmsg_next) != NULL) { if (MSGPRI(pk_nextmsg) > MSGPRI(pk_msg)) { break; } p_prevmsg_next = &(pk_nextmsg->next); } pk_msg->next = pk_nextmsg; *p_prevmsg_next = pk_msg;}/* * メ〖ルボックスへの流慨 */SYSCALL ERsnd_mbx(ID mbxid, T_MSG *pk_msg){ MBXCB *mbxcb; TCB *tcb; ER ercd; CHECK_TSKCTX_UNL(); CHECK_MBXID(mbxid); mbxcb = get_mbxcb(mbxid); CHECK_PAR((mbxcb->mbxinib->mbxatr & TA_MPRI) == 0 || (TMIN_MPRI <= MSGPRI(pk_msg) && MSGPRI(pk_msg) <= mbxcb->mbxinib->maxmpri)); t_lock_cpu(); if (!(queue_empty(&(mbxcb->wait_queue)))) { tcb = (TCB *) queue_delete_next(&(mbxcb->wait_queue)); ((WINFO_MBX *)(tcb->winfo))->pk_msg = pk_msg; if (wait_complete(tcb)) { dispatch(); } ercd = E_OK; } else if ((mbxcb->mbxinib->mbxatr & TA_MPRI) != 0) { enqueue_msg_pri(&(mbxcb->head), pk_msg); ercd = E_OK; } else { pk_msg->next = NULL; if (mbxcb->head != NULL) { mbxcb->last->next = pk_msg; } else { mbxcb->head = pk_msg; } mbxcb->last = pk_msg; ercd = E_OK; } t_unlock_cpu(); return(ercd);}/* * メ〖ルボックスからの减慨 */SYSCALL ERrcv_mbx(ID mbxid, T_MSG **ppk_msg){ MBXCB *mbxcb; WINFO_MBX winfo; ER ercd; CHECK_DISPATCH(); CHECK_MBXID(mbxid); mbxcb = get_mbxcb(mbxid); t_lock_cpu(); if (mbxcb->head != NULL) { *ppk_msg = mbxcb->head; mbxcb->head = (*ppk_msg)->next; ercd = E_OK; } else { wobj_make_wait((WOBJCB *) mbxcb, (WINFO_WOBJ *) &winfo); dispatch(); ercd = winfo.winfo.wercd; if (ercd == E_OK) { *ppk_msg = winfo.pk_msg; } } t_unlock_cpu(); return(ercd);}/* * メ〖ルボックスからの减慨∈ポ〖リング∷ */SYSCALL ERprcv_mbx(ID mbxid, T_MSG **ppk_msg){ MBXCB *mbxcb; ER ercd; CHECK_TSKCTX_UNL(); CHECK_MBXID(mbxid); mbxcb = get_mbxcb(mbxid); t_lock_cpu(); if (mbxcb->head != NULL) { *ppk_msg = mbxcb->head; mbxcb->head = (*ppk_msg)->next; ercd = E_OK; } else { ercd = E_TMOUT; } t_unlock_cpu(); return(ercd);}/* * メ〖ルボックスからの减慨∈タイムアウトあり∷ */SYSCALL ERtrcv_mbx(ID mbxid, T_MSG **ppk_msg, TMO tmout){ MBXCB *mbxcb; WINFO_MBX winfo; TMEVTB tmevtb; ER ercd; CHECK_DISPATCH(); CHECK_MBXID(mbxid); CHECK_TMOUT(tmout); mbxcb = get_mbxcb(mbxid); t_lock_cpu(); if (mbxcb->head != NULL) { *ppk_msg = mbxcb->head; mbxcb->head = (*ppk_msg)->next; ercd = E_OK; } else if (tmout == TMO_POL) { ercd = E_TMOUT; } else { wobj_make_wait_tmout((WOBJCB *) mbxcb, (WINFO_WOBJ *) &winfo, &tmevtb, tmout); dispatch(); ercd = winfo.winfo.wercd; if (ercd == E_OK) { *ppk_msg = winfo.pk_msg; } } t_unlock_cpu(); return(ercd);}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?