📄 eventlog.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: eventlog.c,v 1.5 2003/07/08 14:46:02 takayuki Exp $
*/
#include "sys_defs.h"
#ifdef EVENTLOG_ENABLE
#include "jsp_kernel.h"
#include "task.h"
#include "semaphore.h"
#include "dataqueue.h"
#include "eventflag.h"
#include "mempfix.h"
#include "mailbox.h"
#include "eventlog.h"
#include <t_services.h>
extern SEMCB semcb_table[1];
extern UINT tmax_semid;
extern FLGCB flgcb_table[1];
extern UINT tmax_flgid;
extern DTQCB dtqcb_table[1];
extern UINT tmax_dtqid;
extern MBXCB mbxcb_table[1];
extern UINT tmax_mbxid;
extern MPFCB mpfcb_table[1];
extern UINT tmax_mpfid;
/*
* 僀儀儞僩儘僌弌椡梡 僞僗僋忬懺庢摼娭悢
* (com_support.c偼C++偵側傞偺偱丄偙偙偵抲偔)
*/
Inline BOOL is_inside_of(void * src, void * min, void * sup)
{ return ((long)src >= (long)min) && ((long)src < (long)sup); }
static void decode_waitstatus(TCB * tcb, unsigned int * objtype, int * objid)
{
QUEUE * queue;
if((tcb->tstat & TS_WAIT_SLEEP) != 0)
{
*objtype = TTW_SLP;
}else
{
if((tcb->tstat & TS_WAIT_WOBJCB) != 0)
{
do {
queue = tcb->task_queue.next;
} while( queue != &tcb->task_queue && is_inside_of(queue, tcb_table, &tcb_table[TNUM_TSK]) );
if(queue == &tcb->task_queue)
*objtype = 0;
/* 僙儅僼僅 */
else if(is_inside_of(queue, semcb_table, &semcb_table[tmax_semid-1]))
{
*objtype = TTW_SEM;
*objid = ((long)queue - (long)semcb_table) / sizeof(SEMCB) + 1;
}
/* 僀儀儞僩僼儔僌 */
else if(is_inside_of(queue, flgcb_table, &flgcb_table[tmax_flgid-1]))
{
*objtype = TTW_FLG;
*objid = ((long)queue - (long)flgcb_table) / sizeof(FLGCB) + 1;
}
/* 僨乕僞僉儏乕 */
else if(is_inside_of(queue, dtqcb_table, &dtqcb_table[tmax_dtqid-1]))
{
if(((long)queue % sizeof(DTQCB)) == (long)(&((DTQCB *)0)->rwait_queue))
*objtype = TTW_RDTQ;
else
*objtype = TTW_SDTQ;
*objid = ((long)queue - (long)dtqcb_table) / sizeof(DTQCB) + 1;
}
/* 儊乕儖儃僢僋僗 */
else if(is_inside_of(queue, mbxcb_table, &mbxcb_table[tmax_mbxid-1]))
{
*objtype = TTW_MBX;
*objid = ((long)queue - (long)mbxcb_table) / sizeof(MBXCB) + 1;
}
/* 屌掕挿儊儌儕僾乕儖 */
else if(is_inside_of(queue, mpfcb_table, &mpfcb_table[tmax_mpfid-1]))
{
*objtype = TTW_MPL;
*objid = ((long)queue - (long)mpfcb_table) / sizeof(MPFCB) + 1;
}
}else
{
/* slp_tsk偱偼側偔丄僆僽僕僃僋僩懸偪僉儏乕偵偮側偑傟偰偄側偄僞僀儉傾僂僩晅偒偺懸偪 -> dly_tsk */
if(tcb->winfo->tmevtb != NULL)
*objtype = TTW_DLY;
}
}
}
void decode_taskstatus(TCB * tcb, int * tskid, unsigned int * tskstat, unsigned int * objtype, int * objid)
{
int stat = tcb->tstat;
/* 僞僗僋ID */
*tskid = TSKID(tcb);
/* 僞僗僋忬懺 */
*tskstat = TTS_DMT;
if((stat & TS_RUNNABLE) != 0)
{
*tskstat = TTS_RDY;
}else
{
if((stat & TS_WAITING) != 0)
{
/* 懸偪忣曬偺僨僐乕僪 */
decode_waitstatus((TCB *)tcb, objtype, objid);
if((stat & TS_SUSPENDED) != 0)
*tskstat = TTS_WAS;
else
*tskstat = TTS_WAI;
}else
{
if((stat & TS_SUSPENDED) != 0)
*tskstat = TTS_SUS;
}
}
}
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -