Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/DominicPM/supervisionary
Supervisionary: a proof-checking system for HOL
https://github.com/DominicPM/supervisionary
higher-order-logic rust theorem-prover theorem-proving wasm webassembly
Last synced: about 2 months ago
JSON representation
Supervisionary: a proof-checking system for HOL
- Host: GitHub
- URL: https://github.com/DominicPM/supervisionary
- Owner: DominicPM
- License: mit
- Created: 2021-01-25T18:03:23.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2023-05-02T20:01:05.000Z (over 1 year ago)
- Last Synced: 2024-05-22T20:33:40.949Z (8 months ago)
- Topics: higher-order-logic, rust, theorem-prover, theorem-proving, wasm, webassembly
- Language: Rust
- Homepage:
- Size: 4.84 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.markdown
- License: LICENSE
Awesome Lists containing this project
- awesome-rust-formalized-reasoning - Supervisionary - XowAo)[:lab_coat:](https://dominicpm.github.io/publications/mulligan-supervisionary-2022.pdf) - experimental proof-checking system for Gordon's higher-order logic. (Projects / Verification)
README
# The Supervisionary proof-checking system
![build badge](https://github.com/DominicPM/supervisionary/actions/workflows/ci.yaml/badge.svg)
*Supervisionary* is an experimental proof-checking system for Gordon's
higher-order logic ("HOL"). Rather than using programming language features to
isolate and protect the kernel, as in typical LCF-style implementations of HOL
like HOL4 and Isabelle, Supervisionary uses *privilege* akin to how an operating
system kernel is isolated and protected from untrusted user-space code, with the
two communicating across a defined system call interface.For more information, see the `paper/prisc22/prisc22.tex` two-page abstract, or
a pre-built
[PDF](https://dominicpm.github.io/publications/mulligan-supervisionary-2022.pdf),
of our accepted PriSC 2022 talk on Supervisionary and which relates the main
ideas behind the system.## Authors
Supervisionary was originally written by Dominic Mulligan and Nick Spinale,
Systems Research Group, Arm Research, Cambridge within the context of the
[Veracruz](https://github.com/veracruz-project/veracruz) project. Since 2022,
the system is exclusively developed and maintained by [Dominic
Mulligan](https://dominicpm.github.io).## System components
The repository contains the following components in similarly-named directories:
- *Kernel*: this is the core of the Supervisionary kernel, and is completely
execution-engine independent (well, almost).
- *Wasmi bindings*: this is the binding of the Supervisionary kernel to the
Wasmi execution engine so that Supervisionary can execute Wasm binaries.
- *libsupervisionary*: this is a user-space Rust support library that abstracts
over the raw Supervisionary system call interface.
- *Driver*: this is a command line application that reads a Wasm binary,
supplied on the command line, loads it, then executes it under the
Supervisionary virtual machine. Wasm binaries must be compiled using the
`wasm32-unknown-unknown` target and linked against `libsupervisionary`.
- *System interface*: provides a generic interface that Supervisionary can use
to query or manipulate aspects of the system, for example the filesystem, or
clock-related functions. Also provides a "pass through" implementation of
this interface which calls through to the underlying system executing
Supervisionary.
- *Tests*: these are test binaries linked against `libsupervisionary` that
exercise the different aspects of the Supervisionary system call interface.
These can be executed using `driver`, as explained below.## License and copyright
See the `LICENSE` file in the Supervisionary root directory for full details of
the MIT open-source license that Supervisionary is licensed under.## Build instructions
Assuming a semi-recent Rust toolchain installation, first install `cargo-make`:
```shell
λ > cargo install cargo-make
```Moreover, make sure the `wasm32-unknown-unknown` toolchain is installed, as
follows:```shell
λ > rustup target install wasm32-unknown-unknown
```Then to compile all Supervisionary components, do:
```shell
λ > cargo make build
```To compile and execute Supervisionary's integration tests, do:
```shell
λ > cargo make integration-tests
```To build Supervisionary documentation, do:
```shell
λ > cargo make document
```Note that generated documentation is placed in `./target/doc` in the
Supervisionary root directory.