📄 tool_config.h
字号:
/*
* TOPPERS/JSP Kernel
* Toyohashi Open Platform for Embedded Real-Time Systems/
* Just Standard Profile Kernel
*
* Copyright (C) 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: tool_config.h,v 1.5 2003/07/08 14:46:02 takayuki Exp $
*/
/*
* 奐敪娐嫬埶懚儌僕儏乕儖
*/
#ifndef _TOOL_CONFIG_H_
#define _TOOL_CONFIG_H_
#include "cpu_rename.h"
#include "sys_defs.h"
#include <kernel_debug.h>
#ifndef _MACRO_ONLY
#ifdef EVENTLOG_ENABLE
#ifdef __cplusplus
extern "C" void event_write(unsigned int logtype, unsigned int valid, UINT bufsz, ... );
extern "C" void event_write_svc_enter(int fncd, unsigned int params, ... );
extern "C" void event_write_svc_leave(int fncd, unsigned int ercd);
extern "C" void event_write_tskstat(void * tcb);
#else
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_tskstat(void * tcb);
#endif
/*
* 栠傝斣抧庢摼儅僋儘
*/
#define GET_RETURNADDRESS(x) __asm { mov eax, dword ptr [ebp + 4] } __asm { mov dword ptr [x], eax }
#define LOG_SVC_ENTER(x) { DWORD address; GET_RETURNADDRESS(address); event_write_svc_enter x; }
#define LOG_SVC_LEAVE(x) { DWORD address; GET_RETURNADDRESS(address); event_write_svc_leave x; }
#else
#define event_write /##/
#define event_write_tskstat /##/
#define LOG_SVC_ENTER(x)
#define LOG_SVC_LEAVE(x)
#endif
#endif
/*
* 僩儗乕僗儘僌偺愝掕
*/
#define LOG_INH_ENTER(inhno) event_write(LOG_TYPE_INH|LOG_ENTER, 0x1, sizeof(int), (int)(inhno));
#define LOG_INH_LEAVE(inhno) event_write(LOG_TYPE_INH|LOG_LEAVE, 0x1, sizeof(int), (int)(inhno));
#define LOG_ISR_ENTER(intno)
#define LOG_ISR_LEAVE(intno)
#define LOG_CYC_ENTER(cyccb) event_write(LOG_TYPE_CYC|LOG_ENTER, 0x7, sizeof(int)*3, OBJ_CYCLICHANDLER,(int)((cyccb) - cyccb_table)+1,(unsigned int)(cyccb)->cycinib->exinf);
#define LOG_CYC_LEAVE(cyccb) event_write(LOG_TYPE_CYC|LOG_LEAVE, 0x7, sizeof(int)*3, OBJ_CYCLICHANDLER,(int)((cyccb) - cyccb_table)+1,(unsigned int)(cyccb)->cycinib->exinf);
#define LOG_EXC_ENTER(excno) event_write(LOG_TYPE_EXC|LOG_ENTER, 0x1, sizeof(int), (int)(excno));
#define LOG_EXC_LEAVE(excno) event_write(LOG_TYPE_EXC|LOG_LEAVE, 0x1, sizeof(int), (int)(excno));
#define LOG_TEX_ENTER(texptn) event_write(LOG_TYPE_TEX|LOG_ENTER, 0x3, sizeof(int)*2, (int)TSKID(runtsk), (int)(texptn));
#define LOG_TEX_LEAVE(texptn) event_write(LOG_TYPE_TEX|LOG_LEAVE, 0x3, sizeof(int)*2, (int)TSKID(runtsk), (int)(texptn));
#define LOG_TSKSTAT(tcb) event_write_tskstat(tcb);
#define LOG_DSP_ENTER_INT(tcb) event_write(LOG_TYPE_DSP|LOG_ENTER, 0x1, sizeof(int)*2, TSKID(tcb),1);
#define LOG_DSP_ENTER_TSK(tcb) event_write(LOG_TYPE_DSP|LOG_ENTER, 0x1, sizeof(int)*2, TSKID(tcb),0);
#define LOG_DSP_LEAVE(tcb) event_write(LOG_TYPE_DSP|LOG_LEAVE, 0x1, sizeof(int), TSKID(tcb));
#define LOG_ACT_TSK_ENTER(tskid) LOG_SVC_ENTER((TFN_ACT_TSK, 1, tskid, address))
#define LOG_ACT_TSK_LEAVE(ercd) LOG_SVC_LEAVE((TFN_ACT_TSK, ercd, address))
#define LOG_IACT_TSK_ENTER(tskid) LOG_SVC_ENTER((TFN_IACT_TSK, 1, tskid, address))
#define LOG_IACT_TSK_LEAVE(ercd) LOG_SVC_LEAVE((TFN_IACT_TSK, ercd, address))
#define LOG_CAN_ACT_ENTER(tskid) LOG_SVC_ENTER((TFN_CAN_ACT, 1, tskid, address))
#define LOG_CAN_ACT_LEAVE(ercd) LOG_SVC_LEAVE((TFN_CAN_ACT, ercd, address))
#define LOG_EXT_TSK_ENTER() LOG_SVC_ENTER((TFN_EXT_TSK, 0, address))
#define LOG_TER_TSK_ENTER(tskid) LOG_SVC_ENTER((TFN_TER_TSK, 1, tskid, address))
#define LOG_TER_TSK_LEAVE(ercd) LOG_SVC_LEAVE((TFN_TER_TSK, ercd, address))
#define LOG_CHG_PRI_ENTER(tskid, tskpri) LOG_SVC_ENTER((TFN_CHG_PRI, 2, tskid, tskpri, address))
#define LOG_CHG_PRI_LEAVE(ercd) LOG_SVC_LEAVE((TFN_CHG_PRI, ercd, address))
#define LOG_GET_PRI_ENTER(tskid, p_tskpri) LOG_SVC_ENTER((TFN_GET_PRI, 2, tskid, p_tskpri, address))
#define LOG_GET_PRI_LEAVE(ercd, tskpri) LOG_SVC_LEAVE((TFN_GET_PRI, ercd, address))
#define LOG_SLP_TSK_ENTER() LOG_SVC_ENTER((TFN_SLP_TSK, 0, address))
#define LOG_SLP_TSK_LEAVE(ercd) LOG_SVC_LEAVE((TFN_SLP_TSK, ercd, address))
#define LOG_TSLP_TSK_ENTER(tmout) LOG_SVC_ENTER((TFN_TSLP_TSK, 1, tmout, address))
#define LOG_TSLP_TSK_LEAVE(ercd) LOG_SVC_LEAVE((TFN_TSLP_TSK, ercd, address))
#define LOG_WUP_TSK_ENTER(tskid) LOG_SVC_ENTER((TFN_WUP_TSK, 1, tskid, address))
#define LOG_WUP_TSK_LEAVE(ercd) LOG_SVC_LEAVE((TFN_WUP_TSK, ercd, address))
#define LOG_IWUP_TSK_ENTER(tskid) LOG_SVC_ENTER((TFN_IWUP_TSK, 1, tskid, address))
#define LOG_IWUP_TSK_LEAVE(ercd) LOG_SVC_LEAVE((TFN_IWUP_TSK, ercd, address))
#define LOG_CAN_WUP_ENTER(tskid) LOG_SVC_ENTER((TFN_CAN_WUP, 1, tskid, address))
#define LOG_CAN_WUP_LEAVE(ercd) LOG_SVC_LEAVE((TFN_CAN_WUP, ercd, address))
#define LOG_REL_WAI_ENTER(tskid) LOG_SVC_ENTER((TFN_REL_WAI, 1, tskid, address))
#define LOG_REL_WAI_LEAVE(ercd) LOG_SVC_LEAVE((TFN_REL_WAI, ercd, address))
#define LOG_IREL_WAI_ENTER(tskid) LOG_SVC_ENTER((TFN_IREL_WAI, 1, tskid, address))
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -