Abstract
A common type of memory error in the Linux kernel is using uninitialized variables (uninitialized use). Uninitialized uses not only cause undefined behaviors but also impose a severe security risk if an attacker takes control of the uninitialized variables. However, reliably exploiting uninitialized uses on the kernel stack has been considered infeasible until now since the code executed prior to triggering the vulnerability must leave an attacker-controlled pattern on the stack. Therefore, uninitialized uses are largely overlooked and regarded as undefined behaviors, rather than security vulnerabilities. In particular, full memory-safety techniques (e.g., SoftBound+CETS) exclude uninitialized use as a prevention target, and widely used systems such as OpenSSL even use uninitialized memory as a randomness source. In this paper, we propose a fully automated targeted stack-spraying approach for the Linux kernel that reliably facilitates the exploitation of uninitialized uses. Our targeted stack-spraying includes two techniques: (1) a deterministic stack spraying technique that suitably combines tailored symbolic execution and guided fuzzing to identify kernel inputs that user-mode programs can use to deterministically guide kernel code paths and thereby leave attacker-controlled data on the kernel stack, and (2) an exhaustive memory spraying technique that uses memory occupation and pollution to reliably control a large region of the kernel stack. We show that our targeted stack-spraying approach allows attackers to reliably control more than 91% of the Linux kernel stack, which, in combination with uninitialized-use vulnerabilities, suffices for a privilege escalation attack. As a countermeasure, we propose a compiler-based mechanism that initializes potentially unsafe pointer-type fields with almost no performance overhead. Our results show that uninitialized use is a severe attack vector that can be readily exploited with targeted stack-spraying, so future memory-safety techniques should consider it a prevention target, and systems should not use uninitialized memory as a randomness source.
Original language | English (US) |
---|---|
Title of host publication | 24th Annual Network and Distributed System Security Symposium, NDSS 2017 |
Publisher | The Internet Society |
ISBN (Electronic) | 1891562460, 9781891562464 |
DOIs | |
State | Published - 2017 |
Externally published | Yes |
Event | 24th Annual Network and Distributed System Security Symposium, NDSS 2017 - San Diego, United States Duration: Feb 26 2017 → Mar 1 2017 |
Publication series
Name | 24th Annual Network and Distributed System Security Symposium, NDSS 2017 |
---|
Conference
Conference | 24th Annual Network and Distributed System Security Symposium, NDSS 2017 |
---|---|
Country/Territory | United States |
City | San Diego |
Period | 2/26/17 → 3/1/17 |
Bibliographical note
Publisher Copyright:© 2017 24th Annual Network and Distributed System Security Symposium, NDSS 2017. All Rights Reserved.