📄 sc_trace.h
字号:
/***************************************************************************** The following code is derived, directly or indirectly, from the SystemC source code Copyright (c) 1996-2006 by all Contributors. All Rights reserved. The contents of this file are subject to the restrictions and limitations set forth in the SystemC Open Source License Version 2.4 (the "License"); You may not use this file except in compliance with such restrictions and limitations. You may obtain instructions on how to receive a copy of the License at http://www.systemc.org/. Software distributed by Contributors 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. *****************************************************************************//***************************************************************************** sc_trace.h - Functions for tracing signals and variables. Author: Abhijit Ghosh, Synopsys, Inc. *****************************************************************************//***************************************************************************** MODIFICATION LOG - modifiers, enter your name, affiliation, date and changes you are making here. Name, Affiliation, Date: Description of Modification: *****************************************************************************//***************************************************************************** Acknowledgement: The tracing mechanism is based on the tracing mechanism developed at Infineon (formerly Siemens HL). Though this code is somewhat different, the basics are identical to what was originally contributed by Infineon. The contribution of Infineon in the development of this tracing technology is hereby acknowledged. *****************************************************************************/#ifndef SC_TRACE_H#define SC_TRACE_H#include <cstdio>#include "sysc/datatypes/int/sc_nbdefs.h"#include "sysc/kernel/sc_time.h"// Some forward declarationsnamespace sc_dt{ class sc_bit; class sc_logic; class sc_bv_base; class sc_lv_base; class sc_signed; class sc_unsigned; class sc_int_base; class sc_uint_base; class sc_fxval; class sc_fxval_fast; class sc_fxnum; class sc_fxnum_fast;}namespace sc_core {class sc_logic_resolve;class sc_time;template <class T> class sc_signal_in_if;// Write error messagevoid put_error_message(const char* msg, bool just_warning);// Base class for all kinds of trace files. class sc_trace_file{ friend class sc_simcontext; public: // Constructor sc_trace_file(); // All functions are pure virtual because they need to be defined by the // particular tracing mechanism#define DECL_TRACE_METHOD_A(tp) \ virtual void trace( const tp& object, \ const std::string& name ) = 0;#define DECL_TRACE_METHOD_B(tp) \ virtual void trace( const tp& object, \ const std::string& name, \ int width ) = 0; DECL_TRACE_METHOD_A( bool ) DECL_TRACE_METHOD_A( sc_dt::sc_bit ) DECL_TRACE_METHOD_A( sc_dt::sc_logic ) DECL_TRACE_METHOD_B( unsigned char ) DECL_TRACE_METHOD_B( unsigned short ) DECL_TRACE_METHOD_B( unsigned int ) DECL_TRACE_METHOD_B( unsigned long ) DECL_TRACE_METHOD_B( char ) DECL_TRACE_METHOD_B( short ) DECL_TRACE_METHOD_B( int ) DECL_TRACE_METHOD_B( long ) DECL_TRACE_METHOD_B( sc_dt::int64 ) DECL_TRACE_METHOD_B( sc_dt::uint64 ) DECL_TRACE_METHOD_A( float ) DECL_TRACE_METHOD_A( double ) DECL_TRACE_METHOD_A( sc_dt::sc_int_base ) DECL_TRACE_METHOD_A( sc_dt::sc_uint_base ) DECL_TRACE_METHOD_A( sc_dt::sc_signed ) DECL_TRACE_METHOD_A( sc_dt::sc_unsigned ) DECL_TRACE_METHOD_A( sc_dt::sc_fxval ) DECL_TRACE_METHOD_A( sc_dt::sc_fxval_fast ) DECL_TRACE_METHOD_A( sc_dt::sc_fxnum ) DECL_TRACE_METHOD_A( sc_dt::sc_fxnum_fast ) DECL_TRACE_METHOD_A( sc_dt::sc_bv_base ) DECL_TRACE_METHOD_A( sc_dt::sc_lv_base )#undef DECL_TRACE_METHOD_A#undef DECL_TRACE_METHOD_B // Trace an enumerated object - where possible output the enumeration // literals in the trace file. Enum literals is a null terminated array // of null terminated char* literal strings. virtual void trace( const unsigned int& object, const std::string& name, const char** enum_literals ) = 0; // Output a comment to the trace file virtual void write_comment( const std::string& comment ) = 0; // Set the amount of space before next column // (For most formats this does nothing) virtual void space( int n ); // Also trace transitions between delta cycles if flag is true. virtual void delta_cycles( bool flag ); // Set time unit. virtual void set_time_unit( int exponent10_seconds ); // deprecated. virtual void set_time_unit( double v, sc_time_unit tu );protected: // Write trace info for cycle virtual void cycle( bool delta_cycle ) = 0; // Flush results and close file virtual ~sc_trace_file() { /* Intentionally blank */ };protected: bool initialized; // = true means initialized double timescale_unit; // in seconds bool timescale_set_by_user; // = true means set by user};/*****************************************************************************/// Now comes all the SystemC defined tracing functions.// We define two sc_trace() versions for scalar types; one where the object to// be traced is passed as a reference and the other where a pointer to the// tracing object is passed.#define DECL_TRACE_FUNC_REF_A(tp) \void \sc_trace( sc_trace_file* tf, \ const tp& object, \ const std::string& name );#define DECL_TRACE_FUNC_PTR_A(tp) \void \sc_trace( sc_trace_file* tf, \ const tp* object, \ const std::string& name ); \#define DECL_TRACE_FUNC_A(tp) \DECL_TRACE_FUNC_REF_A(tp) \DECL_TRACE_FUNC_PTR_A(tp)DECL_TRACE_FUNC_A( sc_dt::sc_bit )DECL_TRACE_FUNC_A( sc_dt::sc_logic )DECL_TRACE_FUNC_A( sc_dt::sc_int_base )DECL_TRACE_FUNC_A( sc_dt::sc_uint_base )DECL_TRACE_FUNC_A( sc_dt::sc_signed )DECL_TRACE_FUNC_A( sc_dt::sc_unsigned )DECL_TRACE_FUNC_REF_A( sc_dt::sc_bv_base )DECL_TRACE_FUNC_REF_A( sc_dt::sc_lv_base )#undef DECL_TRACE_FUNC_REF_A#undef DECL_TRACE_FUNC_PTR_A#undef DECL_TRACE_FUNC_A// ----------------------------------------------------------------------------#define DEFN_TRACE_FUNC_REF_A(tp) \inline \void \sc_trace( sc_trace_file* tf, const tp& object, const std::string& name ) \{ \ if( tf ) { \ tf->trace( object, name ); \ } \}#define DEFN_TRACE_FUNC_PTR_A(tp) \inline \void \sc_trace( sc_trace_file* tf, const tp* object, const std::string& name ) \{ \ if( tf ) { \ tf->trace( *object, name ); \ } \}#define DEFN_TRACE_FUNC_A(tp) \DEFN_TRACE_FUNC_REF_A(tp) \DEFN_TRACE_FUNC_PTR_A(tp)#define DEFN_TRACE_FUNC_REF_B(tp) \inline \void \sc_trace( sc_trace_file* tf, const tp& object, const std::string& name, \ int width = 8 * sizeof( tp ) ) \{ \ if( tf ) { \ tf->trace( object, name, width ); \ } \}#define DEFN_TRACE_FUNC_PTR_B(tp) \inline \void \sc_trace( sc_trace_file* tf, const tp* object, const std::string& name, \ int width = 8 * sizeof( tp ) ) \{ \ if( tf ) { \ tf->trace( *object, name, width ); \ } \}#define DEFN_TRACE_FUNC_B(tp) \DEFN_TRACE_FUNC_REF_B(tp) \DEFN_TRACE_FUNC_PTR_B(tp)DEFN_TRACE_FUNC_A( bool )DEFN_TRACE_FUNC_A( float )DEFN_TRACE_FUNC_A( double )DEFN_TRACE_FUNC_B( unsigned char )DEFN_TRACE_FUNC_B( unsigned short )DEFN_TRACE_FUNC_B( unsigned int )DEFN_TRACE_FUNC_B( unsigned long )DEFN_TRACE_FUNC_B( char )DEFN_TRACE_FUNC_B( short )DEFN_TRACE_FUNC_B( int )DEFN_TRACE_FUNC_B( long )DEFN_TRACE_FUNC_B( sc_dt::int64 )DEFN_TRACE_FUNC_B( sc_dt::uint64 )#undef DEFN_TRACE_FUNC_REF_A#undef DEFN_TRACE_FUNC_PTR_A#undef DEFN_TRACE_FUNC_A#undef DEFN_TRACE_FUNC_REF_B#undef DEFN_TRACE_FUNC_PTR_B#undef DEFN_TRACE_FUNC_Btemplate <class T> inlinevoidsc_trace( sc_trace_file* tf, const sc_signal_in_if<T>& object, const std::string& name ){ sc_trace( tf, object.read(), name );}template< class T >inlinevoidsc_trace( sc_trace_file* tf, const sc_signal_in_if<T>& object, const char* name ){ sc_trace( tf, object.read(), name );}// specializations for signals of type char, short, int, longvoid sc_trace( sc_trace_file* tf, const sc_signal_in_if<char>& object, const std::string& name, int width );void sc_trace( sc_trace_file* tf, const sc_signal_in_if<short>& object, const std::string& name, int width );void sc_trace( sc_trace_file* tf, const sc_signal_in_if<int>& object, const std::string& name, int width );void sc_trace( sc_trace_file* tf, const sc_signal_in_if<long>& object, const std::string& name, int width );// 1. non-template function is better than template// 2. more-specialized template is better than less-specialized// 3. no partial specialization for template functions// Trace an enumerated object - where possible output the enumeration literals// in the trace file. Enum literals is a null terminated array of null// terminated char* literal strings.voidsc_trace( sc_trace_file* tf, const unsigned int& object, const std::string& name, const char** enum_literals );// Dummy function for arbitrary types of value, does nothingextern void sc_trace( sc_trace_file* tf, const void* object, const std::string& name );// Turn on/off delta cycle tracing on trace file `tf'.// Default is to turn on delta cycle tracing.inlinevoidsc_trace_delta_cycles( sc_trace_file* tf, bool on = true ){ if( tf ) tf->delta_cycles( on );}// Output a comment to the trace fileinlinevoidsc_write_comment( sc_trace_file* tf, const std::string& comment ){ if( tf ) tf->write_comment( comment );}// Equivalent of std::fprintf for trace files!#ifdef __GNUC__void tprintf( sc_trace_file* tf, const char* format, ... ) __attribute__ ((format (printf,2,3)));#elsevoid tprintf( sc_trace_file* tf, const char* format, ... );#endif // Convert double time to 64-bit integerextern void double_to_special_int64( double in, unsigned* high, unsigned* low );} // namespace sc_core#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -