📄 sys_manage.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: sys_manage.c,v 1.8 2003/07/01 13:30:35 hiro Exp $
*/
/*
* 僔僗僥儉忬懺娗棟婡擻
*/
#include "jsp_kernel.h"
#include "check.h"
#include "task.h"
/*
* 僞僗僋偺桪愭弴埵偺夞揮
*/
#ifdef __rot_rdq
SYSCALL ER
rot_rdq(PRI tskpri)
{
UINT pri;
ER ercd;
LOG_ROT_RDQ_ENTER(tskpri);
CHECK_TSKCTX_UNL();
CHECK_TPRI_SELF(tskpri);
t_lock_cpu();
pri = (tskpri == TPRI_SELF) ? runtsk->priority : INT_PRIORITY(tskpri);
if (rotate_ready_queue(pri)) {
dispatch();
}
ercd = E_OK;
t_unlock_cpu();
exit:
LOG_ROT_RDQ_LEAVE(ercd);
return(ercd);
}
#endif /* __rot_rdq */
/*
* 僞僗僋偺桪愭弴埵偺夞揮乮旕僞僗僋僐儞僥僉僗僩梡乯
*/
#ifdef __irot_rdq
SYSCALL ER
irot_rdq(PRI tskpri)
{
ER ercd;
LOG_IROT_RDQ_ENTER(tskpri);
CHECK_INTCTX_UNL();
CHECK_TPRI(tskpri);
i_lock_cpu();
if (rotate_ready_queue(INT_PRIORITY(tskpri))) {
reqflg = TRUE;
}
ercd = E_OK;
i_unlock_cpu();
exit:
LOG_IROT_RDQ_LEAVE(ercd);
return(ercd);
}
#endif /* __irot_rdq */
/*
* 幚峴忬懺偺僞僗僋ID偺嶲徠
*/
#ifdef __get_tid
SYSCALL ER
get_tid(ID *p_tskid)
{
ER ercd;
LOG_GET_TID_ENTER(p_tskid);
CHECK_TSKCTX_UNL();
t_lock_cpu();
*p_tskid = TSKID(runtsk);
ercd = E_OK;
t_unlock_cpu();
exit:
LOG_GET_TID_LEAVE(ercd, *p_tskid);
return(ercd);
}
#endif /* __get_tid */
/*
* 幚峴忬懺偺僞僗僋ID偺嶲徠乮旕僞僗僋僐儞僥僉僗僩梡乯
*/
#ifdef __iget_tid
SYSCALL ER
iget_tid(ID *p_tskid)
{
ER ercd;
LOG_IGET_TID_ENTER(p_tskid);
CHECK_INTCTX_UNL();
i_lock_cpu();
*p_tskid = (runtsk == NULL) ? TSK_NONE : TSKID(runtsk);
ercd = E_OK;
i_unlock_cpu();
exit:
LOG_IGET_TID_LEAVE(ercd, *p_tskid);
return(ercd);
}
#endif /* __iget_tid */
/*
* CPU儘僢僋忬懺傊偺堏峴
*/
#ifdef __loc_cpu
SYSCALL ER
loc_cpu(void)
{
ER ercd;
LOG_LOC_CPU_ENTER();
CHECK_TSKCTX();
if (!(t_sense_lock())) {
t_lock_cpu();
}
ercd = E_OK;
exit:
LOG_LOC_CPU_LEAVE(ercd);
return(ercd);
}
#endif /* __loc_cpu */
/*
* CPU儘僢僋忬懺傊偺堏峴乮旕僞僗僋僐儞僥僉僗僩梡乯
*/
#ifdef __iloc_cpu
SYSCALL ER
iloc_cpu(void)
{
ER ercd;
LOG_ILOC_CPU_ENTER();
CHECK_INTCTX();
if (!(i_sense_lock())) {
i_lock_cpu();
}
ercd = E_OK;
exit:
LOG_ILOC_CPU_LEAVE(ercd);
return(ercd);
}
#endif /* __iloc_cpu */
/*
* CPU儘僢僋忬懺偺夝彍
*
* CPU儘僢僋拞偼丆僨傿僗僷僢僠偑昁梫偲側傞僒乕價僗僐乕儖傪屇傃弌偡偙
* 偲偼偱偒側偄偨傔丆CPU儘僢僋忬懺偺夝彍帪偵僨傿僗僷僢僠儍傪婲摦偡傞
* 昁梫偼側偄丏
*/
#ifdef __unl_cpu
SYSCALL ER
unl_cpu(void)
{
ER ercd;
LOG_UNL_CPU_ENTER();
CHECK_TSKCTX();
if (t_sense_lock()) {
t_unlock_cpu();
}
ercd = E_OK;
exit:
LOG_UNL_CPU_LEAVE(ercd);
return(ercd);
}
#endif /* __unl_cpu */
/*
* CPU儘僢僋忬懺偺夝彍乮旕僞僗僋僐儞僥僉僗僩梡乯
*
* CPU儘僢僋拞偼丆僨傿僗僷僢僠偑昁梫偲側傞僒乕價僗僐乕儖傪屇傃弌偡偙
* 偲偼偱偒側偄偨傔丆CPU儘僢僋忬懺偺夝彍帪偵僨傿僗僷僢僠儍偺婲摦傪梫
* 媮偡傞昁梫偼側偄丏
*/
#ifdef __iunl_cpu
SYSCALL ER
iunl_cpu(void)
{
ER ercd;
LOG_IUNL_CPU_ENTER();
CHECK_INTCTX();
if (i_sense_lock()) {
i_unlock_cpu();
}
ercd = E_OK;
exit:
LOG_IUNL_CPU_LEAVE(ercd);
return(ercd);
}
#endif /* __iunl_cpu */
/*
* 僨傿僗僷僢僠偺嬛巭
*/
#ifdef __dis_dsp
SYSCALL ER
dis_dsp(void)
{
ER ercd;
LOG_DIS_DSP_ENTER();
CHECK_TSKCTX_UNL();
t_lock_cpu();
enadsp = FALSE;
ercd = E_OK;
t_unlock_cpu();
exit:
LOG_DIS_DSP_LEAVE(ercd);
return(ercd);
}
#endif /* __dis_dsp */
/*
* 僨傿僗僷僢僠偺嫋壜
*/
#ifdef __ena_dsp
SYSCALL ER
ena_dsp(void)
{
ER ercd;
LOG_ENA_DSP_ENTER();
CHECK_TSKCTX_UNL();
t_lock_cpu();
enadsp = TRUE;
if (runtsk != schedtsk) {
dispatch();
}
ercd = E_OK;
t_unlock_cpu();
exit:
LOG_ENA_DSP_LEAVE(ercd);
return(ercd);
}
#endif /* __ena_dsp */
/*
* 僐儞僥僉僗僩偺嶲徠
*/
#ifdef __sns_ctx
SYSCALL BOOL
sns_ctx(void)
{
BOOL state;
LOG_SNS_CTX_ENTER();
state = sense_context() ? TRUE : FALSE;
LOG_SNS_CTX_LEAVE(state);
return(state);
}
#endif /* __sns_ctx */
/*
* CPU儘僢僋忬懺偺嶲徠
*/
#ifdef __sns_loc
SYSCALL BOOL
sns_loc(void)
{
BOOL state;
LOG_SNS_LOC_ENTER();
state = sense_lock() ? TRUE : FALSE;
LOG_SNS_LOC_LEAVE(state);
return(state);
}
#endif /* __sns_loc */
/*
* 僨傿僗僷僢僠嬛巭忬懺偺嶲徠
*/
#ifdef __sns_dsp
SYSCALL BOOL
sns_dsp(void)
{
BOOL state;
LOG_SNS_DSP_ENTER();
state = !(enadsp) ? TRUE : FALSE;
LOG_SNS_DSP_LEAVE(state);
return(state);
}
#endif /* __sns_dsp */
/*
* 僨傿僗僷僢僠曐棷忬懺偺嶲徠
*/
#ifdef __sns_dpn
SYSCALL BOOL
sns_dpn(void)
{
BOOL state;
LOG_SNS_DPN_ENTER();
state = (sense_context() || sense_lock() || !(enadsp)) ? TRUE : FALSE;
LOG_SNS_DPN_LEAVE(state);
return(state);
}
#endif /* __sns_dpn */
/*
* 僇乕僱儖摦嶌忬懺偺嶲徠
*/
#ifdef __vsns_ini
SYSCALL BOOL
vsns_ini(void)
{
BOOL state;
LOG_VSNS_INI_ENTER();
state = !(iniflg) ? TRUE : FALSE;
LOG_VSNS_INI_LEAVE(state);
return(state);
}
#endif /* __vsns_ini */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -