Skip to main content

No project description provided

Project description

fsim is a lightweight SystemVerilog simulator based on userland fibers. It leverages slang as a frontend to parse any SystemVerilog files. fsim is guided by the following design goals:

  1. Concurrent and event-driven. Fine-grained multi-threading using fibers.

  2. Performant. Compiles SystemVerilog into C++ code.

  3. Fast to compile. Supports incremental and parallel builds builds via ninja.

How to install

The easiest way to install is via pip. Simply do

pip install fsim

Notice that for maximum compatibility, the Linux wheel is shipped with gcc, which allows xfim to be installed on any Linux system. macOS should work out of the box if the development tools are installed.

To build from source, you can use the following commands. Notice that you also need ninja installed in your environment path.

git submodule update --init
mkdir build
cd build
cmake .. -DCMAKE_BUILD_TYPE=Release
make -j

Usage

Once fsim is installed, you should find fsim executable in your path. The usage is similar to other commercial simulators and C/C++ compilers. For instance, to run a simple testbench, we can do

fsim design.sv tb.sv

The command above will compile the SystemVerilog into an executable called fsim.out. You can override it with -o option. You can then start the simulation by running the executable. A working directory called fsim_dir is created to store compilation files.

To run the simulation automatically after the compilation, we can use -R flag, e.g.:

fsim -R design.sv tb.sv

This feature is simular to Incisive/Xcelium. Notice that if the files are unmodified, subsequent run will not trigger a new compilation.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

fsim-0.0.5-py3-none-manylinux1_x86_64.whl (94.2 MB view details)

Uploaded Python 3

fsim-0.0.5-py3-none-macosx_11_0_x86_64.whl (2.3 MB view details)

Uploaded Python 3 macOS 11.0+ x86-64

File details

Details for the file fsim-0.0.5-py3-none-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for fsim-0.0.5-py3-none-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 8acac9820c927c896bf4e9e85f00ab39419f352e5c1fb7c1fd287bf81bddfe69
MD5 6ebe6d07b6555f8748b75b9b8fb8d32c
BLAKE2b-256 2c3ede13aaa400f38a6b48abc7e2a5e63e3f073809c87cc2ce1064cb5e35302e

See more details on using hashes here.

File details

Details for the file fsim-0.0.5-py3-none-macosx_11_0_x86_64.whl.

File metadata

File hashes

Hashes for fsim-0.0.5-py3-none-macosx_11_0_x86_64.whl
Algorithm Hash digest
SHA256 3b8968c35bbf29056c644f5e046ba530ec5d1d95868fca1431c307747062161c
MD5 8407da8ce3eb2cdb6811df18a4715b39
BLAKE2b-256 5c18d72746bf318e644502a7c9dc93ea36336b2bea9630be4066c98f4995f778

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page