data:image/s3,"s3://crabby-images/f7fee/f7fee79c83bcba139066b214c1a4e3f0fc484294" alt="Codeblocks compiler never finishes"
data:image/s3,"s3://crabby-images/eba76/eba768334b318d093c29d55a9c28bbec22bf3a3f" alt="codeblocks compiler never finishes codeblocks compiler never finishes"
This work presents a model JIT with dynamic generation of native code, implemented and formally verified in Coq. Traditional static compilers like CompCert have been mechanized in proof assistants, but JITs have been scarcely formalized so far, partly due to their impure nature and their numerous components.
data:image/s3,"s3://crabby-images/bf1dc/bf1dcb7b71dfe38b88e4f14c7c0a9aef1e14ddf0" alt="codeblocks compiler never finishes codeblocks compiler never finishes"
Such compilers are complex pieces of software with various components, and greatly rely on a precise interplay between the different languages being executed, including on-stack-replacement. Although some time is spent compiling dynamically, this mechanism makes for much faster times for the remaining of the program execution. But after a while, JITs dynamically produce native code for parts of the program they execute often. For faster startup times and to observe the initial behavior of an execution, interpretation can be initially used.
data:image/s3,"s3://crabby-images/684ab/684abfe3dec670349160b1e1589b1042c54340f2" alt="codeblocks compiler never finishes codeblocks compiler never finishes"
Modern Just-in-Time compilers (or JITs) typically interleave several mechanisms to execute a program. We have demonstrated the effectiveness of our framework for implementation and for verification through two file system implementations. The refinement theorem connecting the two semantics allows the compiler to produce a proof via translation validation certifying the correctness of the generated C code with respect to the semantics of the Cogent source program. Moreover, it allows us to assign two semantics to the language: The first semantics is imperative, suitable for efficient C code generation, and the second is purely functional, providing a user-friendly interface for equational reasoning and verification of higher-level correctness properties. A central aspect of the language is its uniqueness type system, which eliminates the need for a trusted runtime or garbage collector while still guaranteeing memory safety, a crucial property for safety and security. The framework is designed around a new functional programming language, Cogent.
data:image/s3,"s3://crabby-images/9fcbd/9fcbd1ee0fe3d04e6cb79b3924e8aa9775ba661d" alt="codeblocks compiler never finishes codeblocks compiler never finishes"
This paper presents a framework aimed at significantly reducing the cost of proving functional correctness for low-level operating systems components.
data:image/s3,"s3://crabby-images/f7fee/f7fee79c83bcba139066b214c1a4e3f0fc484294" alt="Codeblocks compiler never finishes"