This is a library which contains bindigns for RTL simulators and provides UVM like environment which simplifies feeding and checking the circuit running in RTL simulator. Goal of this library is to remove obscurity and support code reuse. Each simulation is just python object without special properties. This allows also integration with existing test frameworks and better test automation and debugging.
sudo apt install build-essential python3 cmake flex bison git libboost-dev libboost-all-dev- download verilator
- apply patches from
verilator_patches_tmp( as it is done in .travis.yml) - install verilator
- run
sudo python3 setup.py install --verilatorto install globally orpython3 setup.py install --user --verilatorto install to~/.local/... - Or if you want to just test this library without any kind of installation use
python3 setup.py build --verilatorto build c extensions.
Using windows is not recomended with verilator. Asi it is more easy to use docker than tweak Verilator to run on Windows as desired.
- install Python 3
- install Visual Studio (C++)
- install CMake
- install boost
- install Cygwin and save installer
setup-x86_64.exeto cygwin root. - use
ci_scripts/appveyor_install.shto install this library and it's dependencies
After installation verilator has to run under cygwin, but python and this library are not restricted.
- experimental UVM like environment
- experimental Python <-> Verilator RTL simulator binding (pycocotb.verilator)
- experimental Python based RTL simulator (pycocotb.basic_hdl_simulator)
- some examples in tests
- used in HWT, many example hardware tests can be found in hwtLib
- cocotb - there is also WIP version of cocotb-verilator integration
- cocotb-coverage - Functional Coverage and Constrained Randomization Extensions for Cocotb
- chisel-testers
- firesim
- fli - using ModelSim Foreign Language Interface for c – VHDL
- kratos - hardware generator/simulator
- midas
- py-hpi - Python/Simulator integration using procedure calls
- PyVSC Python package providing a library for Verification Stimulus and Coverage
- uvm-python - cocotb based python UVM