Iodine: Verifying Constant-Time Execution of Hardware

Klaus v. Gleissenthall,Rami Gökhan Kıcı,Deian Stefan,Ranjit Jhala
DOI: https://doi.org/10.48550/arXiv.1910.03111
2019-10-08
Abstract:To be secure, cryptographic algorithms crucially rely on the underlying hardware to avoid inadvertent leakage of secrets through timing side channels. Unfortunately, such timing channels are ubiquitous in modern hardware, due to its labyrinthine fast-paths and optimizations. A promising way to avoid timing vulnerabilities is to devise --- and verify --- conditions under which a hardware design is free of timing variability, i.e., executes in constant-time. In this paper, we present Iodine: a clock precise, constant-time approach to eliminating timing side channels in hardware. Iodine succeeds in verifying various open source hardware designs in seconds and with little developer effort. Iodine also discovered two constant-time violations: one in a floating-point unit and another one in an RSA encryption module.
Cryptography and Security
What problem does this paper attempt to address?