Skip to content

gdb python scripts for SystemC design introspection and tracing

License

Notifications You must be signed in to change notification settings

undoio/gdb_systemc_trace

 
 

Repository files navigation

gdb_systemc_trace

GDB Python scripts for SystemC design introspection and tracing

Automatically creates a trace of all signals and module member variables in design

Limitations

Fixed-point datatypes are not supported yet

Installation

Prerequisites

Running basic example

  1. clone gdb_systemc_trace from git and add to $PATH
  2. Download SystemC 2.3.3 https://accellera.org/downloads/standards/systemc
  3. Build with debug info:
    $ tar xvf systemc-2.3.3.tar.gz 
    $ cd systemc-2.3.3/
    $ mkdir build_debug
    $ cd build_debug/
    $ cmake ../ -DCMAKE_BUILD_TYPE=Debug -DCMAKE_CXX_STANDARD=14
    $ make -j8
    # build SystemC examples
    $ make check -j8
    # it is important to cd into example directory, sometimes they read some files from workdir
    $ cd examples/sysc/risc_cpu
    $ gdb_systemc_trace.py risc_cpu
    # systemc_trace.vcd file will be created
    
  4. Use GTKWave or other VCD viewer to view generated vcd:
 $ gtkwave systemc_trace.vcd 

risc_cpu

Running simulation with full trace dump

Tracing only required signals

  • ./gdb_systemc_trace.py -l path/to/your/simulation_executable
  • List of all detected signals in design will be printed to console
  • Copy required signal names (full hierarchical names) into some file, say signals.txt
  • ./gdb_systemc_trace.py -f signals.txt
  • systemc_trace.vcd will be created

Print design tree

  • ./gdb_systemc_trace.py -p path/to/your/simulation_executable

Passing arguments to simulation executable

  • ./gdb_systemc_trace.py path/to/your/simulation_executable argument_1 argument_2 ...

About

gdb python scripts for SystemC design introspection and tracing

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 55.3%
  • C++ 44.7%