SkySkimmer / argosy

Proving crash safety for systems with layered recovery

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Argosy: verifying layered storage systems with recovery refinement

Build Status

Proving crash safety of systems by proving an implementation refines a specification. Argosy supports implementing layered storage systems with a recovery procedure per layer, and modular verification of each layer independent of the other recovery procedures. Argosy also includes an implementation of Crash Hoare Logic (CHL), a program logic based on Hoare logic for proving an invariant for recovery reasoning.

Using Argosy we verified an extended example consisting of a write-ahead log running on top of a disk replication system. See README.md for details on extracting and running the example.

Compiling

We develop Argosy using Coq master. It should be compatible with Coq v8.11, which is tested as part of continuous integration.

This project uses git submodules to include several dependencies. Before compiling, run git submodule update --init --recursive to set those up.

To compile just run make with Coq on your $PATH.

Details on extraction for the logging example are in its own README.md.

About

Proving crash safety for systems with layered recovery

License:MIT License


Languages

Language:Coq 89.3%Language:Haskell 5.7%Language:Shell 3.5%Language:Makefile 0.6%Language:Python 0.5%Language:CSS 0.2%Language:Emacs Lisp 0.1%