SMaCk: Efficient Instruction Cache Attacks via Self-Modifying Code Conflicts
Seonghun Son, Daniel Moghimi, Berk Gulmezoglu
TL;DR
This work exposes a new vein of microarchitectural vulnerability by showing that self-modifying code (SMC) on x86 CPUs triggers detectable conflicts in the L1 instruction cache, which can be exploited to perform refined cache attacks and high-bandwidth covert channels. The authors introduce SMaCk, a suite of attack primitives (e.g., Prime+iProbe, Flush+iReload, Prime+iStore) and demonstrate multiple case studies—including RSA key leakage, OpenSSL SRP single-trace leakage, and ISpectre—across diverse Intel and AMD platforms. They also develop a dynamic detection approach using hardware performance counters to identify SMC-driven attacks with high accuracy and discuss practical countermeasures, including constant-time implementations and SMT management. The work significantly expands the threat model for instruction-cache side channels and provides concrete methods, evidence across architectures, and defense guidance with potential impact on secure cryptographic implementations and cloud multi-tenancy scenarios.
Abstract
Self-modifying code (SMC) allows programs to alter their own instructions, optimizing performance and functionality on x86 processors. Despite its benefits, SMC introduces unique microarchitectural behaviors that can be exploited for malicious purposes. In this paper, we explore the security implications of SMC by examining how specific x86 instructions affecting instruction cache lines lead to measurable timing discrepancies between cache hits and misses. These discrepancies facilitate refined cache attacks, making them less noisy and more effective. We introduce novel attack techniques that leverage these timing variations to enhance existing methods such as Prime+Probe and Flush+Reload. Our advanced techniques allow adversaries to more precisely attack cryptographic keys and create covert channels akin to Spectre across various x86 platforms. Finally, we propose a dynamic detection methodology utilizing hardware performance counters to mitigate these enhanced threats.
