📄 wait.c
字号:
/*
* TOPPERS/JSP Kernel
* Toyohashi Open Platform for Embedded Real-Time Systems/
* Just Standard Profile Kernel
*
* Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
* Toyohashi Univ. of Technology, JAPAN
*
* 忋婰挊嶌尃幰偼丆埲壓偺 (1)乣(4) 偺忦審偐丆Free Software Foundation
* 偵傛偭偰岞昞偝傟偰偄傞 GNU General Public License 偺 Version 2 偵婰
* 弎偝傟偰偄傞忦審傪枮偨偡応崌偵尷傝丆杮僜僼僩僂僃傾乮杮僜僼僩僂僃傾
* 傪夵曄偟偨傕偺傪娷傓丏埲壓摨偠乯傪巊梡丒暋惢丒夵曄丒嵞攝晍乮埲壓丆
* 棙梡偲屇傇乯偡傞偙偲傪柍彏偱嫋戻偡傞丏
* (1) 杮僜僼僩僂僃傾傪僜乕僗僐乕僪偺宍偱棙梡偡傞応崌偵偼丆忋婰偺挊嶌
* 尃昞帵丆偙偺棙梡忦審偍傛傃壓婰偺柍曐徹婯掕偑丆偦偺傑傑偺宍偱僜乕
* 僗僐乕僪拞偵娷傑傟偰偄傞偙偲丏
* (2) 杮僜僼僩僂僃傾傪丆儔僀僽儔儕宍幃側偳丆懠偺僜僼僩僂僃傾奐敪偵巊
* 梡偱偒傞宍偱嵞攝晍偡傞応崌偵偼丆嵞攝晍偵敽偆僪僉儏儊儞僩乮棙梡
* 幰儅僯儏傾儖側偳乯偵丆忋婰偺挊嶌尃昞帵丆偙偺棙梡忦審偍傛傃壓婰
* 偺柍曐徹婯掕傪宖嵹偡傞偙偲丏
* (3) 杮僜僼僩僂僃傾傪丆婡婍偵慻傒崬傓側偳丆懠偺僜僼僩僂僃傾奐敪偵巊
* 梡偱偒側偄宍偱嵞攝晍偡傞応崌偵偼丆師偺偄偢傟偐偺忦審傪枮偨偡偙
* 偲丏
* (a) 嵞攝晍偵敽偆僪僉儏儊儞僩乮棙梡幰儅僯儏傾儖側偳乯偵丆忋婰偺挊
* 嶌尃昞帵丆偙偺棙梡忦審偍傛傃壓婰偺柍曐徹婯掕傪宖嵹偡傞偙偲丏
* (b) 嵞攝晍偺宍懺傪丆暿偵掕傔傞曽朄偵傛偭偰丆TOPPERS僾儘僕僃僋僩偵
* 曬崘偡傞偙偲丏
* (4) 杮僜僼僩僂僃傾偺棙梡偵傛傝捈愙揑傑偨偼娫愙揑偵惗偠傞偄偐側傞懝
* 奞偐傜傕丆忋婰挊嶌尃幰偍傛傃TOPPERS僾儘僕僃僋僩傪柶愑偡傞偙偲丏
*
* 杮僜僼僩僂僃傾偼丆柍曐徹偱採嫙偝傟偰偄傞傕偺偱偁傞丏忋婰挊嶌尃幰偍
* 傛傃TOPPERS僾儘僕僃僋僩偼丆杮僜僼僩僂僃傾偵娭偟偰丆偦偺揔梡壜擻惈傕
* 娷傔偰丆偄偐側傞曐徹傕峴傢側偄丏傑偨丆杮僜僼僩僂僃傾偺棙梡偵傛傝捈
* 愙揑傑偨偼娫愙揑偵惗偠偨偄偐側傞懝奞偵娭偟偰傕丆偦偺愑擟傪晧傢側偄丏
*
* @(#) $Id: wait.c,v 1.6 2003/06/04 01:46:16 hiro Exp $
*/
/*
* 懸偪忬懺娗棟儌僕儏乕儖
*/
#include "jsp_kernel.h"
#include "wait.h"
/*
* 懸偪忬懺傊偺堏峴乮僞僀儉傾僂僩巜掕乯
*
*/
#ifdef __waimake
void
make_wait_tmout(WINFO *winfo, TMEVTB *tmevtb, TMO tmout)
{
make_non_runnable(runtsk);
runtsk->winfo = winfo;
if (tmout > 0) {
winfo->tmevtb = tmevtb;
tmevtb_enqueue(tmevtb, (RELTIM) tmout,
(CBACK) wait_tmout, (VP) runtsk);
}
else {
assert(tmout == TMO_FEVR);
winfo->tmevtb = NULL;
}
}
#endif /* __waimake */
/*
* 懸偪夝彍偺偨傔偺僞僗僋忬懺偺峏怴
*
* tcb 偱巜掕偝傟傞僞僗僋傪丆懸偪夝彍偡傞傛偆僞僗僋忬懺傪峏怴偡傞丏懸
* 偪夝彍偡傞僞僗僋偑幚峴偱偒傞忬懺偵側傞応崌偼丆儗僨傿僉儏乕偵偮側偖丏
* 傑偨丆僨傿僗僷僢僠偑昁梫側応崌偵偼 TRUE 傪曉偡丏
*/
Inline BOOL
make_non_wait(TCB *tcb)
{
assert(TSTAT_WAITING(tcb->tstat));
if (!(TSTAT_SUSPENDED(tcb->tstat))) {
/*
* 懸偪忬懺偐傜幚峴偱偒傞忬懺傊偺慗堏
*/
return(make_runnable(tcb));
}
else {
/*
* 擇廳懸偪忬懺偐傜嫮惂懸偪忬懺傊偺慗堏
*/
tcb->tstat = TS_SUSPENDED;
LOG_TSKSTAT(tcb);
return(FALSE);
}
}
/*
* 懸偪夝彍
*/
#ifdef __waicmp
BOOL
wait_complete(TCB *tcb)
{
if (tcb->winfo->tmevtb != NULL) {
tmevtb_dequeue(tcb->winfo->tmevtb);
}
tcb->winfo->wercd = E_OK;
return(make_non_wait(tcb));
}
#endif /* __waicmp */
/*
* 僞僀儉傾僂僩偵敽偆懸偪夝彍
*/
#ifdef __waitmo
void
wait_tmout(TCB *tcb)
{
if ((tcb->tstat & TS_WAIT_WOBJ) != 0) {
queue_delete(&(tcb->task_queue));
}
tcb->winfo->wercd = E_TMOUT;
if (make_non_wait(tcb)) {
reqflg = TRUE;
}
}
#endif /* __waitmo */
#ifdef __waitmook
void
wait_tmout_ok(TCB *tcb)
{
tcb->winfo->wercd = E_OK;
if (make_non_wait(tcb)) {
reqflg = TRUE;
}
}
#endif /* __waitmook */
/*
* 懸偪忬懺偺嫮惂夝彍
*/
#ifdef __waican
void
wait_cancel(TCB *tcb)
{
if (tcb->winfo->tmevtb != NULL) {
tmevtb_dequeue(tcb->winfo->tmevtb);
}
if ((tcb->tstat & TS_WAIT_WOBJ) != 0) {
queue_delete(&(tcb->task_queue));
}
}
#endif /* __waican */
#ifdef __wairel
BOOL
wait_release(TCB *tcb)
{
wait_cancel(tcb);
tcb->winfo->wercd = E_RLWAI;
return(make_non_wait(tcb));
}
#endif /* __wairel */
/*
* 僞僗僋偺桪愭搙弴偺懸偪僉儏乕傊偺憓擖
*/
Inline void
queue_insert_tpri(TCB *tcb, QUEUE *queue)
{
QUEUE *entry;
UINT priority = tcb->priority;
for (entry = queue->next; entry != queue; entry = entry->next) {
if (priority < ((TCB *) entry)->priority) {
break;
}
}
queue_insert_prev(entry, &(tcb->task_queue));
}
/*
* 幚峴拞偺僞僗僋偺摨婜丒捠怣僆僽僕僃僋僩偺懸偪僉儏乕傊偺憓擖
*/
Inline void
wobj_queue_insert(WOBJCB *wobjcb)
{
if ((wobjcb->wobjinib->wobjatr & TA_TPRI) != 0) {
queue_insert_tpri(runtsk, &(wobjcb->wait_queue));
}
else {
queue_insert_prev(&(wobjcb->wait_queue),
&(runtsk->task_queue));
}
}
/*
* 摨婜丒捠怣僆僽僕僃僋僩偵懳偡傞懸偪忬懺傊偺堏峴
*/
#ifdef __wobjwai
void
wobj_make_wait(WOBJCB *wobjcb, WINFO_WOBJ *winfo)
{
runtsk->tstat = (TS_WAITING | TS_WAIT_WOBJ | TS_WAIT_WOBJCB);
make_wait(&(winfo->winfo));
wobj_queue_insert(wobjcb);
winfo->wobjcb = wobjcb;
LOG_TSKSTAT(runtsk);
}
#endif /* __wobjwai */
#ifdef __wobjwaitmo
void
wobj_make_wait_tmout(WOBJCB *wobjcb, WINFO_WOBJ *winfo,
TMEVTB *tmevtb, TMO tmout)
{
runtsk->tstat = (TS_WAITING | TS_WAIT_WOBJ | TS_WAIT_WOBJCB);
make_wait_tmout(&(winfo->winfo), tmevtb, tmout);
wobj_queue_insert(wobjcb);
winfo->wobjcb = wobjcb;
LOG_TSKSTAT(runtsk);
}
#endif /* __wobjwaitmo */
/*
* 僞僗僋偺桪愭搙曄峏帪偺張棟
*/
#ifdef __wobjpri
void
wobj_change_priority(WOBJCB *wobjcb, TCB *tcb)
{
if ((wobjcb->wobjinib->wobjatr & TA_TPRI) != 0) {
queue_delete(&(tcb->task_queue));
queue_insert_tpri(tcb, &(wobjcb->wait_queue));
}
}
#endif /* __wobjpri */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -