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:
Concurrent and event-driven. Fine-grained multi-threading using fibers.
Performant. Compiles SystemVerilog into C++ code.
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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
File details
Details for the file fsim-0.0.5-py3-none-manylinux1_x86_64.whl
.
File metadata
- Download URL: fsim-0.0.5-py3-none-manylinux1_x86_64.whl
- Upload date:
- Size: 94.2 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8acac9820c927c896bf4e9e85f00ab39419f352e5c1fb7c1fd287bf81bddfe69 |
|
MD5 | 6ebe6d07b6555f8748b75b9b8fb8d32c |
|
BLAKE2b-256 | 2c3ede13aaa400f38a6b48abc7e2a5e63e3f073809c87cc2ce1064cb5e35302e |
File details
Details for the file fsim-0.0.5-py3-none-macosx_11_0_x86_64.whl
.
File metadata
- Download URL: fsim-0.0.5-py3-none-macosx_11_0_x86_64.whl
- Upload date:
- Size: 2.3 MB
- Tags: Python 3, macOS 11.0+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3b8968c35bbf29056c644f5e046ba530ec5d1d95868fca1431c307747062161c |
|
MD5 | 8407da8ce3eb2cdb6811df18a4715b39 |
|
BLAKE2b-256 | 5c18d72746bf318e644502a7c9dc93ea36336b2bea9630be4066c98f4995f778 |