Affiliation:
1. Yale University, New Haven, CT, USA
2. University of Science and Technology of China, Hefei, China
Abstract
Modern computer systems consist of a multitude of abstraction layers (e.g., OS kernels, hypervisors, device drivers, network protocols), each of which defines an interface that hides the implementation details of a particular set of functionality. Client programs built on top of each layer can be understood solely based on the interface, independent of the layer implementation. Despite their obvious importance, abstraction layers have mostly been treated as a system concept; they have almost never been formally specified or verified. This makes it difficult to establish strong correctness properties, and to scale program verification across multiple layers.
In this paper, we present a novel language-based account of abstraction layers and show that they correspond to a strong form of abstraction over a particularly rich class of specifications which we call deep specifications. Just as data abstraction in typed functional languages leads to the important representation independence property, abstraction over deep specification is characterized by an important implementation independence property: any two implementations of the same deep specification must have contextually equivalent behaviors. We present a new layer calculus showing how to formally specify, program, verify, and compose abstraction layers. We show how to instantiate the layer calculus in realistic programming languages such as C and assembly, and how to adapt the CompCert verified compiler to compile certified C layers such that they can be linked with assembly layers. Using these new languages and tools, we have successfully developed multiple certified OS kernels in the Coq proof assistant, the most realistic of which consists of 37 abstraction layers, took less than one person year to develop, and can boot a version of Linux as a guest.
Funder
Defense Advanced Research Projects Agency
National Natural Science Foundation of China
National Science Foundation
China Scholarship Council
Office of Naval Research
Publisher
Association for Computing Machinery (ACM)
Subject
Computer Graphics and Computer-Aided Design,Software
Cited by
20 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. Survey of the Formal Verification of Operating Systems in Power Monitoring System;Proceedings of the 2023 5th International Conference on Pattern Recognition and Intelligent Systems;2023-07-28
2. Applying Rely-Guarantee Reasoning on Concurrent Memory Management and Mailbox in $$\mu $$C/OS-II: A Case Study;Formal Methods for Industrial Critical Systems;2023
3. A Modeling Concept for Formal Verification of OS-Based Compositional Software;Fundamental Approaches to Software Engineering;2023
4. Formal Modeling and Security Analysis for Intra-level Privilege Separation;Proceedings of the 38th Annual Computer Security Applications Conference;2022-12-05
5. Giallar: push-button verification for the qiskit Quantum compiler;Proceedings of the 43rd ACM SIGPLAN International Conference on Programming Language Design and Implementation;2022-06-09