BootKeeper: Validating Software Integrity Properties on Boot Firmware Images
Ronny Chevalier,Stefano Cristalli,Christophe Hauser,Yan Shoshitaishvili,Ruoyu Wang,Christopher Kruegel,Giovanni Vigna,Danilo Bruschi,Andrea Lanzi
DOI: https://doi.org/10.1145/3292006.3300026
2019-03-29
Abstract:Boot firmware, like UEFI-compliant firmware, has been the target of numerous attacks, giving the attacker control over the entire system while being undetected. The measured boot mechanism of a computer platform ensures its integrity by using cryptographic measurements to detect such attacks. This is typically performed by relying on a Trusted Platform Module (TPM). Recent work, however, shows that vendors do not respect the specifications that have been devised to ensure the integrity of the firmware's loading process. As a result, attackers may bypass such measurement mechanisms and successfully load a modified firmware image while remaining unnoticed. In this paper we introduce BootKeeper, a static analysis approach verifying a set of key security properties on boot firmware images before deployment, to ensure the integrity of the measured boot process. We evaluate BootKeeper against several attacks on common boot firmware implementations and demonstrate its applicability.
Cryptography and Security