src/sysc/tracing/sc_wif_trace.h

Go to the documentation of this file.
00001 /*****************************************************************************
00002 
00003   The following code is derived, directly or indirectly, from the SystemC
00004   source code Copyright (c) 1996-2005 by all Contributors.
00005   All Rights reserved.
00006 
00007   The contents of this file are subject to the restrictions and limitations
00008   set forth in the SystemC Open Source License Version 2.4 (the "License");
00009   You may not use this file except in compliance with such restrictions and
00010   limitations. You may obtain instructions on how to receive a copy of the
00011   License at http://www.systemc.org/. Software distributed by Contributors
00012   under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF
00013   ANY KIND, either express or implied. See the License for the specific
00014   language governing rights and limitations under the License.
00015 
00016  *****************************************************************************/
00017 
00018 /*****************************************************************************
00019 
00020   sc_wif_trace.h - Implementation of WIF tracing.
00021 
00022   Original Author - Abhijit Ghosh, Synopsys, Inc.
00023 
00024  *****************************************************************************/
00025 
00026 /*****************************************************************************
00027 
00028   MODIFICATION LOG - modifiers, enter your name, affiliation, date and
00029   changes you are making here.
00030 
00031       Name, Affiliation, Date:
00032   Description of Modification:
00033 
00034  *****************************************************************************/
00035 
00036 /*****************************************************************************
00037 
00038    Acknowledgement: The tracing mechanism is based on the tracing
00039    mechanism developed at Infineon (formerly Siemens HL). Though this
00040    code is somewhat different, and significantly enhanced, the basics
00041    are identical to what was originally contributed by Infineon.
00042    The contribution of Infineon in the development of this tracing
00043    technology is hereby acknowledged.
00044 
00045  *****************************************************************************/
00046 
00047 /*****************************************************************************
00048 
00049    Instead of creating the binary WIF format, we create the ASCII
00050    WIF format which can be converted to the binary format using
00051    a2wif (utility that comes with VSS from Synopsys). This way, 
00052    a user who does not have Synopsys VSS can still create WIF 
00053    files, but the files can only be viewed by users who have VSS.
00054 
00055  *****************************************************************************/
00056 
00057 #ifndef SC_WIF_TRACE_H
00058 #define SC_WIF_TRACE_H
00059 
00060 #include <cstdio>
00061 #include "sysc/datatypes/int/sc_nbdefs.h"
00062 #include "sysc/tracing/sc_trace.h"
00063 #include "sysc/utils/sc_vector.h"
00064 
00065 namespace sc_core {
00066 
00067 class wif_trace;  // defined in wif_trace.cc
00068 template<class T> class wif_T_trace;
00069 
00070 void wif_put_error_message(const char* msg, bool just_warning);
00071 
00072 class wif_trace_file : public sc_trace_file{
00073 public:
00074     enum wif_enum {WIF_BIT=0, WIF_MVL=1, WIF_REAL=2, WIF_LAST};
00075 
00076     void sc_set_wif_time_unit(int exponent10_seconds); // -7 -> 100ns
00077 
00078     // Create a wif trace file.
00079     // `Name' forms the base of the name to which `.awif' is added.
00080     wif_trace_file(const char *name);
00081 
00082     // Flush results and close file.
00083     ~wif_trace_file();
00084 
00085 protected:
00086     // These are all virtual functions in sc_trace_file and
00087     // they need to be defined here.
00088 
00089     // Trace a boolean object (single bit)
00090      void trace(const bool& object, const std::string& name);
00091 
00092     // Trace a sc_bit object (single bit)
00093      void trace(const sc_dt::sc_bit& object, const std::string& name);
00094 
00095     // Trace a sc_logic object (single bit)
00096      void trace(const sc_dt::sc_logic& object, const std::string& name);
00097     
00098     // Trace an unsigned char with the given width
00099      void trace(const unsigned char& object, const std::string& name, 
00100         int width);
00101 
00102     // Trace an unsigned short with the given width
00103      void trace(const unsigned short& object, const std::string& name, 
00104          int width);
00105 
00106     // Trace an unsigned int with the given width
00107      void trace(const unsigned int& object, const std::string& name, 
00108          int width);
00109 
00110     // Trace an unsigned long with the given width
00111      void trace(const unsigned long& object, const std::string& name, 
00112          int width);
00113 
00114     // Trace a signed char with the given width
00115      void trace(const char& object, const std::string& name, int width);
00116 
00117     // Trace a signed short with the given width
00118      void trace(const short& object, const std::string& name, int width);
00119 
00120     // Trace a signed int with the given width
00121      void trace(const int& object, const std::string& name, int width);
00122 
00123     // Trace a signed long with the given width
00124      void trace(const long& object, const std::string& name, int width);
00125     
00126     // Trace a signed long long with the given width
00127      void trace(const sc_dt::int64& object, const std::string& name, 
00128          int width);
00129     
00130     // Trace an usigned long long with the given width
00131      void trace(const sc_dt::uint64& object, const std::string& name, 
00132          int width);
00133     
00134     // Trace a float
00135      void trace(const float& object, const std::string& name);
00136 
00137     // Trace a double
00138      void trace(const double& object, const std::string& name);
00139 
00140     // Trace sc_unsigned
00141      void trace (const sc_dt::sc_unsigned& object, 
00142          const std::string& name);
00143 
00144     // Trace sc_signed
00145      void trace (const sc_dt::sc_signed& object, 
00146          const std::string& name);
00147 
00148     // Trace sc_uint_base
00149      void trace (const sc_dt::sc_uint_base& object, 
00150          const std::string& name);
00151 
00152     // Trace sc_int_base
00153      void trace (const sc_dt::sc_int_base& object, const std::string& name);
00154 
00155     // Trace sc_fxval
00156     void trace( const sc_dt::sc_fxval& object, const std::string& name );
00157 
00158     // Trace sc_fxval_fast
00159     void trace( const sc_dt::sc_fxval_fast& object, 
00160         const std::string& name );
00161 
00162     // Trace sc_fxnum
00163     void trace( const sc_dt::sc_fxnum& object, const std::string& name );
00164 
00165     // Trace sc_fxnum_fast
00166     void trace( const sc_dt::sc_fxnum_fast& object, 
00167         const std::string& name );
00168 
00169     template<class T>
00170     void traceT(const T& object, const std::string& name, wif_enum type)
00171     {
00172       if(initialized)
00173         wif_put_error_message("No traces can be added once simulation has"
00174         " started.\nTo add traces, create a new wif trace file.", false);
00175       else
00176         traces.push_back(new wif_T_trace<T>(object, name,
00177           obtain_new_index(),type));
00178     }
00179 
00180     // Trace sc_bv_base (sc_bv)
00181     virtual void trace( const sc_dt::sc_bv_base& object, 
00182         const std::string& name );
00183 
00184     // Trace sc_lv_base (sc_lv)
00185     virtual void trace( const sc_dt::sc_lv_base& object, 
00186         const std::string& name );
00187 
00188     // Trace an enumerated object - where possible output the enumeration literals
00189     // in the trace file. Enum literals is a null terminated array of null
00190     // terminated char* literal strings.
00191      void trace(const unsigned& object, const std::string& name, 
00192          const char** enum_literals);
00193 
00194     // Output a comment to the trace file
00195      void write_comment(const std::string& comment);
00196 
00197     // Also trace transitions between delta cycles if flag is true.
00198      void delta_cycles(bool flag);
00199 
00200     // Write trace info for cycle.
00201      void cycle(bool delta_cycle);
00202     
00203 private:
00204     // Initialize the tracing mechanism
00205     void initialize();
00206 
00207     // Create wif names for each variable
00208     void create_wif_name(std::string* ptr_to_str);
00209 
00210     // Pointer to the file that needs to be written
00211     FILE* fp;
00212 
00213     double timescale_unit;      // in seconds
00214     bool timescale_set_by_user; // = 1 means set by user
00215     bool trace_delta_cycles;    // = 1 means trace the delta cycles
00216 
00217     unsigned wif_name_index;    // Number of variables traced
00218 
00219     unsigned previous_time_units_low, previous_time_units_high; // Previous time as 64 bit integer
00220     double previous_time;       // Previous time as a double
00221 
00222 public:
00223 
00224     bool initialized;           // = 1 means initialized
00225     // same as create_wif_name (corrected style)
00226     std::string obtain_new_index();
00227 
00228     // Array to store the variables traced
00229     sc_pvector<wif_trace*> traces;
00230 };
00231 
00232 // Create WIF file
00233 extern sc_trace_file *sc_create_wif_trace_file(const char *name);
00234 extern void sc_close_wif_trace_file( sc_trace_file* tf );
00235 
00236 } //  namespace sc_core
00237 
00238 #endif

Generated on Wed Apr 25 13:53:28 2007 for SystemC by  doxygen 1.5.1