Skip to Main content Skip to Navigation
Journal articles

Automatic Application of Power Analysis Countermeasures

Abstract : We introduce a compiler that automatically inserts software countermeasures to protect cryptographic algorithms against power-based side-channel attacks. The compiler first estimates which instruction instances leak the most information through side-channels. This information is obtained either by dynamic analysis, evaluating an information theoretic metric over the power traces acquired during the execution of the input program, or by static analysis. As information leakage implies a loss of security, the compiler then identifies (groups of) instruction instances to protect with a software countermeasure such as random precharging or Boolean masking. As software protection incurs significant overhead in terms of cryptosystem runtime and memory usage, the compiler protects the minimum number of instruction instances to achieve a desired level of security. The compiler is evaluated on two block ciphers, AES and Clefia; our experiments demonstrate that the compiler can automatically identify and protect the most important instruction instances. To date, these software countermeasures have been inserted manually by security experts, who are not necessarily the main cryptosystem developers. Our compiler offers significant productivity gains for cryptosystem developers who wish to protect their implementations from side-channel attacks.
Document type :
Journal articles
Complete list of metadata
Contributor : David Novo Connect in order to contact the contributor
Submitted on : Tuesday, December 18, 2018 - 3:57:32 PM
Last modification on : Friday, August 5, 2022 - 3:02:14 PM

Links full text



Ali Galip Bayrak, Francesco Regazzoni, David Novo, Philip Brisk, François-Xavier Standaert, et al.. Automatic Application of Power Analysis Countermeasures. IEEE Transactions on Computers, Institute of Electrical and Electronics Engineers, 2015, 64 (2), pp.329-341. ⟨10.1109/TC.2013.219⟩. ⟨lirmm-01959272⟩



Record views