SOFIA: Software and Control Flow Integrity Architecture

de Clercq R, Götzfried J, Übler D, Maene P, Verbauwhede I (2017)


Publication Type: Journal article, Original article

Publication year: 2017

Journal

Publisher: Elsevier Ltd

Book Volume: 68

Pages Range: 16-35

DOI: 10.1016/j.cose.2017.03.013

Abstract

Software components are frequently used in cyber-physical systems (CPSes) to control a physical mechanism, such as a valve or brakes on a car. These systems are extremely sensitive to software vulnerabilities, as their exploitation could lead to injury, damage to equipment, or environmental catastrophe. This paper proposes a hardware-based security architecture called SOFIA, which protects software running on microprocessors used in CPSes. SOFIA provides mechanisms to protect software integrity and control flow integrity. This allows the processor to defend against a large number of attacks, including code injection, code reuse, and fault-based attacks on the program counter. In addition, the architecture also defends against software copyright infringement and reverse engineering. All protection mechanisms are enforced in hardware using cryptographic techniques. We are the first to propose a mechanism to enforce control flow integrity at the finest possible granularity using cryptographic techniques. A SOFIA core has been created by implementing the proposed architectural features on a LEON3 microprocessor. The SOFIA core requires that its software conforms to a strict format. To this end, we additionally designed and implemented a software toolchain to compile source code that adheres to the formatting rules. Several benchmarks were compiled with the SOFIA toolchain, and were executed on a SOFIA core running on an FPGA, showing an average total execution time overhead of 106% compared to an unmodified LEON3 core. Our hardware evaluation shows a clock speed reduction of 23.2%.

Authors with CRIS profile

Involved external institutions

How to cite

APA:

de Clercq, R., Götzfried, J., Übler, D., Maene, P., & Verbauwhede, I. (2017). SOFIA: Software and Control Flow Integrity Architecture. Computers & Security, 68, 16-35. https://dx.doi.org/10.1016/j.cose.2017.03.013

MLA:

de Clercq, Ruan, et al. "SOFIA: Software and Control Flow Integrity Architecture." Computers & Security 68 (2017): 16-35.

BibTeX: Download