Ferrocene

Ferrocene, a specification that aims to certify Rust for certain safety-critical environments, and why we do not consider it a formal specification.

Ferrocene is a version of the Rust toolchain that is certified for use in certain safety-critical systems, like the software that runs in your car. In order to be legally certified for such uses, there needs to be a specification of what Rust is supposed to behave like. The Ferrocene Language Specification (FLS) is that specification. Thus, it describes (in formal prose) various aspects of Rust's type system and operational semantics.

The Ferrocene spec is a large step towards a specification. It gives a detailed account of many aspects of the language, and is sometimes extremely rigorous.

Unfortunately, the specification does not apply this level of rigor everywhere. Large parts of Rust are only described in broad terms. For example, the spec only gives a short, "axiomatic" account of borrow checking. It does not describe how the borrow checker actually works (in terms of an algorithm), and the given rules are written in prose, which makes them ambiguous.

The Ferrocene Language Specification has now been donated to the Rust project, to be used as a starting point for Rust's specification. This means that the FLS might soon be officially "blessed" by the Rust project.

For us, the main problems with the FLS are that it is insufficiently formal, as showcased by the example above; this is coupled to the spec's use of English. We hope that this will change in future, and indeed the plan for Rust's specification would allow stricter formalisms for important parts, instead of attempting an English prose description.

Do you know something we don't?

Did we miss something important? Or maybe you just recently launched something that should be listed here, too? Let us know!