Back to Search Start Over

COGENT: Certified Compilation for a Functional Systems Language

Authors :
O'Connor, Liam
Rizkallah, Christine
Chen, Zilin
Amani, Sidney
Lim, Japheth
Nagashima, Yutaka
Sewell, Thomas
Hixon, Alex
Keller, Gabriele
Murray, Toby
Klein, Gerwin
Publication Year :
2016

Abstract

We present a self-certifying compiler for the COGENT systems language. COGENT is a restricted, polymorphic, higher-order, and purely functional language with linear types and without the need for a trusted runtime or garbage collector. It compiles to efficient C code that is designed to interoperate with existing C functions. The language is suited for layered systems code with minimal sharing such as file systems or network protocol control code. For a well-typed COGENT program, the compiler produces C code, a high-level shallow embedding of its semantics in Isabelle/HOL, and a proof that the C code correctly implements this embedding. The aim is for proof engineers to reason about the full semantics of real-world systems code productively and equationally, while retaining the interoperability and leanness of C. We describe the formal verification stages of the compiler, which include automated formal refinement calculi, a switch from imperative update semantics to functional value semantics formally justified by the linear type system, and a number of standard compiler phases such as type checking and monomorphisation. The compiler certificate is a series of language-level meta proofs and per-program translation validation phases, combined into one coherent top-level theorem in Isabelle/HOL.

Details

Language :
English
Database :
OpenAIRE
Accession number :
edsair.doi.dedup.....ff3a65df80ae01f88dbd2b2939dc0f97