source: atk2-sc3_fl850f1l/sysmod/syslog.c@ 117

Last change on this file since 117 was 117, checked in by ertl-ishikawa, 9 years ago

ATK2-SC3 1.3.2 FL850F1L(RH850F1L)依存部(GCC/GHS/CCRH)を追加

File size: 5.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 *
22 * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
23 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
24 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
25 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
26 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
27 * スコード中に含まれていること.
28 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
29 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
30 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
31 * の無保証規定を掲載すること.
32 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
33 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
34 * と.
35 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
36 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
37 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
38 * 報告すること.
39 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
40 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
41 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
42 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
43 * 免責すること.
44 *
45 * 本ソフトウェアは,AUTOSAR(AUTomotive Open System ARchitecture)仕
46 * 様に基づいている.上記の許諾は,AUTOSARの知的財産権を許諾するもので
47 * はない.AUTOSARは,AUTOSAR仕様に基づいたソフトウェアを商用目的で利
48 * 用する者に対して,AUTOSARパートナーになることを求めている.
49 *
50 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
51 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
52 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
53 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
54 * の責任を負わない.
55 *
56 * $Id: syslog.c 187 2015-06-25 03:39:04Z t_ishikawa $
57 */
58
59/*
60 * システムログ機能
61 */
62
63
64/*
65 * AUTOSAR共通のデータ型・定数・マクロ
66 */
67#include "Std_Types.h"
68
69#include "t_syslog.h"
70#include "log_output.h"
71#include "target_sysmod.h"
72#include "syslog.h"
73
74/*
75 * トレースログマクロのデフォルト定義
76 */
77#ifndef LOG_SYSLOG_WRI_LOG_ENTER
78#define LOG_SYSLOG_WRI_LOG_ENTER(prio, p_syslog)
79#endif /* LOG_SYSLOG_WRI_LOG_ENTER */
80
81#ifndef LOG_SYSLOG_WRI_LOG_LEAVE
82#define LOG_SYSLOG_WRI_LOG_LEAVE(ercd)
83#endif /* LOG_SYSLOG_WRI_LOG_LEAVE */
84
85#ifndef LOG_SYSLOG_MSK_LOG_ENTER
86#define LOG_SYSLOG_MSK_LOG_ENTER(lowmask)
87#endif /* LOG_SYSLOG_MSK_LOG_ENTER */
88
89#ifndef LOG_SYSLOG_MSK_LOG_LEAVE
90#define LOG_SYSLOG_MSK_LOG_LEAVE(ercd)
91#endif /* LOG_SYSLOG_MSK_LOG_LEAVE */
92
93/*
94 * 出力すべきログ情報の重要度(ビットマップ)
95 */
96static uint32 syslog_lowmask_not; /* 低レベル出力すべき重要度(反転)*/
97
98/*
99 * システムログ機能の初期化
100 */
101void
102_syslog_syslog_initialize(void)
103{
104 syslog_lowmask_not = 0U;
105}
106
107/*
108 * ログ情報の出力
109 *
110 * CPUロック状態や実行コンテキストによらず動作できるように実装してある
111 */
112StatusType
113_syslog_syslog_wri_log(uint32 prio, const SYSLOG *p_syslog)
114{
115 SIL_PRE_LOC;
116 LOG_SYSLOG_WRI_LOG_ENTER(prio, p_syslog);
117 SIL_LOC_INT();
118
119 /*
120 * 低レベル出力
121 */
122 if (((~syslog_lowmask_not) & LOG_MASK(prio)) != 0U) {
123 _syslog_syslog_print(p_syslog, &target_fput_log);
124 (*target_fput_log)('\n');
125 }
126
127 SIL_UNL_INT();
128 LOG_SYSLOG_WRI_LOG_LEAVE(E_OK);
129 return(E_OK);
130}
131
132/*
133 * 出力すべきログ情報の重要度の設定
134 */
135StatusType
136_syslog_syslog_msk_log(uint32 lowmask)
137{
138 LOG_SYSLOG_MSK_LOG_ENTER(lowmask);
139 syslog_lowmask_not = ~lowmask;
140 LOG_SYSLOG_MSK_LOG_LEAVE(E_OK);
141 return(E_OK);
142}
143
144
145void
146syslog_initialize(void)
147{
148 KERLIBSLG_PRM prm;
149
150 prm.index = KERLIBSLG_ID_SYSLOG_INITIALIZE;
151 KernelLibrarySyslog(&prm);
152 return;
153}
154
155StatusType
156syslog_wri_log(uint32 prio, const SYSLOG *p_syslog)
157{
158 KERLIBSLG_PRM prm;
159
160 prm.index = KERLIBSLG_ID_SYSLOG_WRI_LOG;
161 prm.prio = prio;
162 prm.p_const_syslog = p_syslog;
163 KernelLibrarySyslog(&prm);
164 return(prm.return_er);
165}
166
167StatusType
168syslog_msk_log(uint32 lowmask)
169{
170 KERLIBSLG_PRM prm;
171
172 prm.index = KERLIBSLG_ID_SYSLOG_MSK_LOG;
173 prm.lowmask = lowmask;
174 KernelLibrarySyslog(&prm);
175 return(prm.return_er);
176}
Note: See TracBrowser for help on using the repository browser.