Skip to content

rse-verification/auto-deduct-toolchain

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

auto-deduct-toolchain

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

Designed with VSCode in mind

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.

Building the docker image

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.

Container contents

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.

Starting the container

Once you have built the container, you can start it

docker run -it auto-deduct

Running the Frama-C GUI

If you want to use the Frama-C GUI, you will need an X-window server running.

On Windows

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.

On Linux

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

On Mac

To be done.

About

Project for composing a formal verification toolchain

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •