Secure Composition of Robust and Optimising Compilers
Matthis Kruse, Michael Backes, Marco Patrignani
TL;DR
The paper tackles the problem of understanding how security properties are preserved when composing secure compiler passes that may enforce different guarantees. It develops a general framework for secure composition using cross-language trace relations and universal image projections, and proves that composition preserves the intersection of property classes under suitable well-formedness conditions. A concrete case study demonstrates a six-pass pipeline that preserves the target property specms by combining passes for temporal and spatial memory safety, cryptographic constant time, and speculative safety, along with optimisations. The results provide a principled, modular approach to building secure compilers where end-to-end security of multi-pass pipelines derives from the security guarantees of the individual passes, with formal proofs and a Coq formalization accompanying the development.
Abstract
To ensure that secure applications do not leak their secrets, they are required to uphold several security properties such as spatial and temporal memory safety as well as cryptographic constant time. Existing work shows how to enforce these properties individually, in an architecture-independent way, by using secure compiler passes that each focus on an individual property. Unfortunately, given two secure compiler passes that each preserve a possibly different security property, it is unclear what kind of security property is preserved by the composition of those secure compiler passes. This paper is the first to study what security properties are preserved across the composition of different secure compiler passes. Starting from a general theory of property composition for security-relevant properties (such as the aforementioned ones), this paper formalises a theory of composition of secure compilers. Then, it showcases this theory a secure multi-pass compiler that preserves the aforementioned security-relevant properties. Crucially, this paper derives the security of the multi-pass compiler from the composition of the security properties preserved by its individual passes, which include security-preserving as well as optimisation passes. From an engineering perspective, this is the desirable approach to building secure compilers.
