Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dapphub/k-dss

formal verification of multicollateral dai in the K framework
https://github.com/dapphub/k-dss

Last synced: about 2 months ago
JSON representation

formal verification of multicollateral dai in the K framework

Awesome Lists containing this project

README

        

Table of Contents
=================

* [Installation](#installation)
* [dependencies](#dependencies)
* [build](#build)
* [Usage](#usage)
* [Progress](#progress)
* [Documentation](#documentation)
* [specification format](#specification-format)
* [License](#license)

This repo contains the formal specification and verification of [multicollateral dai](https://github.com/makerdao/dss).

The behavior of the contracts is specified in a literate format at [dss.md](src/dss.md), which generates a series of reachability claims, defining `succeeding` and `reverting` behavior for each function of each contract. These reachability claims are then tested against the [formal semantics of the EVM](https://github.com/kframework/evm-semantics) using the [klab](https://github.com/dapphub/klab) tool for interactive proof inspection and debugging.

An html version of the specification, together with links to in-browser symbolic execution previews, is available at [dapp.ci/k-dss](https://dapp.ci/k-dss)

# Installation
## dependencies
* klab. Installation instructions can be found at [klab](https://github.com/dapphub/klab).

## build
```sh
git clone [email protected]:dapphub/k-dss.git
make
```

This will download and build the target contracts in `dss/`, and compile the literate specifications in `src/` to K specifications, saving the results in `out/specs`.

# Usage

To run a proof with [klab](https://github.com/dapphub/klab), try:

```sh
klab prove --dump out/specs/proof-Vat_dai_pass_rough.k
```

After it finishes, you can open an interactive debug session to exploring the success behaviour of the `dai()` method of the contract `Vat`:

```sh
klab debug $(klab hash out/specs/proof-Vat_dai_pass_rough.k)
```

If you aren't interested in exploring with the debugger, you can omit the `--dump` flag for better performance.

# Progress

You can inspect the current state of the proofs in the CI running at [dapp.ci](https://dapp.ci/k-dss).

# Documentation

To build the literate specification in HTML, run `make doc`. The output of this process is available at [dapp.ci/k-dss](https://dapp.ci/k-dss).

## specification format
The format used in [dss.md](src/dss.md) provides a concise way of specifying the behavior of a contract method (see [act-mode](https://github.com/livnev/act-mode) for a simple emacs major mode for `.act` specs).

Let's break down the specification of the behavior of the function `heal` in the contract `Vat`:

```act
behaviour heal of Vat
interface heal(bytes32 u, bytes32 v, int256 rad)

types

Can : uint256
Dai_v : uint256
Sin_u : uint256
Debt : uint256
Vice : uint256

storage

#Vat.wards(CALLER_ID) |-> Can
#Vat.dai(v) |-> Dai_v => Dai_v - rad
#Vat.sin(u) |-> Sin_u => Sin_u - rad
#Vat.debt |-> Debt => Debt - rad
#Vat.vice |-> Vice => Vice - rad

iff

Can == 1

iff in range uint256

Dai_v - rad
Sin_u - rad
Debt - rad
Vice - rad
```

This snippet of code will generate two reachability claims, `proof-Vat_heal_succ.k` and `proof-Vat_heal_fail.k`. Both of these claims will refer to the bytecode of the contract `Vat` and use the function signature of `heal(bytes32,bytes32,int256)` as the first 4 bytes of calldata (keeping the rest of the calldata abstract). In the `success` spec, the conditions under the `iff` headers are postulated, while in the `fail` spec their negation is.

The interesting part of this particular function happens under the `storage` header. The meaning of the line:
`#Vat.dai(v) |-> Dai_v => Dai_v - rad`
is that in the `success` case, the value at the storage location which we call `#Vat.dai(v)` will be updated from `Dai_v` to `Dai_v - rad`.

To prove this reachability claim, the k prover explores all possible execution paths starting from the precondition (whats on the left hand side of a `=>`) and the claim is proven if they all end in a state satisfying the postcondition (right hand side of the `=>`).

More information about how the K prover and the K Framework in general works can be found at [Semantics-Based Program Verifiers for All Languages](http://fsl.cs.illinois.edu/FSL/papers/2016/stefanescu-park-yuwen-li-rosu-2016-oopsla/stefanescu-park-yuwen-li-rosu-2016-oopsla-public.pdf) and a detailed description of the semantics of EVM defined in K is given in [KEVM: A Complete Semantics of the Ethereum Virtual Machine](https://www.ideals.illinois.edu/handle/2142/97207).

# License
All applicable work in this repository is licensed under AGPL-3.0. Authors:
* Lev Livnev
* Denis Erfurt
* Martin Lundfall