Visible to the public A Secure and Formally Verified Linux KVM Hypervisor

TitleA Secure and Formally Verified Linux KVM Hypervisor
Publication TypeConference Paper
Year of Publication2021
AuthorsLi, Shih-Wei, Li, Xupeng, Gu, Ronghui, Nieh, Jason, Zhuang Hui, John
Conference Name2021 IEEE Symposium on Security and Privacy (SP)
Date Publishedmay
Keywordscomposability, cryptography, cyber physical systems, Hardware, Information management, Linux, privacy, pubcrawl, resilience, Resiliency, security, Virtual machine monitors, virtual machine security, Virtual machining, virtualization privacy
Abstract

Commodity hypervisors are widely deployed to support virtual machines (VMs) on multiprocessor hardware. Their growing complexity poses a security risk. To enable formal verification over such a large codebase, we introduce microverification, a new approach that decomposes a commodity hypervisor into a small core and a set of untrusted services so that we can prove security properties of the entire hypervisor by verifying the core alone. To verify the multiprocessor hypervisor core, we introduce security-preserving layers to modularize the proof without hiding information leakage so we can prove each layer of the implementation refines its specification, and the top layer specification is refined by all layers of the core implementation. To verify commodity hypervisor features that require dynamically changing information flow, we introduce data oracles to mask intentional information flow. We can then prove noninterference at the top layer specification and guarantee the resulting security properties hold for the entire hypervisor implementation. Using microverification, we retrofitted the Linux KVM hypervisor with only modest modifications to its codebase. Using Coq, we proved that the hypervisor protects the confidentiality and integrity of VM data, while retaining KVM's functionality and performance. Our work is the first machine-checked security proof for a commodity multiprocessor hypervisor.

DOI10.1109/SP40001.2021.00049
Citation Keyli_secure_2021