1. Hypervisor-based Protection of Code
- Author
-
Amit Resh, Nezer Jacob Zaidenberg, Asaf Algawi, Michael Kiperberg, and Roee Leon
- Subjects
Computer Networks and Communications ,Computer science ,0211 other engineering and technologies ,Cryptography ,02 engineering and technology ,security ,Computer security ,computer.software_genre ,Encryption ,kryptografia ,Obfuscation ,Code (cryptography) ,tietoturva ,virtual machine monitors ,Safety, Risk, Reliability and Quality ,System bus ,trusted platform module ,ta113 ,021110 strategic, defence & security studies ,code protection ,cryptography ,business.industry ,Hypervisor ,Virtualization ,Obfuscation (software) ,business ,computer - Abstract
The code of a compiled program is susceptible to reverse-engineering attacks on the algorithms and the business logic that are contained within the code. The main existing countermeasure to reverse-engineering is obfuscation. Generally, obfuscation methods suffer from two main deficiencies: 1) the obfuscated code is less efficient than the original and 2) with sufficient effort, the original code may be reconstructed. We propose a method that is based on cryptography and virtualization. The most valuable functions are encrypted and remain inaccessible even during their execution, thus preventing their reconstruction. A specially crafted hypervisor is responsible for decryption, execution, and protection of the encrypted functions. We claim that the system can provide protection even if the attacker: 1) has access to the operating system kernel and 2) can intercept communication over the system bus. The evaluation of the system’s efficiency suggests that it can compete with and outperform obfuscation-based methods. peerReviewed
- Published
- 2019