source: atk2-sc3-1.4.0-ntisr/sysmod/syslog.c

Last change on this file was 172, checked in by ertl-ishikawa, 8 years ago

ATK2-SC3 1.4.0 RH850依存部 非信頼C2ISR対応を追加

  • Property svn:executable set to *
File size: 6.1 KB
Line 
1/*
2 * TOPPERS ATK2
3 * Toyohashi Open Platform for Embedded Real-Time Systems
4 * Automotive Kernel Version 2
5 *
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2005-2015 by Center for Embedded Computing Systems
9 * Graduate School of Information Science, Nagoya Univ., JAPAN
10 * Copyright (C) 2011-2015 by FUJI SOFT INCORPORATED, JAPAN
11 * Copyright (C) 2011-2013 by Spansion LLC, USA
12 * Copyright (C) 2011-2015 by NEC Communication Systems, Ltd., JAPAN
13 * Copyright (C) 2011-2015 by Panasonic Advanced Technology Development Co., Ltd., JAPAN
14 * Copyright (C) 2011-2014 by Renesas Electronics Corporation, JAPAN
15 * Copyright (C) 2011-2015 by Sunny Giken Inc., JAPAN
16 * Copyright (C) 2011-2015 by TOSHIBA CORPORATION, JAPAN
17 * Copyright (C) 2011-2015 by Witz Corporation
18 * Copyright (C) 2014-2015 by AISIN COMCRUISE Co., Ltd., JAPAN
19 * Copyright (C) 2014-2015 by eSOL Co.,Ltd., JAPAN
20 * Copyright (C) 2014-2015 by SCSK Corporation, JAPAN
21 * Copyright (C) 2015 by SUZUKI MOTOR CORPORATION
22 *
23 * 上記著作権者
24は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
25 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
26 * 変・再é…
27å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
28 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
29 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
30 * スコード中に含まれていること.
31 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
32 * 用できる形で再é…
33å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
34å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
35 * 者
36マニュアルなど)に,上記の著作権表示,この利用条件および下記
37 * の無保証規定を掲載すること.
38 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
39 * 用できない形で再é…
40å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
41 * と.
42 * (a) 再é…
43å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
44マニュアルなど)に,上記の著
45 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
46 * (b) 再é…
47å¸ƒã®å½¢æ…
48‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
49 * 報告すること.
50 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
51 * 害からも,上記著作権者
52およびTOPPERSプロジェクトをå…
53è²¬ã™ã‚‹ã“と.
54 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
55 * 由に基づく請求からも,上記著作権者
56およびTOPPERSプロジェクトを
57 * å…
58è²¬ã™ã‚‹ã“と.
59 *
60 * 本ソフトウェアは,AUTOSAR(AUTomotive Open System ARchitecture)仕
61 * 様に基づいている.上記の許諾は,AUTOSARの知的財産権を許諾するもので
62 * はない.AUTOSARは,AUTOSAR仕様に基づいたソフトウェアを商用目的で利
63 * 用する者
64に対して,AUTOSARパートナーになることを求めている.
65 *
66 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者
67お
68 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
69 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
70 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
71 * の責任を負わない.
72 *
73 * $Id: syslog.c 425 2015-12-07 08:06:19Z witz-itoyo $
74 */
75
76/*
77 * システムログ機能
78 */
79
80
81/*
82 * AUTOSARå…
83±é€šã®ãƒ‡ãƒ¼ã‚¿åž‹ãƒ»å®šæ•°ãƒ»ãƒžã‚¯ãƒ­
84 */
85#include "Std_Types.h"
86
87#include "t_syslog.h"
88#include "log_output.h"
89#include "target_sysmod.h"
90#include "syslog.h"
91
92/*
93 * トレースログマクロのデフォルト定義
94 */
95#ifndef LOG_SYSLOG_WRI_LOG_ENTER
96#define LOG_SYSLOG_WRI_LOG_ENTER(prio, p_syslog)
97#endif /* LOG_SYSLOG_WRI_LOG_ENTER */
98
99#ifndef LOG_SYSLOG_WRI_LOG_LEAVE
100#define LOG_SYSLOG_WRI_LOG_LEAVE(ercd)
101#endif /* LOG_SYSLOG_WRI_LOG_LEAVE */
102
103#ifndef LOG_SYSLOG_MSK_LOG_ENTER
104#define LOG_SYSLOG_MSK_LOG_ENTER(lowmask)
105#endif /* LOG_SYSLOG_MSK_LOG_ENTER */
106
107#ifndef LOG_SYSLOG_MSK_LOG_LEAVE
108#define LOG_SYSLOG_MSK_LOG_LEAVE(ercd)
109#endif /* LOG_SYSLOG_MSK_LOG_LEAVE */
110
111/*
112 * 出力すべきログ情
113報の重要度(ビットマップ)
114 */
115static uint32 syslog_lowmask_not; /* 低レベル出力すべき重要度(反転)*/
116
117/*
118 * システムログ機能の初期化
119 */
120void
121_syslog_syslog_initialize(void)
122{
123 syslog_lowmask_not = 0U;
124}
125
126/*
127 * ログ情
128報の出力
129 *
130 * CPUロック状æ…
131‹ã‚„実行コンテキストによらず動作できるように実装
132してある
133 */
134StatusType
135_syslog_syslog_wri_log(uint32 prio, const SYSLOG *p_syslog)
136{
137 SIL_PRE_LOC;
138 LOG_SYSLOG_WRI_LOG_ENTER(prio, p_syslog);
139 SIL_LOC_INT();
140
141 /*
142 * 低レベル出力
143 */
144 if (((~syslog_lowmask_not) & LOG_MASK(prio)) != 0U) {
145 _syslog_syslog_print(p_syslog, &target_fput_log);
146 (*target_fput_log)('\n');
147 }
148
149 SIL_UNL_INT();
150 LOG_SYSLOG_WRI_LOG_LEAVE(E_OK);
151 return(E_OK);
152}
153
154/*
155 * 出力すべきログ情
156報の重要度の設定
157 */
158StatusType
159_syslog_syslog_msk_log(uint32 lowmask)
160{
161 LOG_SYSLOG_MSK_LOG_ENTER(lowmask);
162 syslog_lowmask_not = ~lowmask;
163 LOG_SYSLOG_MSK_LOG_LEAVE(E_OK);
164 return(E_OK);
165}
166
167
168void
169syslog_initialize(void)
170{
171 KERLIBSLG_PRM prm;
172
173 prm.index = KERLIBSLG_ID_SYSLOG_INITIALIZE;
174 KernelLibrarySyslog(&prm);
175 return;
176}
177
178StatusType
179syslog_wri_log(uint32 prio, const SYSLOG *p_syslog)
180{
181 KERLIBSLG_PRM prm;
182
183 prm.index = KERLIBSLG_ID_SYSLOG_WRI_LOG;
184 prm.prio = prio;
185 prm.p_const_syslog = p_syslog;
186 KernelLibrarySyslog(&prm);
187 return(prm.return_er);
188}
189
190StatusType
191syslog_msk_log(uint32 lowmask)
192{
193 KERLIBSLG_PRM prm;
194
195 prm.index = KERLIBSLG_ID_SYSLOG_MSK_LOG;
196 prm.lowmask = lowmask;
197 KernelLibrarySyslog(&prm);
198 return(prm.return_er);
199}
Note: See TracBrowser for help on using the repository browser.