CIDPro: Custom Instructions for Dynamic Program Diversification

Thinh Hung Pham,Alexander Fell,Arnab Kumar Biswas,Siew-Kei Lam,Nandeesha Veeranna
DOI: https://doi.org/10.48550/arXiv.1809.01221
2018-09-05
Abstract:Timing side-channel attacks pose a major threat to embedded systems due to their ease of accessibility. We propose CIDPro, a framework that relies on dynamic program diversification to mitigate timing side-channel leakage. The proposed framework integrates the widely used LLVM compiler infrastructure and the increasingly popular RISC-V FPGA soft-processor. The compiler automatically generates custom instructions in the security critical segments of the program, and the instructions execute on the RISC-V custom co-processor to produce diversified timing characteristics on each execution instance. CIDPro has been implemented on the Zynq7000 XC7Z020 FPGA device to study the performance overhead and security tradeoffs. Experimental results show that our solution can achieve 80% and 86% timing side-channel capacity reduction for two benchmarks with an acceptable performance overhead compared to existing solutions. In addition, the proposed method incurs only a negligible hardware area overhead of 1% slices of the entire RISC-V system.
Cryptography and Security,Hardware Architecture
What problem does this paper attempt to address?