Skip to content

alainmarcel/simview

 
 

Repository files navigation

simview

Simview is a text-based SystemVerilog design browser and waveform viewer. As an ncurses TUI application, it has very little library dependencies and can be easily run over an SSH connection in your favorite terminal emulator. Control of the UI is intuitive and fully keyboard shortcut driven. While that may sound contradictory, there is nice contextual help for every function.

Simview is generally meant to debug and analyze hardware designs written in SystemVerilog. Support for non-synthesizable testbench code is limited.

Screenshot

Features

  • Full design parsing and elaboration, powered by Surelog.
  • Trace signal drivers or loads.
  • Waveform format support for VCD and FST, the most common formats written by Verilator.
  • Automatic (or manual) matching of wave file hierarchy to design hierarchy.
  • Send signals from source code to the wave viewer and vice versa.
  • Search source code and signal lists.

Usage

Simview can be launched with either a VCD/FST wave file, a SystemVerilog design, or both. To load a wave file use the -waves <file> command line option. All other command line options are passed to the Surelog parser. These generally match most EDA tools, with things like -timescale, +incdir, +define=val etc. Use -help to get the full list of parsing options from Surelog. Tips for UI navigation:

  • Use Tab to cycle through the available panes.
  • Keep an eye on the bottom tooltip bar for available commands.
  • Ctrl-arrow keys to resize UI panes.
  • Enter/space to expand collapse tree items.
  • vim-style hjkl keys generally work. Also $^ for horizontal and gG for vertical movement.

Build

Simview is written with C++17 and uses CMake as the build system. Linux or Linux under WSL are currently the only supported platforms, no native Windows or MacOSX support at the moment.

  1. Install pre-requisite packages (Ubuntu 20.04 LTS)
  • sudo apt install build-essential cmake git pkg-config tclsh swig uuid-dev libgoogle-perftools-dev python3 python3-dev default-jre lcov libncurses-dev
  1. Build and install Surelog
  • git clone git@github.com:chipsalliance/Surelog.git
  • cd Surelog
  • git submodule update --init --recursive
  • make
  • sudo make install
  1. Build simview:
  • git clone git@github.com:pieter3d/simview.git
  • cd simview
  • mkdir build
  • cd build
  • cmake ..
  • make

TODO

A list of features that have not yet been implemented.

  • Source viewer: Navigate include files
  • Settings file (libconfig)
    • Sort instances by name or by position in file
    • Customizable colors.
    • Source search: whole file or active scope?
    • Save UI layout dimensions?
  • A colorscheme that works with white backgrounds.
  • Polish: Syntax highlighting of macros
  • Source window: Need a clean way to add multiple signals from the source to the waves at once.
  • alternate layout maybe: left has waves and signals stacked vertically
  • Expose local nets in functions and tasks
  • Expose local variables in always blocks?
  • tracing loads does not trace things on the left side, e.g idx isn't traced in net[idx] = val;
  • Time multiplier for waves (e.g. wave 1 unit is really X us/ns/ps/)
  • Wave + source should be able to figure out enums in waves.
  • Reload waves, and possibly live updates.
  • Search for value in wave.
  • Analog signals.
  • Detect unrolled arrays in waves, make them expandable in the waveforms
  • Lazy / on-demand loading of VCD wave data. Not clear if this is useful since loading anything requires parsing the whole file anyway.
  • Someday: Support FSDB via dynamically loading the necessary .so's on systems that have them installed with a valid license.
  • Command line option to load a saved signal list file at startup.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 97.7%
  • CMake 1.3%
  • Python 1.0%