source: atk2-sc3-1.4.0-ntisr/arch/logtrace/trace_config.c@ 172

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

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

  • Property svn:executable set to *
File size: 8.2 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: trace_config.c 425 2015-12-07 08:06:19Z witz-itoyo $
74 */
75
76/*
77 * トレースログ機能
78 */
79
80#include "kernel_impl.h"
81#include "task.h"
82
83#include "target_timer.h"
84
85/*
86 * 本来はtrace_config.hにプロトタイプ宣言を置くべきだが,TCBが
87 * 定義される前なので,コンパイルが通らないためここに置く
88 */
89extern void log_dsp_enter(const TCB *p_tcb);
90extern void log_dsp_leave(const TCB *p_tcb);
91
92/*
93 * 内
94部関数プロトタイプ宣言
95 */
96static StatusType trace_wri_log(TRACE *p_trace);
97
98/*
99 * トレースログバッファとそれにアクセスするためのポインタ
100 */
101static TRACE trace_buffer[TCNT_TRACE_BUFFER]; /* トレースログバッファ */
102static uint32 trace_count; /* トレースログバッファ中のログの数 */
103static uint32 trace_head; /* å…
104ˆé ­ã®ãƒˆãƒ¬ãƒ¼ã‚¹ãƒ­ã‚°ã®æ ¼ç´ä½ç½® */
105static uint32 trace_tail; /* 次のトレースログの格納位置 */
106static TraceModeType trace_mode = TRACE_AUTOSTOP; /* トレースモード */
107
108/*
109 * トレースログ機能の初期化
110 */
111void
112trace_initialize(uintptr exinf)
113{
114 TraceModeType mode = ((TraceModeType) exinf);
115
116 trace_count = 0U;
117 trace_head = 0U;
118 trace_tail = 0U;
119 trace_mode = mode;
120}
121
122/*
123 * トレースログの開始
124 */
125StatusType
126trace_sta_log(TraceModeType mode)
127{
128 if ((mode & TRACE_CLEAR) != 0U) {
129 trace_count = 0U;
130 trace_head = 0U;
131 trace_tail = 0U;
132 }
133 trace_mode = mode;
134 return(E_OK);
135}
136
137/*
138 * トレースログの書込み
139 */
140static StatusType
141trace_wri_log(TRACE *p_trace)
142{
143 SIL_PRE_LOC;
144
145 if (trace_mode != TRACE_STOP) {
146 SIL_LOC_INT();
147
148 /*
149 * トレース時刻の設定
150 *
151 * LOG_WRI_LOG_ENTERから呼ばれた場合にp_trace->logtimを書き換
152 * えてしまうのは気持ちが悪いが,wri_logの方で上書きするため問
153 * 題はない
154 */
155 p_trace->logtim = GET_UTIM();
156
157 /*
158 * トレースバッファに記録
159 */
160 trace_buffer[trace_tail] = *p_trace;
161 trace_tail++;
162 if (trace_tail >= TCNT_TRACE_BUFFER) {
163 trace_tail = 0U;
164 }
165 if (trace_count < TCNT_TRACE_BUFFER) {
166 trace_count++;
167 if ((trace_count >= TCNT_TRACE_BUFFER)
168 && ((trace_mode & TRACE_AUTOSTOP) != 0U)) {
169 trace_mode = TRACE_STOP;
170 }
171 }
172 else {
173 trace_head = trace_tail;
174 }
175
176 SIL_UNL_INT();
177 }
178 return(E_OK);
179}
180
181/*
182 * トレースログの読出し
183 */
184StatusType
185trace_rea_log(TRACE *p_trace)
186{
187 StatusType ercd;
188 SIL_PRE_LOC;
189
190 SIL_LOC_INT();
191
192 /*
193 * トレースログバッファからの取出し
194 */
195 if (trace_count > 0U) {
196 *p_trace = trace_buffer[trace_head];
197 trace_count--;
198 trace_head++;
199 if (trace_head >= TCNT_TRACE_BUFFER) {
200 trace_head = 0U;
201 }
202 ercd = E_OK;
203 }
204 else {
205 ercd = E_NOT_OK;
206 }
207
208 SIL_UNL_INT();
209 return(ercd);
210}
211
212/*
213 * トレースログを出力するためのライブラリ関数
214 */
215
216void
217trace_write_0(uint32 type)
218{
219 TRACE trace;
220
221 trace.logtype = type;
222 (void) trace_wri_log(&trace);
223}
224
225void
226trace_write_1(uint32 type, const uintptr arg1)
227{
228 TRACE trace;
229
230 trace.logtype = type;
231 trace.loginfo[0] = arg1;
232 (void) trace_wri_log(&trace);
233}
234
235void
236trace_write_2(uint32 type, uintptr arg1, uintptr arg2)
237{
238 TRACE trace;
239
240 trace.logtype = type;
241 trace.loginfo[0] = arg1;
242 trace.loginfo[1] = arg2;
243 (void) trace_wri_log(&trace);
244}
245
246void
247trace_write_3(uint32 type, uintptr arg1, uintptr arg2, uintptr arg3)
248{
249 TRACE trace;
250
251 trace.logtype = type;
252 trace.loginfo[0] = arg1;
253 trace.loginfo[1] = arg2;
254 trace.loginfo[2] = arg3;
255 (void) trace_wri_log(&trace);
256}
257
258void
259trace_write_4(uint32 type, uintptr arg1, uintptr arg2, uintptr arg3,
260 uintptr arg4)
261{
262 TRACE trace;
263
264 trace.logtype = type;
265 trace.loginfo[0] = arg1;
266 trace.loginfo[1] = arg2;
267 trace.loginfo[2] = arg3;
268 trace.loginfo[3] = arg4;
269 (void) trace_wri_log(&trace);
270}
271
272void
273trace_write_5(uint32 type, uintptr arg1, uintptr arg2, uintptr arg3,
274 uintptr arg4, uintptr arg5)
275{
276 TRACE trace;
277
278 trace.logtype = type;
279 trace.loginfo[0] = arg1;
280 trace.loginfo[1] = arg2;
281 trace.loginfo[2] = arg3;
282 trace.loginfo[3] = arg4;
283 trace.loginfo[4] = arg5;
284 (void) trace_wri_log(&trace);
285}
286
287/*
288 * アセンブリ言語で記述されるコードからトレースログを出力するための関
289 * 数
290 */
291void
292log_dsp_enter(const TCB *p_tcb)
293{
294 trace_1(LOG_TYPE_DSP | LOG_ENTER, (const uintptr) p_tcb);
295}
296
297void
298log_dsp_leave(const TCB *p_tcb)
299{
300 trace_1(LOG_TYPE_DSP | LOG_LEAVE, (const uintptr) p_tcb);
301}
Note: See TracBrowser for help on using the repository browser.