Skip to content

Tools for testing and verifying the safety and correctness of C programs.

License

Notifications You must be signed in to change notification settings

GaloisInc/VERSE-Toolchain

The VERSE Development Toolchain

This repository assembles the core technologies that make up the VERSE TA1 toolchain and packages them into IDE and CI/CD integrations.

This is a companion to the VERSE Open SUT repository for TA2.

[ VERSE project proposal ]

Toolchain Components

The VERSE toolchain brings together core technologies from EPFL, the University of Cambridge, the University of Illinois at Urbana-Champaign, the University of Maryland, the University of Massachusetts Amherst, and the University of Pennsylvania.

CN

Developers write inline specifications alongside their C code using the CN specification language. Additionally, CN's automated verification backend attempts to automatically prove specifications.

[ Homepage, paper, GitHub, manual ]

Runtime Specification Testing

Runtime spec testing is made up of two parts:

  1. Synthesizing test input from specifications, a form of property-based testing (PBT).
  2. Transliterating CN specifications into C runtime tests that check whether the spec holds for a specific program execution.

TBD: Links and details as these projects progress.

See Tyche and QuickChick (manual, GitHub) for inspiration.

Proof Synthesis, Repair and Visualization

CN provides an escape hatch to Roq (formerly Coq) to provide manual proofs of properties that cannot be automatically verified.

  • Proof synthesis attempts to automatically discharge these proof obligations.
  • Proof repair attempts to automatically fix existing proofs if the code associated with them changes.
  • Proof visualization assists the manual proof effort by tracking and visualizing complex C memory states and other proof details.

TBD: Links to project pages, more details as we discover them.

Installation and Use

Begin by installing OCaml and opam, if need be - here are instructions for how to do so. This build process has been tested with OCaml 4.14.1 and 5.1.1, though other versions are likely to work as well.

With a choice of version in hand, the easiest way to build this repo's packages is with a local opam switch, like so:

VERSION=4.14.1  # or 5.1.1
ln -s telemetry.opam.locked-$VERSION telemetry.opam.locked
ln -s cn-lsp.opam.locked-$VERSION cn-lsp.opam.locked
opam switch create . ocaml.$VERSION --locked -y
eval $(opam env)

If this command succeeds, it should install the cn-lsp and telemetry packages into your local switch.

The cn-lsp package includes a binary called cn-lsp-server. Any language clients should run the binary from there. If a client is run outside the context of your local switch, it may also need to set $CERB_RUNTIME to point to Cerberus's runtime file dependencies, which will have been installed in the switch at <opam-dir>/lib/cerberus/runtime.

How to run CN

You need (1) git and (2) docker (or a comparable alternative such as colima).

In the root directory invoke make.

How to Contribute