📄 eventlog.h
字号:
/*
* 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.h,v 1.4 2003/07/08 14:46:02 takayuki Exp $
*/
#ifndef __EVENTLOG_H__
#define __EVENTLOG_H__
#include "cpu_rename.h"
/* 儘僌弌椡惂屼梡僗儗僢僪儘乕僇儖僗僩儗乕僕 */
#define TLS_LOGMASK 0x00000001
#include "sys_defs.h"
#ifdef EVENTLOG_ENABLE
#include "itron.h"
#include <stdarg.h>
#include "syslog.h"
/*
* ITRON僨僶僢僊儞僌僀儞僞僼僃乕僗娭楢偺掕媊
*/
/*
* 僨傿僗僷僢僠庬暿
*/
#define DSP_NORMAL 0; //僞僗僋僐儞僥僉僗僩偐傜偺僨傿僗僷僢僠
#define DSP_NONTSKCTX 1; //妱崬傒張棟偍傛傃CPU椺奜偐傜偺僨傿僗僷僢僠
typedef W BITMASK;
typedef UINT INHNO;
/* 妱崬傒僴儞僪儔 */
typedef struct t_rglog_interrupt{
INHNO inhno; //妱崬傒僴儞僪儔斣崋
} T_RGLOG_INTERRUPT;
/* 妱崬傒僒乕價僗僴儞僪儔(枹巊梡) */
typedef struct t_rglog_isr {
ID isrid; //妱崬傒僒乕價僗儖乕僠儞ID
INHNO inhno; //妱崬傒僴儞僪儔斣崋
} T_RGLOG_ISR;
/* 僞僀儉僀儀儞僩僴儞僪儔 */
typedef struct t_rglog_timerhdr {
UINT type; //僞僀儅乕偺庬暿
ID hdrid; //僞僀儉僀儀儞僩僴儞僪儔偺ID
VP_INT exinf; //奼挘忣曬
} T_RGLOG_TIMERHDR;
/* CPU椺奜僴儞僪儔 */
typedef struct t_rglog_cupexc {
ID tskid; //懳徾偲側傞僞僗僋ID
} T_RGLOG_CPUEXC;
/* 僞僗僋椺奜張棟儖乕僠儞 */
typedef struct t_rglog_tskexc {
ID tskid; //懳徾偲側傞僞僗僋ID
} T_RGLOG_TSKEXC;
/* 僞僗僋忬懺曄壔 */
typedef struct t_rglog_tskstat {
ID tskid; //僞僗僋ID
STAT tskstat; //慗堏愭僞僗僋忬懺
STAT tskwait; //懸偪忬懺
ID wobjid; //懸偪懳徾偺僆僽僕僃僋僩ID
} T_RGLOG_TSKSTAT;
/* 僨傿僗僷僢僠儍奐巒 */
typedef struct t_rglog_dispatch_enter {
ID tskid; //僞僗僋ID
UINT disptype; //僨傿僗僷僢僠庬暿
} T_RGLOG_DISPATCH_ENTER;
/* 僨傿僗僷僢僠儍廔椆 */
typedef struct t_rglog_dispatch_leave {
ID tskid; //僞僗僋ID
} T_RGLOG_DISPATCH_LEAVE;
/* 僒乕價僗僐乕儖 */
typedef struct t_rglog_svc {
FN fncno; //婡擻僐乕僪
UINT prmcnt; //僷儔儊乕僞悢
VP_INT prmary[1]; //僷儔儊乕僞
} T_RGLOG_SVC;
/* 僐儊儞僩乮暥帤楍偺傒偺儘僌乯 */
typedef struct t_rglog_comment {
UINT length; //暥帤楍偺挿偝
char strtext[1]; //暥帤楍(NULL廔抂)-拞抐偁傝
} T_RGLOG_COMMENT;
typedef struct t_rglog_header {
UINT logtype;
SYSTIM logtim;
BITMASK valid;
UINT bufsz;
} T_RGLOG_HEADER;
typedef union t_rglog_body
{
T_RGLOG_INTERRUPT interrupt;
T_RGLOG_ISR isr;
T_RGLOG_TIMERHDR timerhdr;
T_RGLOG_CPUEXC cpuexc;
T_RGLOG_TSKEXC tskexc;
T_RGLOG_TSKSTAT tskstat;
T_RGLOG_DISPATCH_ENTER dispatch_enter;
T_RGLOG_DISPATCH_LEAVE dispatch_leave;
T_RGLOG_SVC svc;
T_RGLOG_COMMENT comment;
} T_RGLOG_BODY;
typedef struct DBIFLOG
{
struct t_rglog_header header;
union t_rglog_body body;
} DBIFLOG;
typedef struct t_rglog
{
UINT logtype;
SYSTIM logtim;
BITMASK valid;
UINT bufsz;
char buf[1];
} T_RGLOG;
#ifdef __cplusplus
#define EXTERN extern "C"
#else
#define EXTERN extern
#endif
EXTERN void event_write_syslog(const SYSLOG * str);
EXTERN void event_write(unsigned int logtype, unsigned int valid, UINT bufsz, ... );
EXTERN void event_write_svc_enter(int fncd, unsigned int params, ... );
EXTERN void event_write_svc_leave(int fncd, unsigned int ercd, unsigned int retaddr);
EXTERN void event_write_wait_unknown(int tskid);
#undef EXTERN
#endif //EVENTLOG_ENABLE
#endif //__EVENTLOG_H__
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -