📄 task_manage.c
字号:
/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2000,2001 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_manage.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"/* * タスクの弹瓢 */SYSCALL ERact_tsk(ID tskid){ TCB *tcb; ER ercd; CHECK_TSKCTX_UNL(); CHECK_TSKID_SELF(tskid); tcb = get_tcb_self(tskid); t_lock_cpu(); if (TSTAT_DORMANT(tcb->tstat)) { if (make_active(tcb)) { dispatch(); } ercd = E_OK; } else if (!(tcb->actcnt)) { tcb->actcnt = TRUE; ercd = E_OK; } else { ercd = E_QOVR; } t_unlock_cpu(); return(ercd);}/* * タスクの弹瓢∈润タスクコンテキスト脱∷ */SYSCALL ERiact_tsk(ID tskid){ TCB *tcb; ER ercd; CHECK_INTCTX_UNL(); CHECK_TSKID(tskid); tcb = get_tcb(tskid); i_lock_cpu(); if (TSTAT_DORMANT(tcb->tstat)) { if (make_active(tcb)) { reqflg = TRUE; } ercd = E_OK; } else if (!(tcb->actcnt)) { tcb->actcnt = TRUE; ercd = E_OK; } else { ercd = E_QOVR; } i_unlock_cpu(); return(ercd);}/* * タスク弹瓢妥滇のキャンセル */SYSCALL ER_UINTcan_act(ID tskid){ TCB *tcb; ER_UINT actcnt; CHECK_TSKCTX_UNL(); CHECK_TSKID_SELF(tskid); tcb = get_tcb_self(tskid); t_lock_cpu(); actcnt = tcb->actcnt ? 1 : 0; tcb->actcnt = FALSE; t_unlock_cpu(); return(actcnt);}/* * 极タスクの姜位 */SYSCALL voidext_tsk(){#ifdef ACTIVATED_STACK_SIZE /* * create_context と activate_context で·蝗脱面のスタック挝 * 拌を撬蝉しないように·スタック惧にダミ〖挝拌を澄瘦するˉ */ (void) alloca(ACTIVATED_STACK_SIZE);#endif /* ACTIVATED_STACK_SIZE */ if (sense_context()) { /* * 润タスクコンテキストから ext_tsk が钙ばれた眷圭· * システムログにエラ〖を淡峡し·そのまま悸乖を鲁けるˉ * その冯蔡·动扩弄にタスクコンテキストに磊り垂えて· * 悸乖觉轮のタスクを姜位させることになるˉカ〖ネルは * そのまま悸乖を费鲁するが·タ〖ゲットによっては·润 * タスクコンテキスト脱のスタックにゴミが荒ったり·充 * 哈みハンドラのネスト眶の瓷妄に谭解が栏じたりする眷 * 圭があるˉ */ syslog_0(LOG_ALERT, "ext_tsk is called from non-task contexts."); } if (sense_lock()) { /* * CPUロック觉轮で ext_tsk が钙ばれた眷圭は·CPUロック * を豺近してからタスクを姜位するˉ悸刘惧は·サ〖ビス * コ〖ル柒でのCPUロックを臼维すればよいだけˉ */ syslog_0(LOG_WARNING, "ext_tsk is called from CPU locked state."); } else { if (sense_context()) { i_lock_cpu(); } else { t_lock_cpu(); } } if (!(enadsp)) { /* * ディスパッチ敦贿觉轮で ext_tsk が钙ばれた眷圭は· * ディスパッチ钓材觉轮にしてからタスクを姜位するˉ */ syslog_0(LOG_WARNING, "ext_tsk is called from dispatch disabled state."); enadsp = TRUE; } exit_task();}/* * タスクの动扩姜位 */SYSCALL ERter_tsk(ID tskid){ TCB *tcb; UINT tstat; ER ercd; CHECK_TSKCTX_UNL(); CHECK_TSKID(tskid); tcb = get_tcb(tskid); CHECK_NONSELF(tcb); t_lock_cpu(); if (TSTAT_DORMANT(tstat = tcb->tstat)) { ercd = E_OBJ; } else { if (TSTAT_RUNNABLE(tstat)) { make_non_runnable(tcb); } else if (TSTAT_WAITING(tstat)) { wait_cancel(tcb); } make_dormant(tcb); if (tcb->actcnt) { tcb->actcnt = FALSE; if (make_active(tcb)) { dispatch(); } } ercd = E_OK; } t_unlock_cpu(); return(ercd);}/* * タスク庭黎刨の恃构 */SYSCALL ERchg_pri(ID tskid, PRI tskpri){ TCB *tcb; UINT newpri; UINT tstat; ER ercd; CHECK_TSKCTX_UNL(); CHECK_TSKID_SELF(tskid); CHECK_TPRI_INI(tskpri); tcb = get_tcb_self(tskid); newpri = (tskpri == TPRI_INI) ? tcb->tinib->ipriority : INT_PRIORITY(tskpri); t_lock_cpu(); if (TSTAT_DORMANT(tstat = tcb->tstat)) { ercd = E_OBJ; } else if (TSTAT_RUNNABLE(tstat)) { if (change_priority(tcb, newpri)) { dispatch(); } ercd = E_OK; } else { tcb->priority = newpri; if ((tstat & TS_WAIT_WOBJCB) != 0) { wobj_change_priority(((WINFO_WOBJ *)(tcb->winfo)) ->wobjcb, tcb); } ercd = E_OK; } t_unlock_cpu(); return(ercd);}/* * タスク庭黎刨の徊救 */SYSCALL ERget_pri(ID tskid, PRI *p_tskpri){ TCB *tcb; ER ercd; CHECK_TSKCTX_UNL(); CHECK_TSKID_SELF(tskid); tcb = get_tcb_self(tskid); t_lock_cpu(); if (TSTAT_DORMANT(tcb->tstat)) { ercd = E_OBJ; } else { *p_tskpri = EXT_TSKPRI(tcb->priority); ercd = E_OK; } t_unlock_cpu(); return(ercd);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -