mirror of
https://github.com/verilator/verilator.git
synced 2025-01-24 23:34:45 +00:00
525c79bd0a
This adds files to build and run two Docker images: - run: Build a Docker container that can be used as an executable drop-in for verilator. This can be useful to test behavior of older versions or a development version. The functionality is pretty simplistic at the moment for a start. - buildenv: Everything needed to build and test Verilator. Useful to run quick tests in the cloud or try other compilers. It can also serve as basis for further CI integration.
50 lines
1.7 KiB
Plaintext
50 lines
1.7 KiB
Plaintext
= Docker Container as Verilator executable
|
|
|
|
This allows you to run Verilator easily as a docker image, e.g.:
|
|
|
|
docker run -ti verilator/verilator:latest --version
|
|
|
|
This is in particular useful to compare against older version or to
|
|
check when an issue was introduced.
|
|
|
|
You will need to give it access to your files as a volume and fix the
|
|
user rights:
|
|
|
|
....
|
|
docker run -ti -v ${PWD}:/work --user $(id -u):$(id -g) verilator/verilator:latest --cc test.v
|
|
....
|
|
|
|
The caveat is that it can only access files below the current
|
|
directory then, a workaround is to adopt the volume and set
|
|
`-workdir`.
|
|
|
|
There is a convenience script in this folder that wraps around the
|
|
docker calls:
|
|
|
|
$ verilator-docker 3.922 --version
|
|
Verilator 3.922 2018-03-17 rev UNKNOWN_REV
|
|
|
|
Finally, you can also work in the container by setting the entrypoint
|
|
(don't forget to mount a volume if you want your work persistent):
|
|
|
|
docker run -ti --entrypoint /bin/bash verilator/verilator:latest
|
|
|
|
The other files in this folder all for building the containers and to
|
|
store in them. You could use it to build Verilator at a specific
|
|
commit:
|
|
|
|
docker build --build-arg SOURCE_COMMIT=<commit> .
|
|
|
|
== Internals
|
|
|
|
The Dockerfile is pretty straight-forward, it builds Verilator and
|
|
removes the tree after that to reduce the image size. It sets a
|
|
wrapper script (`verilator-wrap.sh`) as entrypoint. This script calls
|
|
Verilator but also copies the verilated runtime files to the `obj_dir`
|
|
or the `-Mdir` respectively. This allows the user to build the C++
|
|
output with the matching runtime files. The wrapper patches the
|
|
generated Makefile accordingly.
|
|
|
|
There is also a hook defined that is run by docker hub via automated
|
|
builds.
|