Search papers, labs, and topics across Lattice.
The paper introduces SEIO*, a framework for securely extracting shallowly embedded F* programs with IO to a deeply embedded lambda-calculus. They achieve this by using relational quotation, where a metaprogram constructs a typing derivation for the shallowly embedded program, followed by a verified syntax-generation function. The authors prove in F* that SEIO* guarantees Robust Relational Hyperproperty Preservation (RrHP), a strong secure compilation criterion, thus advancing the state of the art in verified extraction beyond correctness to security.
Achieve secure compilation for extracted F* programs with IO, guaranteeing Robust Relational Hyperproperty Preservation (RrHP)—a stronger security criterion than prior verified extraction work.
Shallow embeddings that use monads to represent effects are popular in proof-oriented languages because they are convenient for formal verification. Once shallowly embedded programs are verified, they are often extracted to mainstream languages like OCaml or C and linked into larger codebases. The extraction process is not fully verified because it often involves quotation -- turning the shallowly embedded program into a deeply embedded one -- and verifying quotation remains a major open challenge. Instead, some prior work obtains formal correctness guarantees using translation validation to certify individual extraction results. We build on this idea, but limit the use of translation validation to a first extraction step that we call relational quotation and that uses a metaprogram to construct a typing derivation for the given shallowly embedded program. This metaprogram is simple, since the typing derivation follows the structure of the original program. Once we validate, syntactically, that the typing derivation is valid for the original program, we pass it to a verified syntax-generation function that produces code guaranteed to be semantically related to the original program. We apply this general idea to build SEIO*, a framework for extracting shallowly embedded F* programs with IO to a deeply embedded lambda-calculus while providing formal secure compilation guarantees. Using two cross-language logical relations, we devise a machine-checked proof in F* that SEIO* guarantees Robust Relational Hyperproperty Preservation (RrHP), a very strong secure compilation criterion that implies full abstraction as well as preservation of trace properties and hyperproperties against arbitrary adversarial contexts. This goes beyond the state of the art in verified and certifying extraction, which so far has focused on correctness rather than security.