toppers edu jsp
https://qiita.com/kaizen_nagoya/items/5561df93c7e156573fd2
toppersedujsp/library/
https://github.com/kaizen-nagoya/toppersedujsp/tree/main/library
log_output.c
strerror.c
t_perror.c
vasyslog.c
log_output.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: log_output.c,v 1.5 2003/07/01 13:30:08 hiro Exp $
*/
/*
* システムログのフォーマット出力
*/
#include <t_services.h>
/*
* ポインタを格納できる整数型のデフォルトの定義
*/
#ifndef _intptr_
#define _intptr_ long
#endif /* _intptr_ */
/*
* 数値を文字列に変換
*/
static void
convert(unsigned _intptr_ val, unsigned int radix, const char *radchar,
int width, int minus, int padzero, void (*putc)(char))
{
char buf[12];
int i, j;
i = 0;
do {
buf[i++] = radchar[val % radix];
val /= radix;
} while (val != 0);
width -= minus;
if (minus > 0 && padzero > 0) {
(*putc)('-');
}
for (j = i; j < width; j++) {
(*putc)((char)(padzero > 0 ? '0' : ' '));
}
if (minus > 0 && padzero <= 0) {
(*putc)('-');
}
while (i > 0) {
(*putc)(buf[--i]);
}
}
/*
* ログ情報のフォーマット出力
*/
static char const raddec[] = "0123456789";
static char const radhex[] = "0123456789abcdef";
static char const radHEX[] = "0123456789ABCDEF";
void
syslog_printf(char *format, VP_INT *args, void (*putc)(char))
{
int c;
int width;
int padzero;
_intptr_ val;
char *str;
while ((c = *format++) != '\0') {
if (c != '%') {
(*putc)((char) c);
continue;
}
width = padzero = 0;
if ((c = *format++) == '0') {
padzero = 1;
c = *format++;
}
while ('0' <= c && c <= '9') {
width = width*10 + c - '0';
c = *format++;
}
switch (c) {
case 'd':
val = (_intptr_)(*args++);
if (val >= 0) {
convert((unsigned _intptr_) val, 10, raddec,
width, 0, padzero, putc);
}
else {
convert((unsigned _intptr_)(-val), 10, raddec,
width, 1, padzero, putc);
}
break;
case 'u':
val = (_intptr_)(*args++);
convert((unsigned _intptr_) val, 10, raddec,
width, 0, padzero, putc);
break;
case 'x':
case 'p':
val = (_intptr_)(*args++);
convert((unsigned _intptr_) val, 16, radhex,
width, 0, padzero, putc);
break;
case 'X':
val = (_intptr_)(*args++);
convert((unsigned _intptr_) val, 16, radHEX,
width, 0, padzero, putc);
break;
case 'c':
(*putc)((char)(_intptr_)(*args++));
break;
case 's':
str = (char *)(*args++);
while ((c = *str++) != '\0') {
(*putc)((char) c);
}
break;
case '%':
(*putc)('%');
break;
case '\0':
format--;
break;
default:
break;
}
}
putc('\n');
}
void
syslog_print(SYSLOG *p_log, void (*putc)(char))
{
switch (p_log->logtype) {
case LOG_TYPE_COMMENT:
syslog_printf((char *)(p_log->loginfo[0]),
&(p_log->loginfo[1]), putc);
break;
case LOG_TYPE_ASSERT:
syslog_printf("%s:%u: Assertion `%s' failed.",
&(p_log->loginfo[0]), putc);
break;
}
}
void
syslog_output(void (*putc)(char))
{
SYSLOG log;
char *lostmsg = "%d messages are lost.";
INT lostnum, n;
lostnum = 0;
while ((n = vrea_log(&log)) >= 0) {
lostnum += n;
if (log.logtype < LOG_TYPE_COMMENT) {
continue;
}
if (lostnum > 0) {
syslog_printf(lostmsg, (VP_INT *) &lostnum, putc);
lostnum = 0;
}
syslog_print(&log, putc);
}
if (lostnum > 0) {
syslog_printf(lostmsg, (VP_INT *) &lostnum, putc);
}
}
strerror.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: strerror.c,v 1.3 2003/06/04 01:47:08 hiro Exp $
*/
/*
* エラーメッセージ文字列を返す関数
*/
#include <t_services.h>
const char *
itron_strerror(ER ercd)
{
switch (MERCD(ercd)) {
case E_OK:
return("E_OK");
case E_SYS:
return("E_SYS");
case E_NOSPT:
return("E_NOSPT");
case E_RSFN:
return("E_RSFN");
case E_RSATR:
return("E_RSATR");
case E_PAR:
return("E_PAR");
case E_ID:
return("E_ID");
case E_CTX:
return("E_CTX");
case E_MACV:
return("E_MACV");
case E_OACV:
return("E_OACV");
case E_ILUSE:
return("E_ILUSE");
case E_NOMEM:
return("E_NOMEM");
case E_NOID:
return("E_NOID");
case E_OBJ:
return("E_OBJ");
case E_NOEXS:
return("E_NOEXS");
case E_QOVR:
return("E_QOVR");
case E_RLWAI:
return("E_RLWAI");
case E_TMOUT:
return("E_TMOUT");
case E_DLT:
return("E_DLT");
case E_CLS:
return("E_CLS");
case E_WBLK:
return("E_WBLK");
case E_BOVR:
return("E_BOVR");
default:
return("unknown error");
}
}
t_perror.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: t_perror.c,v 1.3 2003/06/04 01:47:08 hiro Exp $
*/
/*
* エラーメッセージの出力
*/
#include <t_services.h>
extern const char *itron_strerror(ER ercd);
void
t_perror(UINT prio, const char *file, int line, const char *expr, ER ercd)
{
syslog_4(prio, "%s reported by `%s' in line %d of `%s'.",
itron_strerror(ercd), expr, line, file);
}
vasyslog.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: vasyslog.c,v 1.4 2003/06/18 12:48:38 hiro Exp $
*/
/*
* 可変数引数のシステムログライブラリ
*/
#include <t_services.h>
#include <stdarg.h>
ER
syslog(UINT prio, const char *format, ...)
{
SYSLOG log;
va_list ap;
int i;
int c;
log.logtype = LOG_TYPE_COMMENT;
log.loginfo[0] = (VP_INT) format;
i = 1;
va_start(ap, format);
while ((c = *format++) != '\0' && i < TMAX_LOGINFO) {
if (c != '%') {
continue;
}
if ((c = *format++) == '0') {
c = *format++;
}
while ('0' <= c && c <= '9') {
c = *format++;
}
switch (c) {
case 'd':
log.loginfo[i++] = (VP_INT) va_arg(ap, int);
break;
case 'u':
case 'x':
case 'X':
log.loginfo[i++] = (VP_INT) va_arg(ap, unsigned int);
break;
case 'p':
log.loginfo[i++] = (VP_INT) va_arg(ap, void *);
break;
case 'c':
log.loginfo[i++] = (VP_INT) va_arg(ap, int);
break;
case 's':
log.loginfo[i++] = (VP_INT) va_arg(ap, char *);
break;
case '\0':
format--;
break;
default:
break;
}
}
va_end(ap);
return(vwri_log(prio, &log));
}