📄 task_sync.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: task_sync.c,v 1.3 2002/03/26 08:19:38 hiro Exp $ *//* * タスク烧掳票袋怠墙 */#include "jsp_kernel.h"#include "check.h"#include "task.h"#include "wait.h"/* * 弹静略ち */SYSCALL ERslp_tsk(){ WINFO winfo; ER ercd; CHECK_DISPATCH(); t_lock_cpu(); if (runtsk->wupcnt) { runtsk->wupcnt = FALSE; ercd = E_OK; } else { runtsk->tstat = (TS_WAITING | TS_WAIT_SLEEP); make_wait(&winfo); dispatch(); ercd = winfo.wercd; } t_unlock_cpu(); return(ercd);}/* * 弹静略ち∈タイムアウトあり∷ */SYSCALL ERtslp_tsk(TMO tmout){ WINFO winfo; TMEVTB tmevtb; ER ercd; CHECK_DISPATCH(); CHECK_TMOUT(tmout); t_lock_cpu(); if (runtsk->wupcnt) { runtsk->wupcnt = FALSE; ercd = E_OK; } else if (tmout == TMO_POL) { ercd = E_TMOUT; } else { runtsk->tstat = (TS_WAITING | TS_WAIT_SLEEP); make_wait_tmout(&winfo, &tmevtb, tmout); dispatch(); ercd = winfo.wercd; } t_unlock_cpu(); return(ercd);}/* * タスクの弹静 */SYSCALL ERwup_tsk(ID tskid){ TCB *tcb; UINT tstat; ER ercd; CHECK_TSKCTX_UNL(); CHECK_TSKID_SELF(tskid); tcb = get_tcb_self(tskid); t_lock_cpu(); if (TSTAT_DORMANT(tstat = tcb->tstat)) { ercd = E_OBJ; } else if ((tstat & TS_WAIT_SLEEP) != 0) { if (wait_complete(tcb)) { dispatch(); } ercd = E_OK; } else if (!(tcb->wupcnt)) { tcb->wupcnt = TRUE; ercd = E_OK; } else { ercd = E_QOVR; } t_unlock_cpu(); return(ercd);}/* * タスクの弹静∈润タスクコンテキスト脱∷ */SYSCALL ERiwup_tsk(ID tskid){ TCB *tcb; UINT tstat; ER ercd; CHECK_INTCTX_UNL(); CHECK_TSKID(tskid); tcb = get_tcb(tskid); i_lock_cpu(); if (TSTAT_DORMANT(tstat = tcb->tstat)) { ercd = E_OBJ; } else if ((tstat & TS_WAIT_SLEEP) != 0) { if (wait_complete(tcb)) { reqflg = TRUE; } ercd = E_OK; } else if (!(tcb->wupcnt)) { tcb->wupcnt = TRUE; ercd = E_OK; } else { ercd = E_QOVR; } i_unlock_cpu(); return(ercd);}/* * タスク弹静妥滇のキャンセル */SYSCALL ER_UINTcan_wup(ID tskid){ TCB *tcb; ER_UINT wupcnt; CHECK_TSKCTX_UNL(); CHECK_TSKID_SELF(tskid); tcb = get_tcb_self(tskid); t_lock_cpu(); if (TSTAT_DORMANT(tcb->tstat)) { wupcnt = E_OBJ; } else { wupcnt = tcb->wupcnt ? 1 : 0; tcb->wupcnt = FALSE; } t_unlock_cpu(); return(wupcnt);}/* * 略ち觉轮の动扩豺近 */SYSCALL ERrel_wai(ID tskid){ TCB *tcb; ER ercd; CHECK_TSKCTX_UNL(); CHECK_TSKID(tskid); tcb = get_tcb(tskid); t_lock_cpu(); if (!(TSTAT_WAITING(tcb->tstat))) { ercd = E_OBJ; } else { if (wait_release(tcb)) { dispatch(); } ercd = E_OK; } t_unlock_cpu(); return(ercd);}/* * 略ち觉轮の动扩豺近∈润タスクコンテキスト脱∷ */SYSCALL ERirel_wai(ID tskid){ TCB *tcb; ER ercd; CHECK_INTCTX_UNL(); CHECK_TSKID(tskid); tcb = get_tcb(tskid); i_lock_cpu(); if (!(TSTAT_WAITING(tcb->tstat))) { ercd = E_OBJ; } else { if (wait_release(tcb)) { reqflg = TRUE; } ercd = E_OK; } i_unlock_cpu(); return(ercd);}/* * 动扩略ち觉轮への败乖 */SYSCALL ERsus_tsk(ID tskid){ TCB *tcb; UINT tstat; ER ercd; CHECK_TSKCTX_UNL(); CHECK_TSKID_SELF(tskid); tcb = get_tcb_self(tskid); t_lock_cpu(); if (tcb == runtsk && !(enadsp)) { ercd = E_CTX; } else if (TSTAT_DORMANT(tstat = tcb->tstat)) { ercd = E_OBJ; } else if (TSTAT_RUNNABLE(tstat)) { /* * 悸乖できる觉轮から动扩略ち觉轮への莲败 */ tcb->tstat = TS_SUSPENDED; if (make_non_runnable(tcb)) { dispatch(); } ercd = E_OK; } else if (TSTAT_SUSPENDED(tstat)) { ercd = E_QOVR; } else { /* * 略ち觉轮から企脚略ち觉轮への莲败 */ tcb->tstat |= TS_SUSPENDED; ercd = E_OK; } t_unlock_cpu(); return(ercd);}/* * 动扩略ち觉轮からの浩倡 */SYSCALL ERrsm_tsk(ID tskid){ TCB *tcb; UINT tstat; ER ercd; CHECK_TSKCTX_UNL(); CHECK_TSKID(tskid); tcb = get_tcb(tskid); t_lock_cpu(); if (!(TSTAT_SUSPENDED(tstat = tcb->tstat))) { ercd = E_OBJ; } else if (!(TSTAT_WAITING(tstat))) { /* * 动扩略ち觉轮から悸乖できる觉轮への莲败 */ if (make_runnable(tcb)) { dispatch(); } ercd = E_OK; } else { /* * 企脚略ち觉轮から略ち觉轮への莲败 */ tcb->tstat &= ~TS_SUSPENDED; ercd = E_OK; } t_unlock_cpu(); return(ercd);}/* * 动扩略ち觉轮からの动扩浩倡 * * JSPカ〖ネルでは·frsm_tsk と rsm_tsk は票办の借妄となるˉ */#ifdef LABEL_ALIASLABEL_ALIAS(frsm_tsk, rsm_tsk)#else /* LABEL_ALIAS */SYSCALL ERfrsm_tsk(ID tskid){ return(rsm_tsk(tskid));}#endif /* LABEL_ALIAS *//* * 极タスクの觅变 */SYSCALL ERdly_tsk(RELTIM dlytim){ WINFO winfo; TMEVTB tmevtb; CHECK_DISPATCH(); CHECK_PAR(dlytim <= TMAX_RELTIM); t_lock_cpu(); runtsk->tstat = TS_WAITING; make_non_runnable(runtsk); runtsk->winfo = &winfo; winfo.tmevtb = &tmevtb; tmevtb_enqueue(&tmevtb, dlytim, (CBACK) wait_tmout_ok, (VP) runtsk); dispatch(); t_unlock_cpu(); return(winfo.wercd);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -