Publication | Open Access
Spectre Attacks: Exploiting Speculative Execution
264
Citations
17
References
2019
Year
Unknown Venue
Modern ProcessorsEngineeringInformation SecurityComputer ArchitectureSpeculative ExecutionSide-channel AttackSoftware AnalysisFormal VerificationHardware SecurityShared MemoryTrusted Execution EnvironmentCompilersMemory ManagementOperating System SecurityComputer EngineeringSpectre AttacksComputer ScienceBranch PredictionData SecurityProgram AnalysisAttack ModelSystem SoftwareTransactional Memory
Modern processors use branch prediction and speculative execution to maximize performance, but speculative logic can access victim memory and registers, enabling side‑channel leaks exploited by Spectre attacks. The paper presents practical attacks that combine side‑channel, fault, and return‑oriented programming techniques to read arbitrary memory from a victim process. These attacks exploit speculative execution to induce the victim to perform operations that would not occur during correct execution, leaking confidential information via measurable side‑channel effects. The attacks expose a serious threat to real systems, violating core security assumptions of operating‑system process isolation, containerization, just‑in‑time compilation, and existing countermeasures, and are present in Intel, AMD, and ARM processors used worldwide.
Modern processors use branch prediction and speculative execution to maximize performance. For example, if the destination of a branch depends on a memory value that is in the process of being read, CPUs will try to guess the destination and attempt to execute ahead. When the memory value finally arrives, the CPU either discards or commits the speculative computation. Speculative logic is unfaithful in how it executes, can access the victim's memory and registers, and can perform operations with measurable side effects. Spectre attacks involve inducing a victim to speculatively perform operations that would not occur during correct program execution and which leak the victim's confidential information via a side channel to the adversary. This paper describes practical attacks that combine methodology from side channel attacks, fault attacks, and return-oriented programming that can read arbitrary memory from the victim's process. More broadly, the paper shows that speculative execution implementations violate the security assumptions underpinning numerous software security mechanisms, including operating system process separation, containerization, just-in-time (JIT) compilation, and countermeasures to cache timing and side-channel attacks. These attacks represent a serious threat to actual systems since vulnerable speculative execution capabilities are found in microprocessors from Intel, AMD, and ARM that are used in billions of devices. While makeshift processor-specific countermeasures are possible in some cases, sound solutions will require fixes to processor designs as well as updates to instruction set architectures (ISAs) to give hardware architects and software developers a common understanding as to what computation state CPU implementations are (and are not) permitted to leak.
| Year | Citations | |
|---|---|---|
Page 1
Page 1