Compcert is a compiler that generates PowerPC, ARM and x86 assembly code from Compcert C, a large subset of the C programming language. The particularity of this compiler is that it is written mostly within the specification language of the Coq proof assistant, and its correctness --- the fact that the generated assembly code is semantically equivalent to its source program --- was entirely proved within the Coq proof assistant.
High-level descriptions of the Compcert compiler and its proof of correctness can be found in the following papers (in increasing order of technical details):
This Web site gives a commented listing of the underlying Coq specifications and proofs. Proof scripts are folded by default, but can be viewed by clicking on "Proof". Some modules (written in italics below) differ between the three supported target architectures. The PowerPC versions of these modules are shown below; the ARM and x86 versions can be found in the source distribution.
This development is a work in progress; some parts have substantially changed since the overview papers above were written.
The complete sources for Compcert can be downloaded from the Compcert Web site.
This document and the Compcert sources are copyright 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Institut National de Recherche en Informatique et en Automatique (INRIA) and distributed under the terms of the following license.
Pass | Source & target | Compiler code | Correctness proof |
---|---|---|---|
Pulling side-effects out of expressions; fixing an evaluation order |
Compcert C to Clight | SimplExpr | SimplExprspec SimplExprproof |
Simplification of control structures; explication of type-dependent computations |
Clight to Csharpminor | Cshmgen | Cshmgenproof |
Stack allocation of local variables whose address is taken; simplification of switch statements |
Csharpminor to Cminor | Cminorgen | Cminorgenproof |
Recognition of operators and addressing modes |
Cminor to CminorSel | Selection SelectOp |
Selectionproof SelectOpproof |
Construction of the CFG, 3-address code generation |
CminorSel to RTL | RTLgen | RTLgenspec RTLgenproof |
Recognition of tail calls | RTL to RTL | Tailcall | Tailcallproof |
Function inlining | RTL to RTL | Inlining | Inliningspec Inliningproof |
Postorder renumbering of the CFG | RTL to RTL | Renumber | Renumberproof |
Constant propagation | RTL to RTL | Constprop ConstpropOp |
Constpropproof ConstproppOproof |
Common subexpression elimination | RTL to RTL | CSE | CSEproof |
Register allocation by coloring of an interference graph |
RTL to LTL | InterfGraph Coloring Allocation |
Coloringproof Allocproof |
Branch tunneling | LTL to LTL | Tunneling | Tunnelingproof |
Linearization of the CFG | LTL to LTLin | Linearize | Linearizeproof |
Removal of unreferenced labels | LTLin to LTLin | CleanupLabels | CleanupLabelsproof |
Spilling, reloading, calling conventions | LTLin to Linear | Reload Conventions Conventions1 |
Parallelmove Reloadproof |
Redundant reload elimination | Linear to Linear | RRE | RREproof |
Laying out the activation records | Linear to Mach | Stacking Bounds Stacklayout |
Stackingproof Asmgenretaddr |
Emission of assembly code | Mach to Asm | Asmgen | Asmgenproof1 Asmgenproof |