This is a project for composing a formal verification toolchain using TriCera, Frama-C and custom Frama-C plug-ins.
The development environment and toolchain are provided as a Dockerfile under the GNU GPLv2 license. For full license conditions, please see the LICENSE file
While not at all necessary for using the image, it is designed with
Visual Studio Code in mind, and more specifically, using it as a container
for remote development
in VSCode. An example/template of a
devcontainer configuration
can be found in this repository, in .devcontainer/devcontainer.json
.
In the examples we are using bash, but the syntax should be similar in your command line shell of choice.
The dockerfile will download things using a Java runtime environment
(JRE). JRE needs to know about proxies, so if you are building the
container while behind a proxy please provide the appropriate values
according to the example below. (Also remember that you might have to
set your HTTP_PROXY
and HTTPS_PROXY
environment variables.)
Of course you are free to choose any tag you like for your image.
git clone https://github.com/rse-verification/toolchain.git
cd toolchain/Dockerfiles
# Use the following for normal builds
docker build -t auto-deduct:0.1.0 -t auto-deduct:latest -f AutoDeductDockerfile .
# Use the follwing behind a proxy
docker build --build-arg PROXY_HOST=<your.proxy.name> --build-arg PROXY_PORT=<port> -t auto-deduct:0.1.0 -t auto-deduct:latest -f AutoDeductDockerfile .
Please note that building the container can take quite a while since a lot of OCAML modules for Frama-C are built from source during the container build.
All tools and source code are installed in the container to be used by
the user dev
. Password setup for this user is also dev
.
Apart from Scala (used by TriCera) and Frama-C things installed under
/home/dev/.local/...
there is also
-
/home/dev/repos/tricera
- Source code for TriCera model checker. The binaries are built as part of the container build, and symbolic links are created in/home/dev/.local/bin
-
/home/dev/repos/saida
- Source code for the Saida Frama-C plugin. The plugin is built and installed as an OCAML package as part of the container build. -
/home/dev/repos/interface-specification-propagator
- Source code for the the ISP (Interface Specification Propagator) Frama-C plugin. The plugin is built and installed as an OCAML package as part of the container build. -
/home/dev/repos/auto-deduct-examples
- Some helper scripts, and a set of examples on which the toolchain has been tested in practice.
Once you have built the container, you can start it
docker run -it auto-deduct
If you want to use the Frama-C GUI, you will need an X-window server running.
For Windows there are at least two X-servers
Make sure your server is started, then in your auto-deduct container start the Frama-C GUI from the command line.
frama-c-gui
However, if you use the image as a devcontainer for Visual Studio Code (VSCode), and run the GUI from a terminal inside VSCode, VSCode integrates with WSL. WSL already has support for Wayland and therefore there is no need for an extra X-server.
As long as you are running a GUI in your GNU/Linux distribution chances are very high that you already have a server installed. (There are two systems for GUIs on GNU/Linux, the X Window System provided by X.Org Server, and Wayland. If you are running Wayland chances are pretty high that you have some compatibility solution installed.) However, in order use your host's X server, you need start your container with additional arguments
docker run -it --env DISPLAY=$DISPLAY --volume /tmp/.X11-unix:/tmp/.X11-unix
To be done.