Skip to content

Latest commit

 

History

History
36 lines (23 loc) · 2.03 KB

README.md

File metadata and controls

36 lines (23 loc) · 2.03 KB

The Rust Verification working group

This working group is intended to provide a forum for all things formal methods and verification for Rust. We anticipate significant overlap in requirements for tools and want to provide a central repository to exchange ideas and share progress.

For an overview of our current status, visit our (WIP) page.

Why Rust?

Most of the benefits of performing verification on Rust programs are directly derived from the guarantees of safe Rust. Unsafe code is significantly more complex, but it may be possible to define contracts that must be upheld at the unsafe boundary. For more information on the differences between safe and unsafe Rust, see the Rustonomicon.

  • No need to reason extensively about the memory model
  • Data races are eliminated
  • A substantial subset can be transformed into pure functions

Goals

  • Develop formal foundations for the Rust language (RustBelt).
  • Extract required information from the compiler
  • Design methods to formally verify programs written in Rust
  • Investigate ways to combine program verification with broader testing frameworks

Get Involved

Join our mailing list, get in touch with us or open a pull request to let us know about your Rust verification project.

We follow the Rust Code of Contact. Any concerns should be brought to [email protected]

License

The output of the verification working group is distributed under the following licenses: