📄 fancy.cxx
字号:
//==========================================================================//// fancy.cxx//// Fancy formatting trace and assert functions////==========================================================================//####COPYRIGHTBEGIN####// // ------------------------------------------- // The contents of this file are subject to the Red Hat eCos Public License // Version 1.1 (the "License"); you may not use this file except in // compliance with the License. You may obtain a copy of the License at // http://www.redhat.com/ // // Software distributed under the License is distributed on an "AS IS" // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the // License for the specific language governing rights and limitations under // the License. // // The Original Code is eCos - Embedded Configurable Operating System, // released September 30, 1998. // // The Initial Developer of the Original Code is Red Hat. // Portions created by Red Hat are // Copyright (C) 1998, 1999, 2000 Red Hat, Inc. // All Rights Reserved. // ------------------------------------------- // //####COPYRIGHTEND####//==========================================================================//#####DESCRIPTIONBEGIN####//// Author(s): nickg// Contributors: nickg// Date: 1997-12-04// Purpose: Fancy Trace and assert functions// Description: The functions in this file are fancy implementations of the// standard trace and assert functions. These do printf// style formatting, printing the string and arguments.////####DESCRIPTIONEND####////==========================================================================#include <pkgconf/system.h>#include <pkgconf/infra.h>#ifdef CYGDBG_INFRA_DEBUG_TRACE_ASSERT_FANCY#include <cyg/infra/cyg_type.h> // base types#include <cyg/infra/cyg_trac.h> // tracing macros#include <cyg/infra/cyg_ass.h> // assertion macros#include <pkgconf/hal.h> // HAL configury#include <cyg/infra/diag.h> // HAL polled output#include <cyg/hal/hal_arch.h> // architectural stuff for...#include <cyg/hal/hal_intr.h> // interrupt control#ifdef CYGPKG_KERNEL#include <pkgconf/kernel.h> // kernel configury#include <cyg/kernel/thread.hxx> // thread id to print#include <cyg/kernel/sched.hxx> // ancillaries for above#include <cyg/kernel/thread.inl> // ancillaries for above#endif// -------------------------------------------------------------------------// Local Configuration: hack me!// these are generally:// if 0, feature is disabled// if 1, feature is enabled, printing is default width// if >1, field is padded up to that width if necessary// (not truncated ever)#define CYG_FILENAME 20#define CYG_THREADID 0 // DO NOT SET IF NO KERNEL#define CYG_LINENUM 4#define CYG_FUNCNAME 100#define CYG_DIAG_PRINTF 1#define CYG_FUNC_INDENT 2#ifndef CYGPKG_KERNEL# undef CYG_THREADID# define CYG_THREADID 0#endif#if CYG_FUNCNAME == 1#define CYG_FBUF_SIZE 100#else#define CYG_FBUF_SIZE (CYG_FUNCNAME+20)#endif// -------------------------------------------------------------------------// Functions to trim file names and function names down to printable lengths// (these are shared between trace and assert functions)#ifdef CYGDBG_USE_TRACING#if 0static char * tracepremsgs[] = { " INFO:", "ENTER :", "ARGS :", "RETURN:", "bad code"};#endifstatic char * tracepremsgs[] = { "'", "{{", "((", "}}", "bad code"};static char * tracepostmsgs[] = { "'", "", "))", "", "bad code"};static voidwrite_whattrace( cyg_uint32 what ){#if CYG_FUNC_INDENT static cyg_uint32 cyg_indent = 0; if ( 3 == what ) cyg_indent -= CYG_FUNC_INDENT; cyg_uint32 i = cyg_indent; for ( ; i > 0; i-- ) diag_write_string( " " );#endif // CYG_FUNC_INDENT diag_write_string( tracepremsgs[ what > 4 ? 4 : what ] );#if CYG_FUNC_INDENT if ( 1 == what ) cyg_indent += CYG_FUNC_INDENT;#endif // CYG_FUNC_INDENT}static voidwrite_whattracepost( cyg_uint32 what ){ diag_write_string( tracepostmsgs[ what > 4 ? 4 : what ] );}#endif // CYGDBG_USE_TRACINGstatic const char *trim_file(const char *file){#if CYG_FILENAME if ( NULL == file ) file = "<nofile>";#if 1 == CYG_FILENAME const char *f = file; while( *f ) f++; while( *f != '/' && f != file ) f--; return f==file?f:(f+1);#else static char fbuf2[100]; const char *f = file; char *g = fbuf2; while( *f ) f++; while( *f != '/' && f != file ) f--; if ( f > file ) f++; while( *f ) *g++ = *f++; while( CYG_FILENAME > (g - fbuf2) ) *g++ = ' '; *g = 0; return fbuf2;#endif#else return "";#endif}static const char *trim_func(const char *func){#if CYG_FUNCNAME static char fbuf[CYG_FBUF_SIZE]; int i; if ( NULL == func ) func = "<nofunc>"; for( i = 0; func[i] && func[i] != '(' && i < CYG_FBUF_SIZE-4 ; i++ ) fbuf[i] = func[i]; fbuf[i++] = '('; fbuf[i++] = ')'; fbuf[i ] = 0; i=0;#if 1 == CYG_FUNCNAME return &fbuf[i];#else char *p = &fbuf[i]; while ( *p ) p++; while ( CYG_FUNCNAME > (p - (&fbuf[i])) ) *p++ = ' '; *p = 0; return &fbuf[i];#endif#else return "";#endif}void write_lnum( cyg_uint32 lnum){#if CYG_LINENUM diag_write_char('[');#if 1 < CYG_LINENUM cyg_uint32 i, j; for ( i = 2, j = 100; i < CYG_LINENUM ; i++, j *= 10 ) if ( lnum < j ) diag_write_char(' ');#endif diag_write_dec(lnum); diag_write_char(']'); diag_write_char(' ');#endif}void write_thread_id(){#if CYG_THREADID Cyg_Thread *t = Cyg_Thread::self(); cyg_uint16 tid = 0xFFFF; if( t != NULL ) tid = t->get_unique_id(); diag_write_char('<'); diag_write_hex(tid); diag_write_char('>');#endif}// -------------------------------------------------------------------------// Trace functions:#ifdef CYGDBG_USE_TRACINGexternC voidcyg_tracenomsg( char *psz_func, char *psz_file, cyg_uint32 linenum ){ cyg_uint32 old_ints; HAL_DISABLE_INTERRUPTS(old_ints); DIAG_DEVICE_START_SYNC(); diag_write_string("TRACE: "); write_thread_id(); diag_write_string(trim_file(psz_file)); write_lnum(linenum); diag_write_string(trim_func(psz_func)); diag_write_char('\n'); DIAG_DEVICE_END_SYNC(); HAL_RESTORE_INTERRUPTS(old_ints); };// provide every other one of these as a space/caller bloat compromise.externC voidcyg_tracemsg( cyg_uint32 what, char *psz_func, char *psz_file, cyg_uint32 linenum, char *psz_msg ){ cyg_uint32 old_ints; HAL_DISABLE_INTERRUPTS(old_ints); DIAG_DEVICE_START_SYNC(); if ( NULL == psz_msg ) psz_msg = "<nomsg>"; diag_write_string( "TRACE: " ); write_thread_id(); diag_write_string(trim_file(psz_file)); write_lnum(linenum); diag_write_string(trim_func(psz_func)); diag_write_char(' '); write_whattrace( what ); diag_write_string(psz_msg); write_whattracepost( what ); diag_write_char('\n'); DIAG_DEVICE_END_SYNC(); HAL_RESTORE_INTERRUPTS(old_ints);};externC voidcyg_tracemsg2( cyg_uint32 what, char *psz_func, char *psz_file, cyg_uint32 linenum, char *psz_msg, CYG_ADDRWORD arg0, CYG_ADDRWORD arg1 ){ cyg_uint32 old_ints; HAL_DISABLE_INTERRUPTS(old_ints); DIAG_DEVICE_START_SYNC(); if ( NULL == psz_msg ) psz_msg = "<nomsg>"; diag_write_string( "TRACE: " ); write_thread_id(); diag_write_string(trim_file(psz_file)); write_lnum(linenum); diag_write_string(trim_func(psz_func)); diag_write_char(' '); write_whattrace( what );#if CYG_DIAG_PRINTF diag_printf( psz_msg, arg0, arg1 );#else diag_write_string(psz_msg); diag_write_char(' '); diag_write_hex(arg0); diag_write_char(' '); diag_write_hex(arg1);#endif write_whattracepost( what ); diag_write_char('\n'); DIAG_DEVICE_END_SYNC();
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -