/* * TOPPERS Software * Toyohashi Open Platform for Embedded Real-Time Systems * * Copyright (C) 2007-2011 by Embedded and Real-Time Systems Laboratory * Graduate School of Information Science, Nagoya Univ., JAPAN * * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する. * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー * スコード中に含まれていること. * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記 * の無保証規定を掲載すること. * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ * と. * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著 * 作権表示,この利用条件および下記の無保証規定を掲載すること. * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに * 報告すること. * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること. * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを * 免責すること. * * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ * の責任を負わない. * * $Id: trace_dump.c 167 2016-03-08 11:37:45Z coas-nagasima $ */ /* * トレースログのダンプ */ #include "kernel_impl.h" #include "task.h" #include /* * カーネル情報の取出し */ static intptr_t get_tskid(intptr_t info) { TCB *p_tcb; ID tskid; p_tcb = (TCB *) info; if (p_tcb == NULL) { tskid = 0; } else { tskid = TSKID(p_tcb); } return((intptr_t) tskid); } static intptr_t get_tskstat(intptr_t info) { uint_t tstat; const char *tstatstr; tstat = (uint_t) info; switch (tstat & (TS_RUNNABLE|TS_WAITING|TS_SUSPENDED)) { case TS_DORMANT: tstatstr = "DORMANT"; break; case TS_RUNNABLE: tstatstr = "RUNNABLE"; break; case TS_WAITING: tstatstr = "WAITING"; break; case TS_SUSPENDED: tstatstr = "SUSPENDED"; break; case TS_WAITING|TS_SUSPENDED: tstatstr = "WAITING-SUSPENDED"; break; default: tstatstr = "unknown state"; break; } return((intptr_t) tstatstr); } /* * トレースログの表示 */ static void trace_print(TRACE *p_trace, void (*putc)(char)) { intptr_t traceinfo[TMAX_LOGINFO + 1]; const char *tracemsg; int_t i; traceinfo[0] = (intptr_t)(p_trace->logtim); syslog_printf("[%d] ", traceinfo, putc); switch (p_trace->logtype) { case LOG_TYPE_TSKSTAT: traceinfo[0] = get_tskid(p_trace->loginfo[0]); traceinfo[1] = get_tskstat(p_trace->loginfo[1]); tracemsg = "task %d becomes %s."; break; case LOG_TYPE_DSP|LOG_LEAVE: traceinfo[0] = get_tskid(p_trace->loginfo[0]); tracemsg = "dispatch to task %d."; break; case LOG_TYPE_COMMENT: for (i = 1; i < TMAX_LOGINFO; i++) { traceinfo[i-1] = p_trace->loginfo[i]; } tracemsg = (const char *)(p_trace->loginfo[0]); break; case LOG_TYPE_ASSERT: traceinfo[0] = p_trace->loginfo[0]; traceinfo[1] = p_trace->loginfo[1]; traceinfo[2] = p_trace->loginfo[2]; tracemsg = "%s:%u: Assertion `%s' failed."; break; default: traceinfo[0] = p_trace->logtype; tracemsg = "unknown trace log type: %d."; break; } syslog_printf(tracemsg, traceinfo, putc); (*putc)('\n'); } /* * トレースログのダンプ */ void trace_dump(intptr_t exinf) { TRACE trace; void (*putc)(char); putc = (void (*)(char)) exinf; while (trace_rea_log(&trace) >= 0) { trace_print(&trace, putc); } }