Skip to content

Commit

Permalink
Add "Proof Guide" document following review in PR 246
Browse files Browse the repository at this point in the history
This PR add a guide to proof using CBMC for the mlkem-native project
in cbmc/proofs/proof_guide.md

The document contains:
* Onboarding and installation guide for CBMC
* Common proof "patterns"
* Advice on writing loop invariants and contracts
* A step-by-step guide to producing a new proof of a C function
* A worked example of the above process.

Signed-off-by: Rod Chapman <[email protected]>
  • Loading branch information
rod-chapman committed Nov 8, 2024
1 parent 8001044 commit 6f5e75c
Show file tree
Hide file tree
Showing 3 changed files with 464 additions and 4 deletions.
5 changes: 4 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -32,9 +32,12 @@ ENVIRONMENT OR TO PROTECT ANY SENSITIVE DATA.** Once we have the first stable ve

#### Verification

Mostly TODO. We apply CBMC to verify the absence of UB in a few basic C routines, but the bulk of the C verification
Mostly TODO. We apply [CBMC](https://github.com/diffblue/cbmc) to verify type-safety and the absence of
UB in a few basic C routines, but the bulk of the C verification
is outstanding. No formal verification has yet been applied to the backends.

See the [Proof README](cbmc/proofs/README.md) and [Proof Guide](cbmc/proofs/proof_guide.md) for more details.

### Getting started

### Nix setup
Expand Down
11 changes: 8 additions & 3 deletions cbmc/proofs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,8 @@ of certain classes of undefined behaviour for parts of the C-code in mlkem-nativ
Proofs are organized by functions, with the harnesses and proofs for each function
in a separate directory.

TODO: Provide more information about CBMC and the properties it proves
See the [Proof Guide](proof_guide.md) for a walkthrough of how to use CBMC and
develop new proofs.

# Usage

Expand All @@ -26,6 +27,10 @@ If `GITHUB_STEP_SUMMARY` is set, the proof summary will be appended to it.

# Covered functions

The following functions are currently covered:
Each proved function has an eponymous sub-directory of its own. The shell command

- `poly.c`: `poly_compress`
```
find . -name cbmc-proof.txt
```

yields a list of the subdirectories, and thus function names, that have a proof.
Loading

0 comments on commit 6f5e75c

Please sign in to comment.