OSDN Git Service

5d85bb5aa1ceccb8f28cdc1f99bab05b3c98ce1a
[trx-305dsp/dsp.git] / hirado / kernel / library / vasyslog.c
1 /*
2  *  TOPPERS/JSP Kernel
3  *      Toyohashi Open Platform for Embedded Real-Time Systems/
4  *      Just Standard Profile Kernel
5  * 
6  *  Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7  *                              Toyohashi Univ. of Technology, JAPAN
8  *  Copyright (C) 2004-2005 by Embedded and Real-Time Systems Laboratory
9  *              Graduate School of Information Science, Nagoya Univ., JAPAN
10  * 
11  *  上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation 
12  *  によって公表されている GNU General Public License の Version 2 に記
13  *  述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
14  *  を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
15  *  利用と呼ぶ)することを無償で許諾する.
16  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
17  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
18  *      スコード中に含まれていること.
19  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
20  *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
21  *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
22  *      の無保証規定を掲載すること.
23  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
24  *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
25  *      と.
26  *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
27  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
28  *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
29  *        報告すること.
30  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
31  *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
32  * 
33  *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
34  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
35  *  含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
36  *  接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
37  * 
38  *  @(#) $Id: vasyslog.c,v 1.1 2009/01/31 05:27:37 suikan Exp $
39  */
40
41 /*
42  *  可変数引数のシステムログライブラリ
43  */
44
45 #include <t_services.h>
46 #include <stdarg.h>
47
48 ER
49 syslog(UINT prio, const char *format, ...)
50 {
51     SYSLOG  log;
52     va_list ap;
53     int i;
54     int c;
55     BOOL    lflag;
56
57     log.logtype = LOG_TYPE_COMMENT;
58     log.loginfo[0] = (VP_INT) format;
59     i = 1;
60     va_start(ap, format);
61
62     while ((c = *format++) != '\0' && i < TMAX_LOGINFO) {
63         if (c != '%') {
64             continue;
65         }
66
67         lflag = FALSE;
68         c = *format++;
69         while ('0' <= c && c <= '9') {
70             c = *format++;
71         }
72         if (c == 'l') {
73             lflag = TRUE;
74             c = *format++;
75         }
76         switch (c) {
77         case 'd':
78             log.loginfo[i++] = lflag ?
79                     (VP_INT) va_arg(ap, long) :
80                     (VP_INT) va_arg(ap, int);
81             break;
82         case 'u':
83         case 'x':
84         case 'X':
85             log.loginfo[i++] = lflag ?
86                     (VP_INT) va_arg(ap, unsigned long) :
87                     (VP_INT) va_arg(ap, unsigned int);
88             break;
89         case 'p':
90             log.loginfo[i++] = (VP_INT) va_arg(ap, void *);
91             break;
92         case 'c':
93             log.loginfo[i++] = (VP_INT) va_arg(ap, int);
94             break;
95         case 's':
96             log.loginfo[i++] = (VP_INT) va_arg(ap, const char *);
97             break;
98         case '\0':
99             format--;
100             break;
101         default:
102             break;
103         }
104     }
105     va_end(ap);
106     return(vwri_log(prio, &log));
107 }